Developer log: Difference between revisions

From vice-emu
Jump to navigation Jump to search
mNo edit summary
 
(470 intermediate revisions by 5 users not shown)
Line 1: Line 1:
<big>'''As of the 3.2 release, this page is no more used. All developers are supposed to update the GTK3 and SDL ports when they add things that need GUI items.'''</big>
<div class="noautonum">__TOC__</div>
<div class="noautonum">__TOC__</div>


Line 124: Line 128:
| style="background:#FF0000;" | dos (3)
| style="background:#FF0000;" | dos (3)
| style="background:#FF0000;" | os/2 (10)
| style="background:#FF0000;" | os/2 (10)
| style="background:white;" |
| style="background:#00FF00;" | SDL (-)
|-
|| r30535 ||
| style="background:white;" |
| style="background:#FF0000;" | win32 (10)
| style="background:#FF0000;" | *nix (5)
| style="background:#FF0000;" | osx (40)
| style="background:white;" |
| style="background:#FF0000;" | amiga (17)
| style="background:#FF0000;" | beos (26)
| style="background:#FF0000;" | dos (21)
| style="background:#FF0000;" | os/2 (41)
| style="background:white;" |
| style="background:#FF0000;" | SDL (6)
|-
|| r30784 ||
| style="background:white;" |
| style="background:#ADFF2F;" | win32 (1)
| style="background:#00FF00;" | *nix (-)
| style="background:#00FF00;" | osx (-)
| style="background:white;" |
| style="background:#FF8000;" | amiga (26)
| style="background:#FF8000;" | beos (31)
| style="background:#FF8000;" | dos (14)
| style="background:#FF0000;" | os/2 (50)
| style="background:white;" |
| style="background:#00FF00;" | SDL (-)
|-
|| r32419 ||
| style="background:white;" |
| style="background:#00FF00;" | win32 (-)
| style="background:#00FF00;" | *nix (-)
| style="background:#00FF00;" | osx (-)
| style="background:white;" |
| style="background:#00FF00;" | amiga (-)
| style="background:#FFC000;" | beos (3)
| style="background:#00FF00;" | dos (-)
| style="background:#FFC000;" | os/2 (4)
| style="background:white;" |
| style="background:#00FF00;" | SDL (-)
|-
|| r32520 || 3.0
| style="background:white;" |
| style="background:#00FF00;" | win32 (-)
| style="background:#00FF00;" | *nix (-)
| style="background:#00FF00;" | osx (-)
| style="background:white;" |
| style="background:#00FF00;" | amiga (-)
| style="background:#00FF00;" | beos (-)
| style="background:#00FF00;" | dos (-)
| style="background:#FFFF00;" | os/2 (2)
| style="background:white;" |
| style="background:white;" |
| style="background:#00FF00;" | SDL (-)
| style="background:#00FF00;" | SDL (-)
Line 158: Line 214:
----
----


==2.2==
===r34242===
 
===2.2.7 (r22889)===
 
* NEW: archdep_fix_permissions (r23053)
** should set the permissions of a given file to "rw", respecting the current umask (if any)
** '''TODO:''' add proper code for the following ports: beos
** '''TODO:''' ...and copy to arch/sdl/archdep_* when doing that
 
----
 
==2.3==
===2.3.9 (r24210)===
 
* additional functions signals_pipe_set() and signals_pipe_unset() added in arch/*/signals.c (r24261)
** to check if a port needs this implemented, type this into one terminal:
*: <code> x64 -remotemonitor</code>
*: and this into another:
*: <code> echo "reset" | nc -p 6510</code>
*: now terminate the connection by pressing ctrl-c. if the emulator now quits (or crashes) you probably need to handle SIGPIPE, ie set up a signal handler for SIGPIPE that calls monitor_abort() (see the unix code as an example). if not, just locate the respective fixme note in 'your' sourcefile and remove it.
** '''TODO''': check/confirm/implement for the following ports: amiga, beos, dos, os/2
** '''TODO''': ...and copy to arch/sdl/archdep_* when sigpipe handling is required
 
* after above changes, check whether VDC and VIC-II palettes can coexist, and update the todo list here: [[Todo#Ports_.2F_UIs]]
** '''TODO''': check following ports: beos, osx
 
* put the status of the vsid ui into the todo list here: [[Todo#Ports_.2F_UIs]]
** '''TODO''': check following ports: dos
 
** cartridge_attach_image(type,name) and cartridge_detach_image(type) are now available in xcbm2/cbm5x0, look for types in cartridge.h
** direct usage of "Cart1Name", "Cart2Name", "Cart3Name", "Cart4Name" resources is deprecated, use the above functions instead.
** '''TODO''': fix gui items in following ports: osx
 
* NEW: Atari ST mouse and the Atari CX-22 trackball and improved Amiga mouse emulation by Magnus Lind.
** '''TODO''': Check and test UI items for Atari ST mouse and Atari CX-22 trackball (osx)
*** testprograms can be found in testprogs/propmouse
 
===2.3.10 (r24627)===
 
* Added 3rd sid support for x64 and x128 (r24733).
** changed Resource: "SidStereo", instead of 0=off, 1=on, it's now: 0=off, 1=1 extra sid, 2=2 extra sids.
** new Resource: "SidTripleAddressStart", the address of the 3rd sid.
** '''TODO:''' add/change gui items in the following ports: osx
 
===2.3.15 (r25340)===
 
* added support for "Formel 64" parallel cable (r25438)
** extended resources Drive8ParallelCable, Drive9ParallelCable, Drive10ParallelCable, Drive11ParallelCable (enum) from 0..2 to 0..3 (DRIVE_PC_NONE, DRIVE_PC_STANDARD, DRIVE_PC_DD3, DRIVE_PC_FORMEL64). added DRIVE_PC_NUM respectively (drive.h)
** '''TODO:''' update gui items in following ports: os/2
 
===r25459===
by Rhialto
 
I enabled up to DRIVE_NUM IEEE-488 drives, rather than 2 (in True Drive Emulation mode). In some places where they are enumerated, it is 4. The drives use their full 3 bits of jumpered drive number now, rather than just 1 bit.
 
I have also generalised  code so as to allow another dual drive. Since dual drives currently use up two device numbers, it will use 10 and 11. I'm currently simplifying the methods for checking the dualness of a drive.
 
When that is done, I hope to have gained enough understanding of the code to remove the horrible hack of using 2 devices for a dual drive, and remove it. It looks like it will simplify a lot of code (including removing lots of code that I changed for allowing 2 dual drives). That will have some repercussions on the GUIs, since for every drive you may need to be able to attach ''two'' image files. It also would add an extra "drive" parameter (in addition to the current "unit" parameter) to a shedload of functions, although this is a pretty mechanical change. In fact, it is the GUI change that currently holds me back...
 
'''TODO''': Think of some elegant way to represent settings for 8 floppy images (for 4 dual drives), without requiring all GUIs to be updated at once.
'''TODO''': After that, I can rework the code to make dual drives more regular and hence allow 4 of them.
 
===2.3.21 (r26032)===
* added "SuperCard+" emulation (this is a drive expansion board for 1541/1570/1571/1571cr)
* new Resource: "DriveSuperCardName" (string) that specifies the SuperCard ROM image
* new Resources: "Drive8SuperCard", "Drive9SuperCard", "Drive10SuperCard", "Drive11SuperCard" (toggle) that specify whether SuperCard is enabled for the respective drive
* '''TODO''': add GUI items to following ports: os/2, osx
 
===2.3.22 (r26155)===
* added Smart mouse emulation
** '''TODO''': check if GUI items work on following ports: osx
 
* added c64/c128/vic20 DS12C887 RTC expansion emulation
** new Resource: "DS12C887RTC" (BOOL) DS12C887 RTC cart on/off
** new Resource: "DS12C887RTCbase" (int) DS12C887 RTC cart base address
** '''TODO''': Add GUI items to the following ports: osx
 
* added c64/c128 RTC58321a userport RTC expansion emulation
** new Resource: "UserportRTC" (BOOL) 58321A RTC on/off
** '''TODO''': Add GUI items to the following ports: osx
 
----
 
==2.4==
===2.4 (r26680)===
* updated the datasette emulation to also work as expected when there is no tape image present
** all UI elements should be always visible and enabled (as with a real datasette :))
** the parameter passed to ui_set_tape_status can then be used to somehow indicate whether a tape image is present (eg by using a different color)
** ui_set_tape_status, ui_display_tape_motor_status, ui_display_tape_control_status and ui_display_tape_counter in ui code perhaps must be updated to handle being called before the respective gui item has been created (which unfortunately can not be avoided easily with the current architecture)
** '''TODO''': Check and if required adapt GUI items for the following ports: beos, dos, os/2, osx
 
===r27046===
* NEW: Resource "DriveSoundEmulationVolume" (integer, 0 - 4000) to adjust the volume of the drive noise emulation
** '''TODO''': add GUI items in following ports: beos, os/2, osx
 
===2.4.4 (r27450)===
* NEW: added Resource "JAMAction" to select default action on CPU JAM. (int, MACHINE_JAM_ACTION_DIALOG, MACHINE_JAM_ACTION_CONTINUE, MACHINE_JAM_ACTION_MONITOR, MACHINE_JAM_ACTION_RESET, MACHINE_JAM_ACTION_HARD_RESET and MACHINE_NUM_JAM_ACTIONS respectively)
** '''TODO''': add GUI item(s) in following ports: os/2


also see r27981 below
* added tapecart emulation, still needs GUI hookups


===r27452===
Tapecart support has been added in the Gtk3 UI and the SDL UI, including a 'flush image button' which uses the new tapecart_flush_tcrt() function in tapecart.c.
* NEW: added Resource "IECReset" (1: drives reset with computer, 0: drives do only reset on powercycle/hard reset) to x64, x64sc and xscpu64 - this should go into the "model selection" dialog (as it depends on the board)
** '''TODO''': add GUI item(s) in following ports: os/2
** NOTE: while adding this, check if the model switching in xscpu64 is working (it should be like in x64sc, not like in x64!)


===r27549===
'''TODO''': Decide if we want to add this to the other ports, to be included in VICE 3.2, the last release with the 'old' ports.
* Resid-FP has been removed.
* To compensate for the missing SID-Type selection, GUI items (slider) should be added for the following Resources: SidResidPassband (0..90), SidResidGain (90..100), SidResidFilterBias (-5000...5000)
** '''TODO''': add/update GUI item(s) in following ports: os/2


===r27914===
==3.0==
* Printer 6 (Plotter) is now available, a new menu like the existing printer menus should be added which has "1520" and "RAW" in its driver selection
** '''TODO''': add/update GUI item(s) in following ports: os/2, osx


===2.4.6 (r27981)===
* Added support for G71 (double sided G64 for 1571) images
* added MACHINE_JAM_ACTION_QUIT as option for JAMACTION
:'''TODO''': add g71 to filters in file-open/attach dialogs in following ports: amiga, dos, osx, win32
** '''TODO''': add/update GUI item(s) in following ports: os/2
:'''TODO''': add g71 to "create image" dialogs (DISK_IMAGE_TYPE_G71) in following ports: amiga, beos, dos, osx, win32


===r28014===
===r32815===
* accessing device #7 on the IEC bus works (only real devices), respective selection (0: none 2: real) should get added to the menus
**'''BUG''': it only works if True Drive Emulation is OFF, even though this has nothing to do with drives. This needs to be fixed in TDE somehow.
** '''TODO''': add/update GUI item(s) in following ports: os/2, osx


===2.4.7 (r28398)===
* Added support for the StarDOS drive ROM, new resources DriveXStarDos (boolean), DriveStarDosName (string)
:'''TODO''': add GUI items to the following ports (take supercard or profdos as example): amiga, beos, dos, osx, win32


* ifdef 0'ed resource "MIDIMode" in xvic
** '''TODO''': check and update GUI for use of this resource in: osx


=== r28480 ===
===r33343===


* SOCKET type should probably be int (not unsigned), as it equals a file descriptor.
* Changed a few malloc()/free() calls to lib_malloc()/lib_free(), which includes some code I cannot check (OSX for example), so should you run into errors/warnings when running VICE with -debug enabled, let me know. I think I got it right, but you never know.
** '''TODO''': check and fix socketimpl.h in: beos
 
=== r28503 ===
 
* changed mon_reg_list_t->flags into a bitfield (see mon_register.h)
** '''TODO''': check and fix in: osx (vicemachinecontroller.m)
 
=== r28517 ===
 
* removed 'next' member from mon_reg_list_t, and thus make it a simple array rather than a linked list. (check for end of list by testing ->name == NULL)
** '''TODO''': check and fix in: amiga, beos, dos, os/2 (if port compiles no fix is needed)
 
=== 2.4.8 (r28546) ===
 
* new Resource: "IDE64USBServerAddress" (string) for entering a listening address, e.g. "ip4://127.0.0.1:64245"
* new Resource: "IDE64USBServer" (boolean) for enabling/disabling it.
* '''TODO''': add GUI items in beos, os/2
 
=== 2.4.9 (r28665) ===
 
* new Resource: "DS12C887RTCRunMode" (int) for setting the initial run mode of the RTC oscillator (0=halted, 1=running)
* '''TODO''': add GUI items for amiga, beos, dos, os/2, osx
 
=== r28935 ===
 
* added generic function/list for querying the enabled compile time features. (see vicefeatures.h)
: '''TODO''': add GUI items for dos, os/2, osx
 
=== r28951 ===
 
* new Resource: (BOOL) "DS12C887RTCSave" (c64,vic20,c128) for enabling saving RTC data (0=disabled, 1=enabled)
* '''TODO''': add GUI items for osx
 
* new Resources: (BOOL) "Drive8RTCSave", "Drive9RTCSave", "Drive10RTCSave", "Drive11RTCSave" (all iec machines except vsid) for enabling saving RTC data (0=disabled, 1=enabled)
* '''TODO''': add GUI items for os/2, osx
 
* new Resource: (BOOL) "UserportRTCSave" (c64/c128) for enabling saving RTC data (0=disabled, 1=enabled)
* '''TODO''': add GUI items for osx
 
* new Resource: (BOOL) "SmartMouseRTCSave" (c64/c128) for enabling saving RTC data (0=disabled, 1=enabled)
* '''TODO''': add GUI items for osx
 
=== 2.4.13 (r28982) ===
 
* new function "cartridge_get_info_list()" for querying the list of cartridges for building the "attach binary image" menu(s) in x64/x64sc/xscpu64/x128. see cartridge.h
: '''TODO''': convert code to use the list instead of hardcoding it: amiga, beos, dos, os/2, osx, win32
 
=== 2.4.15 (r29202) ===
* added new resource "VICIIVSPBug" (bool) to enable/disable emulation of the VSP bug
: '''TODO''': add UI elements to following ports: amiga, beos, dos, os/2, win32 (VICIISC only!)
 
=== r29231 ===
* added new resource "DatasetteTapeWobble" (int) to emulate random tape wobble
: '''TODO''': add UI elements to following ports: amiga, beos, dos, os/2, win32
 
=== r29237 ===
* added new resource "MemoryHack" (int) to activate the different kinds of plus4 memory expansion hacks (0: none, 1: CS256K, 2: H256K, 3: H1024K, 4: H4096K), and removed the "CS256K" and "H256K" resources
: '''TODO''': fix UI elements for the following ports: beos, dos, os/2, win32
 
=== r29348 ===
* added new resource "EasyFlashOptimizeCRT" (bool) to allow/disallow optimizing of the .crt file when writing
: '''TODO''': fix UI elements for the following ports: amiga, beos, dos, os/2, win32
 
=== r29610 ===
* long overdue rework of keyboard map handling is in trunk now. for details on migrating to the new code see [[Keymaps]]
: '''TODO''': fix UI elements for the following ports: amiga, beos, dos, os/2, osx, win32


==Branches==
==Branches==
Line 363: Line 244:
* 2.3-new-cpu-cores (blacky)
* 2.3-new-cpu-cores (blacky)
** This branch is all about (old and) new cpu cores, it is meant to implement the following:
** This branch is all about (old and) new cpu cores, it is meant to implement the following:
*** z80 support for x64/x64sc (z80 cp/m cartridge).
*** <strike>z80 support for x64/x64sc (z80 cp/m cartridge).</strike> (code is in the trunk and used by the c64 cpm cart)
*** <strike>65(S)C02 support as used in some accelerator carts, but also as direct 6502/6510 replacement.</strike> (core is in the trunk and used by the fd2000/4000 drives)
*** <strike>65(S)C02 support as used in some accelerator carts, but also as direct 6502/6510 replacement.</strike> (core is in the trunk and used by the fd2000/4000 drives)
*** 65CE02 support as direct 6502/6510 replacement.
*** 65CE02 support as direct 6502/6510 replacement.
Line 377: Line 258:
** TODO: user interface for Drive?Swap8Button, DrivexSwap?Button, Drive?WriteProtectButton
** TODO: user interface for Drive?Swap8Button, DrivexSwap?Button, Drive?WriteProtectButton
** TODO: gui changes so that this type can be selected
** TODO: gui changes so that this type can be selected
** TODO: RTC72421 emulation needed
** <strike>TODO: RTC72421 emulation needed</strike> (in trunk)
** TODO: proper disk image attaching, hdd/iso/fdd image types? Currently file is hardcoded to "/tmp/image" for all!
** TODO: proper disk image attaching, hdd/iso/fdd image types? Currently file is hardcoded to "/tmp/image" for all!
** Future: geos, swap8, swap9 and write protect LEDs on GUI would be nice
** Future: geos, swap8, swap9 and write protect LEDs on GUI would be nice
Line 385: Line 266:
----
----


List of ports: amiga, beos, dos, os/2, osx, *nix, win32, sdl
List of ports: amiga, beos, dos, osx, *nix, win32, sdl


List of ports outside UI updates: android, dingoo
List of ports outside UI updates: android, dingoo
[[Category:Deprecated]]

Latest revision as of 18:26, 23 March 2023

As of the 3.2 release, this page is no more used. All developers are supposed to update the GTK3 and SDL ports when they add things that need GUI items.


The developer log is intended to be a central place for all developers to take down notes on what has changed during development. This helps to keep all porters up to date regarding API and Resource changes.

Status

r25372 win32 (1) *nix (1) osx (29) amiga (39) beos (43) dos (39) os/2 (55) SDL (1)
r25801 win32 (-) *nix (-) osx (30) amiga (37) beos (41) dos (40) os/2 (4) SDL (-)
r25858 2.3.19 win32 (-) *nix (-) osx (30) amiga (9) beos (41) dos (40) os/2 (4) SDL (-)
r25955 2.3.20 win32 (2) *nix (-) osx (30) amiga (4) beos (31) dos (28) os/2 (4) SDL (-)
r26032 2.3.21 win32 (3) *nix (-) osx (31) amiga (5) beos (32) dos (6) os/2 (5) SDL (1)
r26488 2.4 win32 (3) *nix (-) osx (35) amiga (5) beos (36) dos (7) os/2 (5) SDL (1)
r26876 2.4.1 win32 (4) *nix (-) osx (36) amiga (5) beos (37) dos (8) os/2 (6) SDL (-)
r28197 2.4.7 win32 (5) *nix (-) osx (48) amiga (5) beos (8) dos (8) os/2 (11) SDL (-)
r28270 win32 (-) *nix (-) osx (48) amiga (1) beos (5) dos (3) os/2 (10) SDL (-)
r30535 win32 (10) *nix (5) osx (40) amiga (17) beos (26) dos (21) os/2 (41) SDL (6)
r30784 win32 (1) *nix (-) osx (-) amiga (26) beos (31) dos (14) os/2 (50) SDL (-)
r32419 win32 (-) *nix (-) osx (-) amiga (-) beos (3) dos (-) os/2 (4) SDL (-)
r32520 3.0 win32 (-) *nix (-) osx (-) amiga (-) beos (-) dos (-) os/2 (2) SDL (-)


more than one open issue from before the last release version
no open issues from before the last release version, plus at most one other open issue
no open issues from before the last release version
no open issues from before the last tagged version, plus at most one other open issue
no open issues from before the last tagged version
no open issues

Trunk

Here is a short overview of all changes made in trunk that are relevant for the respective port/gui maintainers.

Note: new stuff should be added at the bottom and each item should have the related svn revision

To keep the size of this list down (and hopefully shrinking) ...

  • Port/GUI Maintainers should remove their port from the respective item when it is implemented.
  • To not clutter this page with stuff that will not get implemented anytime soon ("i will not add lightpen support to this handheld port") in such cases the respective port should also get removed from the respective item, and a note pointing out the missing feature should get added to Todo#Ports_.2F_UIs instead.
  • Items which have no more TODOs left should then be moved to the Developer_log_old Page

r34242

  • added tapecart emulation, still needs GUI hookups

Tapecart support has been added in the Gtk3 UI and the SDL UI, including a 'flush image button' which uses the new tapecart_flush_tcrt() function in tapecart.c.

TODO: Decide if we want to add this to the other ports, to be included in VICE 3.2, the last release with the 'old' ports.

3.0

  • Added support for G71 (double sided G64 for 1571) images
TODO: add g71 to filters in file-open/attach dialogs in following ports: amiga, dos, osx, win32
TODO: add g71 to "create image" dialogs (DISK_IMAGE_TYPE_G71) in following ports: amiga, beos, dos, osx, win32

r32815

  • Added support for the StarDOS drive ROM, new resources DriveXStarDos (boolean), DriveStarDosName (string)
TODO: add GUI items to the following ports (take supercard or profdos as example): amiga, beos, dos, osx, win32


r33343

  • Changed a few malloc()/free() calls to lib_malloc()/lib_free(), which includes some code I cannot check (OSX for example), so should you run into errors/warnings when running VICE with -debug enabled, let me know. I think I got it right, but you never know.

Branches

Here is a short overview of all branches that are currently active in SVN, i.e. someone develops a new feature that soon will be merged into trunk. Note here the upcoming features, if some testing is required on specific platforms or there is something porters need to be aware of. When a branch was merged into trunk, the respective info should be moved to the Developer_log_old Page.

  • 2.3-new-cpu-cores (blacky)
    • This branch is all about (old and) new cpu cores, it is meant to implement the following:
      • z80 support for x64/x64sc (z80 cp/m cartridge). (code is in the trunk and used by the c64 cpm cart)
      • 65(S)C02 support as used in some accelerator carts, but also as direct 6502/6510 replacement. (core is in the trunk and used by the fd2000/4000 drives)
      • 65CE02 support as direct 6502/6510 replacement.
      • 65802/65816 support as used in some accelerator carts, but also as direct 6502/6510 replacement (65802 only). (core is in the trunk and used by xscpu64 as the main cpu core).
      • 6809/6309 support as used in the super pet. (core is in the trunk and used by the superpet)
      • 8088 support as used in a copro board for the cbm2 (able to run cp/m-86 and msdos 1.25).
  • driveupdate (soci)
    • The point is to have a single FDD emulation for all drives which need low level media emulation and caching. The disk image handling is also reworked to make simpler to use and extend it later. Some features were added like handling of d71 double sided emulation mode disk images, real 6502 FDC with GCR image (works for 1001 now, planned for others). Improved fault handling and updating of Dxx images, 1581 and other MFM drives needs some work. Planned is to get the 1571 MFM mode somehow working together with the GCR mode (probably not on the same type of image file), and maybe implement G64 image support for the IEEE drives. And of course all these changes brings some new bugs to fix. This is most likely not going to be finished in 2011, and maybe some parts should be migrated to trunk to get some of the ready stuff out earlier.
  • vice-1990 (soci)
    • Branch for emulating the 1990 drive.
    • TODO: user interface for Drive?Swap8Button, DrivexSwap?Button, Drive?WriteProtectButton
    • TODO: gui changes so that this type can be selected
    • TODO: RTC72421 emulation needed (in trunk)
    • TODO: proper disk image attaching, hdd/iso/fdd image types? Currently file is hardcoded to "/tmp/image" for all!
    • Future: geos, swap8, swap9 and write protect LEDs on GUI would be nice
    • Future: device number comes from the image instead of VICE.
    • Future: vdrive support. Good luck ;)

List of ports: amiga, beos, dos, osx, *nix, win32, sdl

List of ports outside UI updates: android, dingoo