Page 1 of 1

a list of most devices...

Posted: Sat Mar 10, 2007 3:20 am
by earlz
I'm trying to layout the design for all of the devices of my emulator...
It uses external plugins for devices, but the way my messaging system works, I need to have #defines for about every device that has interaction

If you could, add any devices I missed, and anything that might "hook" into it...

here is a bit of a list

keyboard
-KeyPress --usually sent from gui, tells that a key was pressed
-KeyRelease

com(1)
-hook_into --this is a function call or something for communication between com host and com client

lpt
-hook_into --same as above

USB
-hook_into(port_num) -- same as above...

Mouse
-MouseMoved --has a packet of mouse info..(usually sent from GUI)

Floppy
-LoadImage --loads a floppy image, or possibly mounts a floppy drive

DMA(in the core, I guess?)

PCI
-hook_into(card_num) --a function for communication between host and device

Firewire
-hook_into(num) ?no idea on Firewire..

Network_Card
-hook_into... (or should this be considered generic and be put under PCI or whatever?)

ISA
-hook_into(card_num)..hook into for communication

IDE
-hook_into(number) ...I guess, no idea..

CD-Drive
-LoadImage --loads a CD image(.iso) or mounts a CD

HDD
-LoadImahe --same as above

graphics_card
--get_rendering_resolution --this ones already implemented actually..

PIT
?

PIC
-CallIRQ --Calls an IRQ




that's all I can think of right now...

Posted: Sat Mar 10, 2007 1:23 pm
by ~
What about:


TV/Radio Card

Audio Card

Multimedia device (camera, ...)

Game device (joystick, ...)

Posted: Sat Mar 10, 2007 5:41 pm
by Brynet-Inc
~ wrote:What about:


TV/Radio Card

Audio Card

Multimedia device (camera, ...)

Game device (joystick, ...)
Are those absolute essentials? ;)

Anyway.. I would emulate the bare minimal.. considering your targeting the 8086 initially.. Emulate a bare bones ISA-only system?

(PCI/USB/Firewire etc should probably wait a bit..)

Posted: Sat Mar 10, 2007 6:10 pm
by ~
Maybe only the audio is essential just like the network card. A system without any of these get very limited and it's nice to recall its existence.

Re: a list of most devices...

Posted: Sat Mar 10, 2007 9:15 pm
by Brendan
Hi,
hckr83 wrote:I'm trying to layout the design for all of the devices of my emulator...
It uses external plugins for devices, but the way my messaging system works, I need to have #defines for about every device that has interaction
It would be nice to be able to assign a real device to the emulator. For example, open some list of devices (e.g. "Device Manager" in Windows), right click on a second video card and select "make available for emulators", then tell the emulator to use the real video card instead of an emulated video card.

In this case the interface between the emulator and it's plugins would emulate reads/writes to physical addresses (for memory mapped devices), reads/writes to I/O ports, read/writes to PCI configuration space and IRQs; but wouldn't emulate any specific devices.

In addition, the plugins would need to be hierarchical. For e.g. you could have the main CPU module (the emulator itself) with a chipset plugin attached to it. Then the chipset plugin could have a USB controller plugin, and the USB controller plugin could have a USB mouse and flash memory plugin.

Basically, you could treat the OS's IPC like the CPUs front side bus for the interface between the emulator and the chipset plugin; treat the OS's IPC like a PCI bus for the interface between the chipset plugin and PCI device plugins; and treat the OS's IPC like a USB bus for the interface between a USB controller and a USB device plugin; etc.

That way anyone could make a plugin for any hardware (without the emulator knowing much about the hardware), and the host OS's device drivers could support the same interface/s and act like plugins (to allow real devices to be used from within the emulator).

You could also have several different emulators (e.g. one that interprets instructions like Bochs, one that uses dynamic translation, one that uses VMX/SVM hardware virtualization, etc). You could even emulate different CPUs using the same interfaces - for e.g. a SPARC emulator and/or Itanium emulator that uses the same "PCI device" plugins.

It'd be "mix & match emulation heaven", and you won't need to have #defines for every device... ;)


Cheers,

Brendan

Posted: Sat Mar 10, 2007 9:35 pm
by Brynet-Inc
Well if he's trying to make a portable emulator.. That wouldn't be really realistic.. It would be full of "ifdefs/defines" to make that available to people using the Windows "port" :roll:

Posted: Sat Mar 10, 2007 10:13 pm
by Brendan
Hi,
Brynet-Inc wrote:Well if he's trying to make a portable emulator.. That wouldn't be really realistic.. It would be full of "ifdefs/defines" to make that available to people using the Windows "port" :roll:
Portability is a major pain in the neck, but it's a pain in the neck that won't really go away regardless of how the emulator actually works.

For example, (from hckr83's original post) consider the words "but the way my messaging system works".

From what I remember hckr83's messaging system is an asynchronous event driving thing, much like mine. I've tried to implement asynchronous messaging on Linux before (a "portability layer" for C, so applications designed for my OS could be ported to "legacy OSs"). I got the IPC to work using sockets and datagrams on Linux, but by the time I got it to work (and solved some of the other problems) it was far too ugly to consider. It's like making water run uphill - technically possible, but not necessarily good for the environment. ;)

For the ideas above I'd restrict it severely for other OSs (e.g. one portable emulator core and bare minimum hardware emulation). Then I'd tell people to use my OS instead if they want the full singing dancing version of the emulator. This makes good marketting sense too (if you want people to shift from other OSs to your OS, and your "stuff" is good enough).


Cheers,

Brendan

Posted: Sat Mar 10, 2007 10:43 pm
by earlz
lol...my Device IPC(if I can call it that) is much different from my OS design's

This one I think is quite good, it's a mix between Events and Messages...
Basically once an message is sent, A "EventCalled" type function is called with the message stuff...
it has some weird features like CallBack_when_done() is set by the sender to tell that the message was received
and then it goes even weirder with the CallBack_when_CallBack_called() which is called after the CallBack_whendone() is called, and is set by the device that got the message