Mame 0.128u7

  • 0.128u7
    -------


    NOTE: As of this release, we have two more major changes. These should
    be the last "huge" changes of this dev cycle.


    The most major change is the final retirement of the global Machine
    pointer, which has been part of MAME for many years. Frankly, I never
    thought we'd hit this point so quickly, so my hats off to Atari Ace
    who helped push through the final round of changes needed to make this
    happen finally. As a result of this change, it should be possible in
    the coming year to finally write a driver that runs two full machines
    simultaneously.


    The second big change is that the CPUs are now full-fledged devices,
    and participate like all other devices in the system configuration.
    This is mainly an internal structural change, but in the end removes
    some redundant code and behavior. In a future dev cycle, a similar
    thing will happen with the sound cores.


    Starting now, the focus for MAME will be to iron out remaining issues
    and release a 0.129 sometime around the 1st of the year. Please keep
    reporting bugs to MAMETesters as you find things.




    MAMETesters Bugs Fixed
    ----------------------
    - 02745: [Crash/Freeze] all sets using autosave: Games using autosave
    segfault on startup (Aaron Giles)
    - 02750: [Sound] All Sets in equites.c: no background music
    (Aaron Giles)
    - 02757: [Documentation] sengoku3: manufacturer should be "Noise
    Factory / SNK" (Phil Bennett)
    - 02753: [Crash/Freeze] gradius4: hardware error -1 (Aaron Giles)
    - 02755: [Crash/Freeze] All Sets in metro.c: Crash with access
    violation. (Aaron Giles)
    - 02756: [Crash/Freeze] hyprduel, hyprdelj: Colors on the title screen
    wrong, games crash mame with ACCESS VIOLATION (Mamesick)




    Source Changes
    --------------
    Removed old cherrym driver (meant to be removed last time, oops).
    [Aaron Giles]


    Funworld.c improvements [Roberto Fresca]
    - Added new set: Jolly Card (italian, encrypted bootleg).
    No coins... Only remote credits. After nvram init, set the Payout
    DIP to 'manual' to allow the remote credits mode to work.
    - Created inputs from the scratch for jolycdib.
    - Updated technical notes.


    Made CPUs into proper devices. CPUs are now added in the machine
    configuration just as any other device, and the standard CPU
    configuration is performed via the inline configuration macros.
    [Aaron Giles]


    Changed cpu_type from an enumeration into a pointer to the CPU's
    get_info function, very similar to device behavior. Updated all
    drivers to #include the necessary header files for the CPU's they
    reference. [Aaron Giles, Atari Ace]


    Added function cpu_get_type() to return the CPU type. [Aaron Giles]


    Changed several cpu_* functions over to the device_* equivalents,
    specifically for get/set info and for reset. [Aaron Giles]


    The device system now maintains a parallel list of devices based on
    type and class, for faster iteration through all devices of a given
    type or class. [Aaron Giles]


    Cleaned up code that looped over CPUs via the machine->cpu array to
    now loop using the type-based device list. [Aaron Giles]


    Removed start/stop/reset/nvram functions from the device_config in
    favor of grabbing them as needed. [Aaron Giles]


    Cleaned up the generic interrupt_enable code to work with CPU devices
    instead of numbers. [Aaron Giles]


    Mapped the devtag_* functions to device_* functions via macros instead
    of parallel implementations. [Aaron Giles]


    Removed cpuintrf_init() which is no longer necessary. [Aaron Giles]


    Changed a number of APIs in the system to accept running_machine,
    address_space, or device_config types, in order to remove the use of
    the global Machine variable. Removed the global Machine variable now
    that it is no longer directly references. [Atari Ace, Aaron Giles]


    Added the concept of device "owner", for devices owned by other
    devices. [Aaron Giles]


    Modified laserdisc players to walk back to their global device state
    via the owner, rather than brute-force searching for the first
    instance and hoping that is the right one. [Aaron Giles]


    Finalizer update [poUzVdb90]
    - converted to tilemap
    - added flipscreen
    - changed sound chip name from SN76496 to SN76489A


    Made the concept of a "clock" native to devices. The clock is now
    specified when the device is added, and the clock is available in
    the device_config directly via device->clock. Updated all devices
    that have a clock to specify it when adding the device, rather than
    as part of their configuration. As part of this work, also created
    device-specific _ADD and _REMOVE macros to simplify configuration.
    [Aaron Giles]


    Defined a generic device execute function callback, though it
    is not used yet. The long term plan is that any device with an
    execute callback will be scheduled along with the CPUs. Now that
    CPUs are devices, their scheduling will be moved over to this
    logic eventually. [Aaron Giles]


    Changed various NVRAM devices to fetch their default memory region
    from the device->region rather than specifying it in the
    configuration. [Aaron Giles]


    Moved device startup to *before* the DRIVER_INIT is called. This
    is to allow the DRIVER_INIT to configure devices that have been
    properly allocated. So far I don't see any negative effects, but
    be on the lookout if something weird shows up. [Aaron Giles]


    Rewrote the device iteration logic to make use of the typenext
    field and the newly-introduced classnext field for iterating more
    efficiently through devices of a given type or class. [Aaron Giles]


    Modified the parameters of the stream_update_func callback. As part of
    this work, macro-ized all the callbacks to STREAM_UPDATE, and added
    the sound device as a parameter. [Atari Ace]


    Cleaned up i86/i286/i386/nec/v30mz headers: [Aaron Giles]
    * renamed i86.h -> i86priv.h
    * renamed i86intrf.h -> i86.h
    * consolidated i88intrf.h, i186intf.h, i188intf.h, etc into i86.h


    Cleaned up many other CPU headers to move memory read/write macros
    out of them, since they are inappropriate and should be prive to the
    CPU core. [Aaron Giles]


    Removed index and clock parameters from CPU_INIT function.
    [Aaron Giles]


    Some PIC8259 updates: [Wilbert Pol]
    - Fixed operation of edge-triggered interrupts
    - INT output line is now cleared when an IRQ is acknowledged
    - Implemented basic OCW3 features


    Fixed proms in boobhack. [robiza]


    Decoded some graphics and setup some RAM in the Virtual Combat driver.
    [Andrew Gardner]


    Cleaned up device and sound interfaces to match the CPU interfaces
    when handling strings. Namely, the generic get_info functions
    allocate a temporary string and the device in question copies its
    string to the target, instead of assigning a const char *. Updated
    all device and sound cores to operate this way. [Aaron Giles]


    Added the concept of a cpu_state_table, which is supplied by the CPU
    cores and which describes all the register state accessible to the
    debugger and other subsystems. The format of the table is such that
    most data can be simply fetched from memory without the further
    involvement of the CPU core, including the display of common formats.
    Extensibility points are available for custom display and for
    importing/exporting the data to intermediate variables for more
    complicated scenarios. Updated the ADSP21xx, TMS340x0, i86, Z80, Z180,
    and 8085 cores to use this. [Aaron Giles]


    Removed the old debugger register list, which was never used. Replaced
    it with using ordering from the cpu_state_table. [Aaron Giles]


    Renamed REG_PC -> REG_GENPC, REG_SP -> REG_GENSP, and
    REG_PREVIOUSPC -> REG_GENPCBASE. Updated a few spots that were using
    these directly. Moved these definitions into the end of the register
    area rather than leaving them outside which put them in a weird range.
    [Aaron Giles]


    More cleanup. Added address-space-specific constants for the various
    bus width and shift CPU interface constants. Changed all the cores
    to use them. [Aaron Giles]


    Changed ADSP21xx cores to accept a configuration struct instead of
    using set_info to specify serial port callbacks. Simplified the
    ADSP21xx get/set info significantly. Removed support for only
    including certain variants of the chips; they are now either all
    supported or all unsupported. [Aaron Giles]


    Memory view fixes: [Aaron Giles]
    * Fixed bug that computed the wrong total size if the address
    space was a full 32 bits
    * Improved display to show unmapped memory with *s
    * Disabled enumeration of disk and 0-length regions


    Added PAL to arkgcbl. [robiza]


    Added Country Girl to the Jangou driver,working with sound
    [David Haywood, Angelo Salese]
    - Fixed transparency pens in the Jangou driver (so removed the
    GAME_IMPERFECT_GRAPHICS flag); [Angelo Salese]
    - Added a kludge for Jangou Lady RNG,will be worked on in the future;
    [Angelo Salese]


    Added running_machine callbacks for the Amiga code. [Nathan Woods]


    Updated sscope2 to use newly-dumped roms. [robiza]


    Added running_machine parameters to the f3853 callbacks. [Wilbert Pol]


    Added running_machine parameter to the callback in the sid interface.
    [Wilbert Pol]


    Removed MDRV_INTERLEAVE(x), which specified the minimum scheduling
    quantum in terms of "frames" (a dubious concept now with multiple
    screens and changing refresh rates). Replaced it with a new
    MDRV_QUANTUM_TIME(x) which specifies the minimum scheduling quantum
    as a time value. Time can be specified as HZ(x), NSEC(x), USEC(x),
    etc. Updated all drivers to use this, assuming 60 was the frame
    rate (this is not perfect but should work for almost all cases).
    [Aaron Giles]


    Changed MDRV_WATCHDOG_INIT_TIME(x) to automatically prepend
    UINT64_ATTOTIME_IN_ to the parameter, ensuring there is no improper
    use of this macro and bringing it in line with the MDRV_QUANTUM_TIME()
    macro. Updated all callers. [Aaron Giles]


    Added new MDRV_QUANTUM_PERFECT_CPU(x) to specify that the minimum
    quantum should be enough to ensure that the specified CPU tag only
    ever executes a single instruction at a time. This can be used to
    explicitly require "perfect" synchronization for drivers that have
    multiple CPUs with shared memory. Turned this on for the arknoid2
    driver for now as a test (the interleave on that driver was already
    very close to perfect anyway). [Aaron Giles]


    Fixed some color issues in the goldstar.c driver [David Haywood]


    Merged goldstar and lucky8 drivers. [David Haywood]


    Improvements to ddragon3/shadfrce/wwfsstar/wwfwfest: [Mamesick]
    - converted driver to be fully scanlines based using timers
    - updated driver to new video screen raw parameters
    - hooked up interrupts (ddragon3, wwfwfest)


    Fixed Agress' title screen. [David VanVoorhis]


    Fixed update_handler for the dsp56k and polygonet. [Andrew Gardner]


    Improvements to the dmndrby.c driver. [Mike Green]


    Continued rewrite of the Motorola DSP56k CPU core. [Andrew Gardner]
    * Fixed flag calculation and sign extension for numerous ops.
    * Added rnd, mpysuuu, and dmac ops.
    * Fixed do loop behavior to skip empty loops.
    * Added stack underflow exception handling.


    Improvements to the skylncr.c driver: [Roberto Fresca, David Haywood]
    - Complete reel support from the scratch.
    - Full inputs, outputs & DIP switches from the scratch.
    - Added new games.
    - Updated technical and game notes.


    Rewrote 8080/8085 interrupt handling so that it makes sense. Changed
    callbacks to be specified in a config structure. Converted core to
    cpu_state_table. Changed to a single HAS_808X define for both cores.
    Fixed several drivers that used 8080/8085 interrupts in odd ways.
    [Aaron Giles]


    Converted warpwarp driver to raw video parameters. [Aaron Giles]


    Fixe 'run to cursor' and 'toggle breakpoint' operations in the
    debugger when dealing with CPUs that have shifted address spaces.
    [Andrew Gardner]


    Improvements to goldstar.c driver. [Roberto Fresca]
    - Hooked the 3x PPI 8255 devices to chryigld and ncb3.
    - Reworked the chryigld and ncb3 inputs based on PPI 8255 connections.
    - Added the unmapped PSG sound to chryigld and ncb3.
    - Some works on their machine driver.
    - Some cleanups.




    New games added or promoted from NOT_WORKING status
    ---------------------------------------------------
    Country Girl [David Haywood, Angelo Salese]
    4nin-uchi Mahjong Jantotsu [David Haywood, Angelo Salese]
    Three Ds - Three Dealers Casino House [David Haywood, Angelo Salese]
    Sky Lancer (Bordun, ver.U450C) [Roberto Fresca, David Haywood]
    Butterfly Video Game (ver.U350C) [Roberto Fresca, David Haywood]
    Mad Zoo (ver.U450C) [Roberto Fresca, David Haywood]
    Casino Winner [Chris Hardy, Angelo Salese]
    Cherry I Gold (bootleg of Golden Star) [Roberto Fresca]




    New clones added
    ----------------
    Jolly Card (italian, encrypted bootleg) [Roberto Fresca]
    Double Dragon 3 - The Rosetta Stone (prototype) [Guru]




    New games marked as GAME_NOT_WORKING
    ------------------------------------
    Grand Prix 98 [David Haywood]
    Leader [Roberto Fresca, David Haywood]
    Parent Jack [David Haywood]
    Janshi [David Haywood]
    Cherry Master I (v1.01) [Roberto Fresca, David Haywood]