Wednesday, February 15, 2006

Emulación

Como algunos sabran, ultimamente, para despejarme de proyectos mas grandes y complejos, he recuperado mi emulador de gameboy que escribí por alli el 1999-2000.

Llamarlo emulador seria uno de los peores eufemismos que uno se puede imaginar, pues:

- No emulaba la pantalla
- El emulador de la cpu, tenia mas errores que lineas de codigo
- Todo el timing estaba hecho a ojo

Resumidamente, que era solo un core del z80 modificado que trae la gameboy.

El dia 2 de enero, cuando la xmo'06 de collapse estaba parada esperando a algunos graficos, y que yo corrigiera mil bugs del engine, decidi darle un toque, a ver si lo conseguia. Porque? Hacer un GUI en windows forms me hacia mucha gracia, pero necesitaba algun proyecto, y el emulador era perfecto: necesitaba un debugger decente para la cpu, integrar graficos en la pantalla principal, un visor de sprites... Era la oportunidad perfecta!

Resumiendo las 3 semanas que siguieron, hice mil versiones del debugger, cada una mas usable, un visor de sprites, integré opengl en la ventana principal, para poder ver lo que veria en una gameboy, un visor de "hardware", como lo llamo yo, que no es mas que todas las direcciones de gameboy que controlan la pantalla, y la cpu.

Sobre la parte mas tecnica del emulador, comentaré como lo hice, y quizas, que cosas haria diferente ahora mismo:

1o) Consigue roms libres con codigo. El debugger ayuda mucho para todo lo que no tengas codigo original, pero unos buenos comentarios son mano de santo. A parte, siempre son mas simples que un juego comercial, y ayudan a corregir detalles que de otra manera se te escaparian. Las hay para todas las consolas/maquinas, asi que no hay excusa.

2o) El debugger lo mas simple posible. En las primeras versiones, tenia un debugger super-cutre, sin ni soporte para breakpoints, pero con mucha información sobre los registros especiales. Al final, he sacado esos registros especiales (que no son mas que ciertas direcciones de memoria) a otra ventana, y he dejado el debugger asi:



Mis recomendaciones en concreto, serian: añade soporte para breakpoints lo mas pronto posible, haz que el viewer del desensamblado sea scrollable, y haz que el comando run corra igual que correria el emulador sin debugger. Son detalles simples, pero yo no los tenia al principio, y me he demostrado que son muy utiles.

3o) Debuggea, debuggea, y debuggea. En mi caso, el interpretador, es un switch gigantesco, y tengo que todas las instrucciones que no soporto, salga un error y salga. Antes de emular/jugar a ningun juego, probé mil roms de juegos, solo para asegurarme que el interpretador esta completo, ya habra tiempo para implementar graficos. Puedo decir que me sé gran parte del codigo tanto el Dr. Mario como el Tetris. Si no te gusta debuggear, un emulador te aburrira soberanamente.

Me dejo mil cosas, pero es realmente complejo explicarlo todo en solo un post. Ahora ya emulo el 90% de los juegos de la gameboy mono perfectamente. Otro dia pondré shots :)



Cambiando de tema...

Hablando con diversas personas del IRC y messenger, me comentaron que seria interesante que hablara de emuladores de diversas maquinas, y de joyas que he visto para gameboy/gameboy color. Empezaré por las joyas de gameboy, explicando un poco como es la maquina, para que se entienda un poquito lo que podeis ver.

La gameboy mono solo puede mostrar 4 tonalidades de ocre en un LCD de 160x144 pixeles, su cpu va a 4mhz, y la pantalla funciona con un puntero a tiles de 8x8 pixeles o de 8x16 pixeles. Se pueden mostrar 40 sprites en pantalla, con una limitación de 10 por linea, pudiendo cada sprite estar girado respecto la X, la Y. A parte, tiene un background de 256x256 pixeles, scrolleable en X e Y, que funciona de manera que cuando una parte sale por un lado, aparece en el otro (scrolleable en loop, vaya, pero asi se entiende mejor). También se puede activar, la llamada "window" que es otro background que se pinta encima del background, este no loopea como el background, y tiene una resolución de 256x256. Para mas efectos, los sprites pueden tener prioridades sobre ciertos colores del background y la window, pudiendo crear asi diversos efectos (como un personaje pasando por detras de arboles, o cosas parecidas). La cpu solo puede direccionar 16bits, es decir, 64kb de datos, pero esta limitación se pasa con banking, que no es mas que tener cierto rango de memoria que se puede cambiar por otro al escribir en ciertos registros del cartucho. Con esto, se puede conseguir hasta 8kb de ram, o 2mb de rom. Hasta aqui la explicación rapida de como funciona una gameboy mono de toda la vida.

La gameboy color, funciona a 4 o 8mhz, dependiendo del modo en el que este la cpu, puede mostrar hasta 64 colores en pantalla, de 32768 posibles, pero esto se puede superar cambiando la paleta por scanline. A parte, tiene varias clases de dma, para copiar memoria mas rapido.

Asi pues, tenemos una consola en la que no tenemos acceso directo a pantalla, que todo lo debemos pintar en la tabla de tiles, con una cpu lenta, ademas de tener muy limitados los periodos de escritura en esa ram de tiles.

El mejor emulador actualmente es el kigb, si quereis ver alguna de las roms abajo reseñadas, usadlo!

Demos/juegos impresionantes:

- Stun Race FX: posiblemente lo mas impresionante que he visto nunca. Solo usa la gameboy mono, pero muestra 3D, buena velocidad, y muchas de las cosas que hacia el chip FX de la SuperNintedo, que era una cuantas generaciones mas avanzado. Simplemente impresionante.

- Mental respirator: 3D, buenos efectos y buenos graficos, quien necesita mas?

- Demotronic: Scroll vertical durante el scanline, algo que segun nintendo no se podia hacer. Vale la pena verla solo si sabeis como funcionan las maquinas por tiles.

Ya seguiré comentando segun me pique, a parte, me dijeron a ver si podia comentar emus de diversas consolas, mas en general:

- Gameboy Mono/Color: Kigb. Testeado con todas las roms conocidas de gameboy, 100% compatible, simplemente perfecto. Portado a varios OS, y aun en desarrollo.

- MasterSystem/Gamegear: Meka. Un buen gui, herramientas para desarrollar, y jugar comodamente. Portado a varios OS, con source disponible y aun en desarrollo.

- Megadrive/MegaCD/32x: Gens. Muy rapido y compatible, como pega, que te cambie el escritorio a 16bits. Portado a varios OS, con codigo disponible, algo abandonado.

- Super Nintendo: ZSnes. Muy rapido y compatible, ademas de tener opciones para "mejorar" los graficos como para tirar un tren. Portado a varios OS, con codigo disponible, y en desarrollo.

- Sega Saturn: SSF. El mejor emulador de esta autentica bestia dificil de emulador (tiene 8+ chips que se tienen que sincronizar). Aun en desarrollo, bastante compatible, aunque necesitareis un pc con windows y SSE2.

- Playstation: EPSXE. 100% compatible, rapido, uno de los coders es de por aqui, tiene version windows y linux, y soporta plugins. Algo abandona pero no creo que necesite mas updates.

- Nintendo 64: Project64 (El site a veces esta down). Utiliza emulación de las principales librerias graficas que se usaban en para la n64, asi que pierde compatibilidad en pro de la velocidad. El mas compatible, muy rapido, y aun sigue en desarrollo. Solo para windows, pero el codigo de la 1.4 es libre, asi que se podria "portar".

- Dreamcast: Chankast. Muy rapido, practicamente abandonado, desarrollado por conocidos demosceners. Solo para windows :)

- XBox: CXbx. Un hack de las llamadas a las librerias/hard de xbox, para que rulen en windows, debido al parecido de la XBox a un pc. De momento solo furula el Turok y esta abandonado, pero hay source disponible.

- Playstation 2: pcsx2. Promete ser el mejor, no puedo hablar sobre su rendimiento, a pesar que por los shots promete ir lentillo en la generación actual de CPUs. Sera/es una buena plataforma barata para desarrollar.

- GameCube: Dolphin. Muy lento en nuestra generación de CPUs, pero bastante compatible, y muy impresionante como demostración del "se puede hacer". Sin codigo disponible, pero hay otro emulador hecho por los genios Duddie y Tratax, con source disponible, que dara que hablar cuando sea mas compatible, aqui.

- Nintendo DS: Dualis o DeSmuME. No funcionan juegos comerciales, pero son geniales para desarrollar para DS sin tener que comprar una DS o un cartucho grabable. Tambien es interesante el iDeaS, que hace funcionar alguna rom comercial hasta cierto punto.

Y esto es todo, me he dejado la NES pq nunca me ha interesado mucho, pero diria que el JNes es el mejor.

Buff, 2 posts en un dia, de aqui a 3 meses ya volveré a escribir algo...

2 comments:

xphere said...

Woooo mola!!
Merci per la info!!
Encara recordo una nit que vaig sentir que habien tret un emu de N64, pero que l'habien retirat al cap de un dia... vaig estar buscant i buscant i al final el vaig trobar, i en una o dues horetes ja tenia funcionant... el mario 64!! eren les 5 o les 6 del mati, pero havia valgut la pena :)

El tema dels emu's mola mes del que la gent es pensa, sobretot per la part del codi!! si no fos pq estic enmerdat en 1000 projectes, potser em posaria a fer algun... (una altra cosa es que l'acabés :P)

shash said...

Si, jo també recordo quin emulador era ultraHLE. L'altre dia vaig trobar força informació de com tirava internament, tot i que en ja en sabia molta cosa.

Pero només va ser el primer emulador en correr jocs comercials 3D, ja n'hi havia uns quants abans, que no tiraven res comercial.

Si eso, ya lo traduciré al castellano :P