Controller keys and joysticks binding UI
Per-game controller keys binding profiling
Even though it's been 7.5 years since this issue was published here, I'll leave a like and subscribe to updates if they ever happen. However, given the four years since the app's last release, there's little hope for continued development of Fuse.
I have totally missed the fact that IF1 ULA detects the falling edge of the byte leader pulse, thus providing hardware synchronisation for every byte. With that in mind, "playback" works and broadcast transmissions are working, too. Code is nice and clean and I like it. However, there is a significant (~5 msec) delay before the receiving machine sees inbound data and it breaks everything because at the time receiver sends ACK back to the sender the sender has already started re-transmission. Latest...
Most of the programmes (I've seen so far) utilising CMD18 and CMD25 seem to expect Z-Controller SD card interface, and those appear to be using quite a lot of SPI mode commands. Next revision of the patch, adds basic support for CMD16 and CMD59.
SD Card: multiple block read/write support
Hi all, Fuse team is busy with real life issues (me too) and I think we are not in a position to do a new release :-( Master branch is stable, though. Code contributions deserve more attention and all the gratitude. I'll try to review them if I get free time.
Yeah it would be nice to make a new release, at least to fix bug #509: https://sourceforge.net/p/fuse-emulator/bugs/509/ Sergio, what do you think?
Hi, I was curious if there is a plan to make a new release of fuse? I see there are about 186 commits since release 1.5.7 (including one of mine from last January). Many thanks! Pete
User ROMs directory
It worked by appending zeroes to the file: $ dd if=/dev/zero of=zeroes bs=1 count=$((16384-2048)) $ cat CIP-01\ \(19xx\)\(Intreprindera\ Electronica\).rom zeroes > CIP.rom
I have the following two roms: $ ls -l total 48 -rw-r--r--. 1 x x 2048 Sep 29 2023 'CIP-01 (19xx)(Intreprindera Electronica).rom' -rw-r--r--. 1 x x 16384 Sep 29 2023 'CIP-03 (19xx)(Intreprindera Electronica).rom' I can use the 16384 bytes rom just fine, but not the 2048 one: $ fuse --rom-48 CIP-03\ \(19xx\)\(Intreprindera\ Electronica\).rom $ fuse --rom-48 CIP-01\ \(19xx\)\(Intreprindera\ Electronica\).rom [...] fuse: error: ROM 'CIP-01 (19xx)(Intreprindera Electronica).rom' is 2048 bytes long; expected...
build: Fix Libspectrum build workflow for MacOs. Audiofile disabled in brew, libgcrypt not working.
Wrong branch :(
build: Fix Libspectrum build workflow for MacOs. Audiofile disabled in brew, libgcrypt not working.
build: Fix Libspectrum build workflow for MacOs. Audiofile disabled in brew, libgcrypt not working.
Load Binary Data should remember Start
feat: Nightly build workflow
I need to work on this more. closing.
Hi, the Flatpak build of Fuse has three patches. Two of them have already been committed upstream as [039d7d] and [514389]. The last one is the one that changes the configuration file path: https://github.com/flathub/net.sourceforge.fuse_emulator.Fuse/blob/74570620c0a70f3608208bb53afdf94023c260a5/fuse-config-dir.patch Other than that it's a normal Fuse build.
Ad to proposed.. --enable-flatpak-build Is building a flatpack package only about the location of config file? Having built in support to build a flatpack in FUSE base repo would be great, it would allow me to automate nightly build for linux too ( currently possible only for windows ).
Add Spectrum Next Emulation
Adding the FUSE_EMULATOR_CONFIG environment variable should be as simple as this.
A related idea (just mentioned in the mailing list) is to have a way to specify the path of the configuration file at runtime. An environment variable (FUSE_EMULATOR_CONFIG) would be the easiest, but a command-line option would also work.
Well, the patch was basically to merge upstream what I'm doing already in the Flatpak package, so it's not very sophisticated. Maybe I could have named it --enable-flatpak-build or something like that. Having proper XDG_CONFIG_HOME support would mean that the configuration file goes inside a subdirectory, something like this: $XDG_CONFIG_HOME/fuse-emulator/fuserc $XDG_CONFIG_HOME/fuse/fuserc $XDG_CONFIG_HOME/fuse-emulator/config $XDG_CONFIG_HOME/fuse/config Existing packages for Linux distros won't...
ZX Spectrum icons don't appear in the file chooser
Looks good to me. Committed in [039d7d]. Thank you.
Keep only the mime types for the most common formats
I'm up to allow the use of $XDG_CONFIG_HOME. Some modern applications use $HOME/.config for configuration files, with notable exceptions like OpenSSH [1]. If $XDG_CONFIG_HOME is not set, the config file is stored in the working directory. Maybe we should check this case. The XDG Base Directory Specification [2] says: $XDG_CONFIG_HOME is either not set or empty, a default equal to $HOME/.config should be used. IMO we should also document this location in the manual. Opinions? [1] https://web.archive.org/web/20190925004614/https://bugzilla.mindrot.org/show_bug.cgi?id=2050...
Movie recording ignores speed setting
Currah µSpeech noise
tzx files made with fuse appear broken; they don't load in any other software supporting tzx
Segmentation fault in ula_contend_port_early (peripherals/ula.c)
Segmentation fault in readbyte (memory_pages.c)
Stop using XPM icons in the GTK UI
tzxlist incorrectly reports display duration for message blocks
Thank you. Committed in [98fc1d].
Fix description of TZX message blocks
Stop using XPM icons in the GTK UI
Thank you. Committed in [514389].
Suppress a -Wmisleading-indentation warning from GCC in Xlib UI
Remove GTK names for XPM icons used in Xlib UI
Don't leak tape_marker_pixbuf when the tape browser is closed
Use PNG instead of XPM for the icons in the GTK UI
Here's the patch. We could also divide the number by 1000 and display seconds instead (since that's the actual unit used in the TZX file) but tzxlist uses miliseconds for everything else so maybe it's better to use it here too.
Hello, the "Record start" / "Record stop" options are used to save the raw audio output created by the save routine, so the generated TZX file contains a raw data block (you can see that if you use the tzxlist command-line tool). In your BASIC example you can convert the raw data into a more useful tape file with data blocks like this: $ tape2wav raw-tape.tzx raw-audio.wav $ audio2tape raw-audio.wav tape.tzx The other, simpler way to get the same result is: Go to Options -> Media and enable "Use...
Add option to store the configuration in XDG_CONFIG_HOME
Here is the patch.
Provide AppStream metadata
Looks good to me.
Here is the fix. I include a second patch that fixes a small memory leak in the tape browser dialog.
Here is the fix. I include a second patch that fixes a small memory leak in the tape browser dialog.
Stop using XPM icons in the GTK UI
Ok, so Fuse can actually open a lot of files if you pass them directly through the command line, so I decided to only keep the common ones (like in Windows, plus a couple more) and I expect that advanced users can figure out how to open the rest. The list is: .dsk, .pzx, .rzx, .slt, .sna, .szx, .tap, .tzx and .z80 The bash completion still supports all formats, I don't think it's necessary to reduce that list. Tell me what you think.
Suport for interrupted block instruction undocumented flags behaviour
Unfortunately, at the moment I do not fully understand all the subtleties of IF1 protocol and I could not get a (reliably) working prototype. I am publishing my changes in case if someone is able to pick it up. Updated 2024-09-28: Cleaned up code, slightly easier to read (and smaller)
All configuration options can be changed via command line arguments. Those override anything found in config file. Unfortunately, it means that changing configuration file location using a command line argument is not that simple. A while ago I thought I needed that option anyway, so I created a naive implementation. I have not used it for a while and it MAY NOT work with all build targets! That is why I am not creating a separate patch ticket and simply attaching my changes here.
Unfortunately, at the moment I do not fully understand all the subtleties of IF1 protocol and I could not get a (reliably) working prototype. I am publishing my changes in case if someone is able to pick it up.
I'm thinking there's a typo in the above..... mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_i_01 ......should be : mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_o_01 Oh, yes ... the curse of copy-paste :( Thanks, Gergely
Oh, yes ... the curse of copy-paste :( Thanks, Gergely
This is an updated patch to bring Netgame work again... On linux console: mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_o_01 ./fuse --net-in /tmp/snet_i_01 --net-out /tmp/snet_o_01 --interface1 ../netgame.szx & ./fuse --net-in /tmp/snet_o_01 --net-out /tmp/snet_i_01 --interface1 ../netgame.szx &
On September 16, 2024 11:19:52 PM GMT+02:00, Justin Eastham jceastham@users.sourceforge.net wrote: Hi, I'm thinking there's a typo in the above..... mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_i_01 ......should be : mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_o_01 ? [patches:#199] Interface I Local Area Network emulation Status: open Group: Created: Wed Apr 15, 2009 04:30 PM UTC by Gergely Szasz Last Updated: Mon Sep 16, 2024 05:51 PM UTC Owner: nobody This patch add *basic* IF1 LAN emulation to fuse. The...
Thank you, Gergely.......much appreciated :-)
Hi, I'm thinking there's a typo in the above..... mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_i_01 ......should be : mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_o_01 ?
This is an updated patch to bring Netgame work again... On linux console: mkfifo /tmp/snet_i_01 mkfifo /tmp/snet_i_01 ./fuse --net-in /tmp/snet_i_01 --net-out /tmp/snet_o_01 --interface1 ../netgame.szx & ./fuse --net-in /tmp/snet_o_01 --net-out /tmp/snet_i_01 --interface1 ../netgame.szx &
I’ve managed to create a simple “wire” simulation code. With that code the broadcast transmissions are now being sent out successfully. There are some peculiarities of the IF1 schematics and ROM code, which I do not fully understand (hopefully, yet). If someone has a clear explanation, please share. Right now I rely on Gergely’s comments for if1.c, IF1 ROM disassembly, experimental data, and my very limited understanding of the IF1 schematics. Anyway, here is what I observe “inside” FUSE: SCOUT frame:...
I’ve managed to create a simple “wire” simulation code. With that code the broadcast transmissions are now being sent out successfully. There are some peculiarities of the IF1 schematics and ROM code, which I do not fully understand (hopefully, yet). If someone has a clear explanation, please share. Right now I rely on Gergely’s comments for if1.c, IF1 ROM disassembly, experimental data, and my very limited understanding of the IF1 schematics. Anyway, here is what I observe “inside” FUSE: SCOUT frame:...
Quick summary of the Spectrum Computing discussion: - existing code was not finished (and it tries to analyse the sequence of IN/OUT calls, which seems to be a tricky task) - suggestion to intercept IF1 ROM routines (like it’s done for tape loader) was considered, but rejected I would suggest implementing another approach: build a proper parser for the ZX Net protocol which will serve as an adapter between the IF1 network “socket” (port 0xF7, technically) and the virtual “wire”. Such parser will...
We’ve been discussing this feature on the SpectrumComputing forums for a while, and here are some things mentioned so far about existing (POC?) code: There may be a bug in if1.c:port_net_out, which prevents network from “sending” anything unless RS232 is “connected”: diff --git a/peripherals/if1.c b/peripherals/if1.c index b4ff329..2ed8083 100644 --- a/peripherals/if1.c +++ b/peripherals/if1.c @@ -922,8 +922,8 @@ port_ctr_out( libspectrum_byte val ) static void port_net_out( libspectrum_byte val...
We’ve been discussing this feature on the SpectrumComputing forums for a while, and here are some things mentioned so far about existing (POC?) code: There may be a bug in if1.c:port_net_out, which prevents network from “sending” anything unless RS232 is “connected”: diff --git a/peripherals/if1.c b/peripherals/if1.c index b4ff329..2ed8083 100644 --- a/peripherals/if1.c +++ b/peripherals/if1.c @@ -922,8 +922,8 @@ port_ctr_out( libspectrum_byte val ) static void port_net_out( libspectrum_byte val...
Emulating "ZX Net" spectrum networking
SpecEmu 3.2 - also fine. Seems like only libspectrum issue.
libspectrum: libspectrum_rzx_playback_frame: wrong number
improve the teletext datastream code
Thank you. Merged in [8fd925].
Merge request #30: improve the teletext datastream code
whoops, that's the windows specific function. I'll move it to a compat function
Thank you Guesser. When I try to compile on linux I get this error: peripherals/ttx2000s.c: In function ‘ttx2000s_field_event’: peripherals/ttx2000s.c:357:9: warning: implicit declaration of function ‘ioctlsocket’ [-Wimplicit-function-declaration] 357 | if( ioctlsocket( teletext_socket, FIONREAD, &n ) == -1) { | ^~~~~~~~~~~ peripherals/ttx2000s.c:357:39: error: ‘FIONREAD’ undeclared (first use in this function) 357 | if( ioctlsocket( teletext_socket, FIONREAD, &n ) == -1) { | ^~~~~~~~ Can you fix...
Can't load compressed dsk files
(Hopefully) the final version of the patch, includes UI elements and man page. Things that can be improved: - printer support can be streamlined, I did not touch existing printer code on purpose - Win32 port
(Hopefully) the final version of the patch, includes UI elements and man page. Things that can be improved: - printer support can be streamlined, I did not touch existing printer code on purpose - Win32 port
The patch is not compatible with the modern high speed software, like sercp. I presume the tstates-based "timer emulation" is not precise enough. If I tweak the code to send each bit every 90 tstates for 38400 and every 30 tstates for 115200, the sercp 0.8 works. However, lookin at the sercp code, it actually spends 91 and 31 tstates polling each bit at 38400 and 115200 respectively. However, it seems to be compatible with anything using ROM or CP/M routines for RS232/MIDI comms.
Almost complete functional changes. Remaining tasks: UI replace existing serial printer emulation multiplatform support (at least making sure it compiles anywhere) cleanup code :) The following settings available (command line only): --ay-io-device TYPE - where TYPE is None, RS232 or MIDI for MIDI the following options available: --ay-io-midi-tx FILE - attach MIDI receiver (e.g. amidicat http://krellan.com/amidicat/ ) for RS232 the following options available: --ay-io-rs232-baud - choose the speed...
Almost complete functional changes. Remaining tasks: UI replace existing serial printer emulation multiplatform support (at least making sure it compiles anywhere) cleanup code :) The following settings available (command line only): --ay-io-device TYPE - where TYPE is None, RS232 or MIDI for MIDI the following options available: --ay-io-midi-tx FILE - attach MIDI receiver (e.g. amidicat http://krellan.com/amidicat/ ) for RS232 the following options available: --ay-io-rs232-baud - choose the speed...
Almost complete functional changes. Remaining tasks: UI replace existing serial printer emulation multiplatform support (at least making sure it compiles anywhere) cleanup code :) The following settings available (command line only): --ay-io-device TYPE - where TYPE is None, RS232 or MIDI for MIDI the following options available: --ay-io-midi-tx FILE - attach MIDI receiver (e.g. amidicat http://krellan.com/amidicat/ ) for RS232 the following options available: --ay-io-rs232-baud - choose the speed...
Almost complete functional changes. Remaining tasks: UI replace existing serial printer emulation multiplatform support (at least making sure it compiles anywhere) cleanup code :) The following settings available (command line only): --ay_io_device TYPE - where TYPE is None, RS232 or MIDI for MIDI the following options available: --ay_io_midi_tx FILE - attach MIDI receiver (e.g. amidicat http://krellan.com/amidicat/ ) for RS232 the following options available: --ay_io_rs232_baud - choose the speed...
Thanks a lot for the inspiration! I have created an enhanced version which should be able to handle any arbitrary baud rate: https://sourceforge.net/p/fuse-emulator/patches/442/
AY RS232 interface for 128/+2/+3
How does one press the BREAK key on the emulator? On a physical ZX Spectrum, the break function is invoked by pressing Caps Shift and the Space key. But that doesn't seem to work on Fuse. I've tried pressing the physical Left-Shift and Space keys on several ports of Fuse, but none of them produced the Break function—they simply typed a space. I tried the native macOS port by Fredrick Meunier (1.5.6), the Windows port by Sergio Baldoví (1.6.0) and the Fedora package (1.6.0-9.fc40). I would have also...
improve the teletext datastream code
Hi, The disk image is from TOSEC archive.: https://archive.org/details/Sinclair_ZX_Spectrum_TOSEC_2012_04_23 There are two disk image file format (Extended DSK and UDI) which can contain non standard tracks and other (meta) data (e.g. controller ic status registers). Other image formats only contain plain data bytes. https://sinclair.wiki.zxnet.co.uk/wiki/Category:Complex_Disk_Image_Formats http://cpctech.cpc-live.com/docs/extdsk.html https://sinclair.wiki.zxnet.co.uk/wiki/UDI_format The DSK/EDSK...
Enable DISCiPLE on 128K machines
As part of my investiagtions into "what could have been", I would like to try out converting certain software to various disk systems using Lerm utilities - not that it's hugely useful, of course. I have tried - mainly Tape Utility D so far - without success as I can't find settings that seem to make much progress. Are there good settings for fuse that will allow utilities such as this to run well with "faithful to sold version" TZX files as input? I know some of this is likely to be fiddly, but...
Remove use of deprecated `gdk_keymap_get_default`
Simpler version merged from branch patch-440-remove-gdk_keymap_get_default-2
Remove use of deprecated `gdk_keymap_get_default` function.
Remove use of deprecated `gdk_keymap_get_default`
Remove use of deprecated `gdk_keymap_get_default` function.
Remove use of deprecated `gdk_keymap_get_default`