您的位置:首页 > mame > Makaron WIP模拟器01.24版本内容分享

Makaron WIP模拟器01.24版本内容分享

作者:互联网  时间: 2010-03-03 02:09:53  

Makaron WIP模拟器01.24版更新了哪些内容?下面波波小编为大家带来了Makaron WIP模拟器01.24版本内容分享,一起来看看吧!

Makaron WIP模拟器01.24版本内容分享

原文:

Now the usuall stuff. I'm sure you've noticed how even the MT version gets choppy sometimes, SH4 speed indicator going all red for a split second with sound getting distorted, and so on. If you were paying attention you've noticed your HDD led blinked at the very same moment. Yup, it's not a coincidence. Untill now CD/GD image reads were blocking the main emulator thread - but no more.

I've begun converting GD layer to threaded model and hit few walls (what a surprise, huh?). I mean it's very doable but I have a very specific implementation in mind:

- ATA/ATAPI layer responds according to standards

- INTRQ/DMARQ signals can change asynchronously

- disc reads do not block emulator

- data reads are speed-limited to 12x

- DMA transfers are speed-limited to G1 max. of 10MB/s

I'd also like to move CDDA support from image reader to GD module as a special case of raw sector read. This way I'd have only one place in which the buffers are being refilled from HDD - nice and tidy.

So far I've completed about half of that, that is data reads are not blocking anymore - man, that does make a difference. You will like it :). Still, the limiter on DMA is 10MB/s now and there's none on GD yet. Why would I even need those? Because I like it that way. Sure as hell would make my life easier to just remove them but this is a gauntlet thrown in my face and I will take up that challenge :)

All this and no need for thread blocking other then BSY flag in status register - just like the hardware. But this might not last as I still need to figure out how to convert functions that "open" and "swap" discs - those can be called anytime from main thread (that is, menu that will be there someday). I need to gracefully handle cases like swap requests in the middle of buffer refill for example.

The additional thread doesn't run all the time, it goes to sleep when GD is not being accessed. This means you don't need triple-core (and if you have you will not notice any speedup) beacuse it'll most likely get scheduled to the core doing rendering, once it finishes that of course. I'm sure you realize that on single-core system the read has to block at some point, so non-MT version will have this mechanism disabled and work as they always did.

Oh, by the way, fighters/shooters use fog too:

1640155357320291.png

1640155410195325.png

以上就是小编带来的全部内容了,希望对大家有所帮助,更多游戏资讯,尽在波波三国,敬请关注。

相关资讯

相关应用

最新游戏

更多

Copyright©2010-2019. All rights reserved | 波波三国游戏官网|kofbobo3g@163.com

备案编号:湘ICP备2022015115号-4