Main Restorations Software Audio/Jukebox/MP3 Everything Else Buy/Sell/Trade
Project Announcements Monitor/Video GroovyMAME Merit/JVL Touchscreen Meet Up Retail Vendors
Driving & Racing Woodworking Software Support Forums Consoles Project Arcade Reviews
Automated Projects Artwork Frontend Support Forums Pinball Forum Discussion Old Boards
Raspberry Pi & Dev Board controls.dat Linux Miscellaneous Arcade Wiki Discussion Old Archives
Lightguns Arcade1Up Try the site in https mode Site News

Unread posts | New Replies | Recent posts | Rules | Chatroom | Wiki | File Repository | RSS | Submit news

  

Author Topic: MAME v0.93 is out.....  (Read 3464 times)

0 Members and 1 Guest are viewing this topic.

Buddabing

  • Wiki Master
  • Trade Count: (0)
  • Full Member
  • *****
  • Offline Offline
  • Posts: 1845
  • Last login:February 12, 2015, 02:51:45 pm
  • I'm a llama!
MAME v0.93 is out.....
« on: February 27, 2005, 10:53:31 am »
This release is probably buggy, I may not make a BuddaMAME build until a couple of updates have been done.

Here's the whatsnew.txt:

0.93
----

The main feature of this release is Aaron's huge update to the sound system.
There is a high chance this has introduced new sound / crashing bugs in
several drivers. A number of problems were already found and fixed prior to
the 0.93 release thanks to Aaron, Derrick and R.Belmont.  Updates will follow
to correct any severe bugs found.  Please test this release extensively.

----

Sound System update [Aaron Giles]
 (see list below for changes)

Sound System Changes
--------------------

Core changes
-----------
common.c:
* Changed auto_malloc() behavior so that a failure is absolute (calls
osd_die); you can now assume that auto_malloc will always succeed and will
never return NULL.
* Removed all sample loading code; this is now in sound/samples.c

config.c:
* Tried to update this to the new mixer stuff in usrintrf.c, but it hasn't
been tested and I bet it's busted somehow.

driver.h:
* driver->sound_attributes is gone; if you need to detect stereo support,
count the speakers.

mame.h:
* Machine->samples is history (yay!)

timer.c:
* I created a new type of timer that has a pointer for a callback param
instead of an int. These sit next to the existing timer code, so nothing
else is affected. They made object orienting the sound cores much much
cleaner.

usrintrf.c:
* Mixing volumes are retrived from the sound core, not from the mixer (which
is gone). Mixing volumes can now be overdriven to 2.0 (could be increased in
the future)


Machine driver changes
----------------------
* MDRV_SPEAKER_ADD is how to create a new speaker. You specify a name and a
3D vector for where the speaker is relative to the player's head.
* MDRV_SPEAKER_REMOVE and MDRV_SPEAKER_REPLACE operate as expected.
* MDRV_SPEAKER_STANDARD_MONO("name") specifies a single standard mono
speaker positioned directly in front of the user.
* MDRV_SPEAKER_STANDARD_STEREO("leftname","rightname") specifies a standard
pair of stereo speakers situated to the left/right of the user.

* MDRV_SOUND_ADD now takes a 'clock' parameter instead of an interface
pointer. The clock for each chip is specified here rather than in the
interface. I have removed any 'clock'-like parameters from all the sound
interface structures.
* MDRV_SOUND_CONFIG is where you specify the interface. This mirrors
MDRV_CPU_CONFIG. Note that you do not have to specify a config; in this
case, it is NULL. This is ok. Many sound chips really only need a clock and
volume info (which has also been removed from the interface structs).
* MDRV_SOUND_ROUTE is how to control where a sound chip outputs its data.
The first parameter is the output index, or ALL_OUTPUTS if you want to route
all the outputs for a given chip to the same place. The second parameter is
either the name of a speaker or the name of another tagged sound chip. The
third parameter is a floating point gain: 1.0 is standard.
* You can specify as many sound routes as you need; multiple routes for the
same output will split the sound. For example, you can route the single mono
output of an OKIM6295 to both the left and right speakers on a stereo
system.


Sound core interface changes
----------------------------
mixer.c/.h:
* These files are gone, gone, gone. Everything is handled by the streams or
by sndintrf.c directly. Mixing is performed by code in sndintrf.c which
creates a stream to do the final mixing.

sndintrf.h:
* We now no longer #include every sound core's header. You have to include
them yourself in your driver.

sndintrf.c:
* Sound cores are now hooked up very much like CPU cores. There is a single
get_info function that is public for each core; all other functions and data
are retrieved through it.
* Similar to CPU cores, you can call sndtype_xxx() to query/set values for a
specific sound chip type; you can also call sndnum_xxx() to query/set values
for an indexed sound chip in the Machine->drv->sound array; finally, you can
call sndti_xxx() to query/set values for the nth instance of any give sound
chip type (sndti = sound type+index).
* At startup, all sound cores/filters are created. Then all the speakers are
created. Finally, everything is wired up together. There are new consistency
checks to make sure you don't do anything wildly bad.
* sndintrf.c calls the OSD layer now, and always requests stereo output. It
also does a final downmix from the various speaker streams into left/right
streams based on the X coordinate of the speaker.

sound/streams.c:
* I have added a new type defined in sound/streams.h: stream_sample_t, which
is used to represent a sample as used by the stream system. It is typedef'd
to an INT32.
* Regardless of the size of stream_sample_t, all streams should be generated
as if 16 bits were the maximum. The extra bits give us headroom to overdrive
things if we want.
* All streams have the same format callback, with support for multiple
inputs and outputs.
* Each stream has a sample rate; inputs to that stream will be
down/upsampled to that rate; outputs will be down/upsampled as necessary to
connect to the input of the next stream/speaker in line.
* Each input to a stream has its own gain, and each output has a gain as
well. These can be controlled while things are running to provide some extra
volume knobs.
* I haven't done much in the way of optimizations in order to keep things
simple and working. Once things are back to normal, I may consider some
additional optimizations.


Notes for sound core authors
----------------------------
* I marked all sound cores as Copyright the MAME Team; if you want your own
credit there, feel free to send an update.
* I removed all volume and clock speeds from the interfaces; these are
specified elsewhere now.
* I made interfaces optional for many sound chips that often don't need an
interface.
* Many sound cores used global variables and assumed a single instance of
themselves; this has been fixed in all cases.
* In some cases I removed global lookup tables and pushed them into the
sound interfaces. This can eventually be fixed but I didn't want to deal
with it.
* stream_init and stream_init_multi are gone; there is only stream_create
now.
* Streams are named for you automatically, so you don't need to pass in
names to stream_create. Volumes are also outside of your control now, so you
don't need to pass in volumes to stream_create either.
* The get_info function can return pointers to set_info(), start(), stop(),
and reset(). There is no concept of an update() function anymore -- updates
are handled via streams.
* The start() function is passed three things: a 'sound index', which
indicates which instance of chip you are (i.e., 0 if you're the first chip
of this type to be created, 1 if you're the second, etc); a 'clock' which is
specified in the driver (no clocks in the interfaces please!); and a
'config' which is a pointer to the interface for this chip (it can be NULL
too, be careful).
* The start() function now is expected to allocate memory for its data
structures and return a pointer to that if successful. If not, it should
return NULL.
* The pointer returned by the start() function is passed to the stop() and
reset() functions.
* Since there were many cases where we provided a read/write handler for the
'nth' chip, you can also fetch the pointer from the start() function by
calling sndti_token(chip_type, index).
* If you have a non-digital chip that doesn't do internal clipping, you can
probably remove the clipping code and let the mixer clip it in the end.
* If you do your mixing in a secondary buffer to get more bits of
resolution, you can probably optimize your code to mix directly into the
stream buffer.
* While fixing up all the sound cores I was VERY brute force in getting
things to work. If you don't like what I did to your sound core, feel free
to fix it up.


Sound core-specific changes
---------------------------
* ADPCM -- I removed this entirely and wired up dummy MSM5205s to most of
the drivers still using it; these need to be revisited and fixed.
* AY8910 -- cleaned up the interface for the YM chips to access this.
* Custom -- many drivers using "custom" drivers were just using hard-coded
samples and playing them with the (now-defunct) mixer. This is not "custom",
it is "samples". They have been converted over to samples.
* Filter (volume) -- this is a new very simple filter that can be used to
control the volume of a stream if you need an extra knob.
* Filter (RC) -- this is a new filter that replaces the old RC filter that
was in the streams code. Eventually, this could get replaced by some simple
discrete logic.
* IremGA20 -- Acho cod... transmission lost
* NES APU -- changed the way this worked so that it used streams properly
instead of an update function.
* Samples -- there is now a start function that allows you to create your
own custom samples if you want. This allows us to replace "custom" drivers
with "samples" in several cases. There is a new call sample_start_raw()
which lets you play a raw sample from a pointer to INT16 data.
* Votrax -- there was a dead Vortrax core that was still being
hard-compiled. I pulled this out and made it a proper sound type (which
currently isn't included).
* VRender0 -- fixed a clipping bug that was lurking there (negative clipping
wrapped to positive values -- noticeable at 32-bits)
* YM2151 -- removed the alternate version and kept only Jarek's around.
Having two cores was confusing and caused problems.
* YM2203/2608/2610 -- these chips now pass a set of functions into the FM
core with pointers to all the AY8910-compatibility routines, rather than
relying on global pointers.
* YMZ280B -- this code is just terrible now compared to when I first wrote
it! :(

----

Other changes in 0.93
---------------------

Misc patch [Nathan Woods]
   src/debug/debugcpu.c:
      - Changed an instance of memory_get_read_ptr() to memory_get_op_ptr()

   src/cpu/g65816/g65816ds.h:
   src/cpu/g65816/g65816ds.c:
   src/cpu/g65816/g65816.c:
      - G65816 disassembler changes; program_read_byte() is no longer used
   for disassembling and also the core now reports the PC as being the full
   PB or'd with PC

Fixed controls in Hyper Crash (still needs freeplay to start) [Angelo Salese]

Changed Big Striker to use its PROM [Pierpaolo Prazzoli]

Changed way .map file is generated [smf]

SPI Big Endian fix [R.Belmont]

Swapped Namco 54xx filters on Port A & C [Derrick Renaud]
   (fixes xevious sound)
   
C89 fix [Lawrence Gold]

Decrypted GFX in all SPI games [Nicola Salmoria]

Fixed crash in WCBowling 1.2 [Derrick Renaud]

FD1089 update (adding 317-0028) [Nicola Salmoria]

Added many opcodes to Shisensho II decryption table [Pierpaolo Prazzoli]
   game is *almost* working correctly, still some errors
   
Updated MACs driver [Tomasz Slanina]
   yujan now boots but isn't playable

Fixed ddcrew (2 player) sound loading [David Haywood]

Fixed Alien Syndrome ROM names [Shinobiz]

Removed ingame debug button in rachero which was causing you to be locked
to the middle lane [David Haywood]

New Games / Clones supported or promoted from GAME_NOT_WORKING status:
----------------------------------------------------------------------

Ufo Senshi Yohko Chan [Pierpaolo Prazzoli, Nicola Salmoria]

Senkyu / Battle Balls [Nicola Salmoria, Ville Linde]
Raiden Fighters [Nicola Salmoria, Ville Linde]
Raiden Fighters 2 [Nicola Salmoria, Ville Linde]
Raiden Fighters Jet [Nicola Salmoria, Ville Linde]
Viper Phase 1 [Nicola Salmoria, Ville Linde]
E-Jan High School [Nicola Salmoria, Ville Linde]
   sound emulation on the SPI games is still incomplete
   various alpha blending effects missing
   
clones
------

Super Cross (Japan set 2) [Pierpaolo Prazzoli]

Alpha Mission [Dave Widel]

Aliens (World set 3, Japan set 2) [MAN]

Defense [Torsten]
   (note the program roms are bad on the original board, a patch is needed)

High Impact Football Proto v8.6 [Brian Troha]

Surprise Attack (Asia Ver L.) [Andreas Thors
I have changed my nickname to "Cakemeister". Please do not PM the Buddabing account because I do not check it anymore.

Please read the wiki!

SirPeale

  • Green Mountain Man
  • Global Moderator
  • Trade Count: (+23)
  • Full Member
  • *****
  • Offline Offline
  • Posts: 12963
  • Last login:August 04, 2023, 09:51:57 am
  • Arcade Repair in New England
    • Arcade Game and Other Coin-Op Projects
Re: MAME v0.93 is out.....
« Reply #1 on: February 27, 2005, 11:59:22 am »
??? New Galaxian samples ???

MiKman

  • Trade Count: (0)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 360
  • Last login:September 15, 2025, 07:58:44 pm
  • Blah
Re: MAME v0.93 is out.....
« Reply #2 on: February 27, 2005, 12:31:10 pm »
??? New Galaxian samples ???

Looks like there is a whack of new samples needed.  I think with the Sound overhaul we might be best just waiting for next release :)

APFelon

  • Trade Count: (+1)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 564
  • Last login:July 04, 2024, 08:51:53 pm
  • Posts: 5922
Re: MAME v0.93 is out.....
« Reply #3 on: February 27, 2005, 12:51:38 pm »
This looks to be a great release, but I am a bit hesitant to install it on my cab as of yet (due to the possibility of the soundcore rewrite breaking some of my favorite games). Does anyone want to write up their experiences with this release?

APf

SirPeale

  • Green Mountain Man
  • Global Moderator
  • Trade Count: (+23)
  • Full Member
  • *****
  • Offline Offline
  • Posts: 12963
  • Last login:August 04, 2023, 09:51:57 am
  • Arcade Repair in New England
    • Arcade Game and Other Coin-Op Projects
Re: MAME v0.93 is out.....
« Reply #4 on: February 27, 2005, 01:13:45 pm »
Just copy the binary over, rename the old.  Then you can play at will.

mortacci

  • Trade Count: (0)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 24
  • Last login:July 29, 2013, 10:53:04 pm
  • I want to build my own arcade controls!
Re: MAME v0.93 is out.....
« Reply #5 on: February 28, 2005, 10:58:32 am »
What about the DOS versions? When are they comming out? It's been a while since we had an updated DOS version. :-[

Witchboard

  • Trade Count: (+3)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 2002
  • Last login:January 05, 2022, 09:09:24 pm
    • Oklahoma Coin-Operated Collectors
Re: MAME v0.93 is out.....
« Reply #6 on: February 28, 2005, 11:26:01 am »
What about the DOS versions? When are they comming out? It's been a while since we had an updated DOS version. :-[

Huh?  ???

mortacci

  • Trade Count: (0)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 24
  • Last login:July 29, 2013, 10:53:04 pm
  • I want to build my own arcade controls!
Re: MAME v0.93 is out.....
« Reply #7 on: February 28, 2005, 02:13:15 pm »
I was referring to DMAME version .92 and newer. We haven't had a .92 for DOS yet. Why? What is the holdup? I want to get GT2K to play.

papaschtroumpf

  • Trade Count: (0)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 972
  • Last login:July 23, 2013, 11:41:10 pm
  • Have a Cow!
Re: MAME v0.93 is out.....
« Reply #8 on: February 28, 2005, 02:23:16 pm »
Just copy the binary over, rename the old.  Then you can play at will.

unless you need to overwrite some roms or samples in order to use 0.93, in which case you would have to back those up too.

I barely finished upgrading to buddaMame 0.92. I  think I'll wait.

Chris

  • Trade Count: (+2)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 4574
  • Last login:September 21, 2019, 04:59:49 pm
    • Chris's MAME Cabinet
Re: MAME v0.93 is out.....
« Reply #9 on: February 28, 2005, 02:29:24 pm »
I generally update only when there's something compelling in the new version...
--Chris
DOSCab/WinCab Jukebox: http://www.dwjukebox.com

Thenasty

  • Trade Count: (+17)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 4420
  • Last login:Yesterday at 09:36:10 am
    • Thenasty's Arcademania Horizontal/Vertical monitor setup.
Re: MAME v0.93 is out.....
« Reply #10 on: February 28, 2005, 09:09:58 pm »
i'm gonna wait too. I read to much problems with sounds in the mametesters/mame.net forums, so i'll just sit in 92 till something better like 1.0 :)
Thenasty's Arcademania Horizontal/Vertical setup.
http://forum.arcadecontrols.com/index.php?topic=26696.0

Free VGA Breakout Cable
http://forum.arcadecontrols.com/index.php?topic=38228.0

Ultimate All in One Coin Mech write up (Make your own)
http://forum.arcadecontrols.com/index.php?topic=19200.0

SirPeale

  • Green Mountain Man
  • Global Moderator
  • Trade Count: (+23)
  • Full Member
  • *****
  • Offline Offline
  • Posts: 12963
  • Last login:August 04, 2023, 09:51:57 am
  • Arcade Repair in New England
    • Arcade Game and Other Coin-Op Projects
Re: MAME v0.93 is out.....
« Reply #11 on: March 01, 2005, 08:42:17 am »
Just copy the binary over, rename the old.  Then you can play at will.

unless you need to overwrite some roms or samples in order to use 0.93, in which case you would have to back those up too.

I barely finished upgrading to buddaMame 0.92. I  think I'll wait.

The actual number of changed sets between releases is actually very small.  So if you do what I suggested, you can try most games.  And if a game doesn't work due to changes, just try something else.  We're talking about testing here, not production.

GGKoul

  • Cheesecake Apprentice
  • Trade Count: (0)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 4707
  • Last login:May 26, 2024, 02:06:23 am
  • I was once a big man!! -4700 posts later...
Re: MAME v0.93 is out.....
« Reply #12 on: March 01, 2005, 10:15:19 am »
93u1 is already out..

Thenasty

  • Trade Count: (+17)
  • Full Member
  • ***
  • Offline Offline
  • Posts: 4420
  • Last login:Yesterday at 09:36:10 am
    • Thenasty's Arcademania Horizontal/Vertical monitor setup.
Re: MAME v0.93 is out.....
« Reply #13 on: March 01, 2005, 05:42:47 pm »
93u1 is already out..

finally got all those sound probs with 93 fixed. I'll wait for 94.
Thenasty's Arcademania Horizontal/Vertical setup.
http://forum.arcadecontrols.com/index.php?topic=26696.0

Free VGA Breakout Cable
http://forum.arcadecontrols.com/index.php?topic=38228.0

Ultimate All in One Coin Mech write up (Make your own)
http://forum.arcadecontrols.com/index.php?topic=19200.0