How did people program for Consoles with multiple CPUs?How were analytics gathered on software built for retrocomputing platforms?Did Apple not originally allow anyone to develop software for the Macintosh?How did software engineers test their code in 19xx?Did any major corporation ever successfully sue Microsoft for intellectual property theft?Instruction set support for multiplication with a constantBack in the late 1980s, how was commercial software for 8-bit home computers developed?Why did some CPUs use two Read/Write lines, and others just one?

Blender 2.8 I can't see vertices, edges or faces in edit mode

Is it unprofessional to ask if a job posting on GlassDoor is real?

Why can't we play rap on piano?

CEO ridiculed me with gay jokes and grabbed me and wouldn't let go - now getting pushed out of company

Is "remove commented out code" correct English?

Why "Having chlorophyll without photosynthesis is actually very dangerous" and "like living with a bomb"?

What mechanic is there to disable a threat instead of killing it?

Why is it a bad idea to hire a hitman to eliminate most corrupt politicians?

Why is consensus so controversial in Britain?

How could indestructible materials be used in power generation?

How can I make my BBEG immortal short of making them a Lich or Vampire?

What do you call someone who asks many questions?

What reasons are there for a Capitalist to oppose a 100% inheritance tax?

Why do I get two different answers for this counting problem?

Today is the Center

Where does SFDX store details about scratch orgs?

Reserved de-dupe rules

Stopping power of mountain vs road bike

AES: Why is it a good practice to use only the first 16bytes of a hash for encryption?

Doing something right before you need it - expression for this?

Intersection of two sorted vectors in C++

Is there a hemisphere-neutral way of specifying a season?

I would say: "You are another teacher", but she is a woman and I am a man

Facing a paradox: Earnshaw's theorem in one dimension



How did people program for Consoles with multiple CPUs?


How were analytics gathered on software built for retrocomputing platforms?Did Apple not originally allow anyone to develop software for the Macintosh?How did software engineers test their code in 19xx?Did any major corporation ever successfully sue Microsoft for intellectual property theft?Instruction set support for multiplication with a constantBack in the late 1980s, how was commercial software for 8-bit home computers developed?Why did some CPUs use two Read/Write lines, and others just one?













30















I'm specifically interested in the Sega Mega Drive/Genesis, which used a 68000 CPU, but also a Z80, mainly used to control the sound hardware and provide backward compatibility with the Master System.



There was also the Atari Jaguar, with it's Tom and Jerry RISC chips, the Sega Saturn, Featuring a total of eight processors, and probably a lot more.



When writing code (assuming ASM), how would these additional processors be used/accessed? Did one write regular 68000 code (even for sound) and the 68000 itself handled talking to the Z80? Did one need to write two different programs, one for each CPU? If yes, how did they communicate with each other? Or is memory mapping used, which would require a binary that has both 68000 and Z80 instructions in them, making sure that the Z80 code is in a specific memory region?



(This isn't about "regular" multi-processing, like on newer consoles with multi-core CPUs that are all the same. This is about consoles with a main CPU and specialized co-processors for e.g., Sound. Basically, the Sega Genesis, though I'm looking at building my own custom system, so I'm more interested in the basic principles.)










share|improve this question

















  • 3





    "CPU" probably isn't the best term here, though I'm not certain what the idiomatic one of the time is; while you could have a 68k and a Z80, it was also common to see more specialized support chips. The general concept is called asymmetric multiprocessing.

    – chrylis
    Mar 29 at 3:29







  • 1





    Although not a console, in the 1980's, the ATR8000 was a Z80 CP/M system that had an option of replacing the socketed Z80 with a socketed small board that contained a Z80 and a 8088 and 512KB of ram. The 8088 could run MSDOS 2.11, using the Z80 to interface with the peripherals, floppy disks, serial port, printer, and a second serial port used for the ASCII terminal. In CP/M mode, the 512KB of ram could be used as a ramdisk. There was an 8 bit bus used to communicate between the Z80 and the 8088.

    – rcgldr
    Mar 29 at 8:59






  • 1





    The ATR8000 could also be used with an 8 bit Atari 400/800/65XE/130XE, with the Atari used as a terminal, or with the ATR8000 used as a peripheral controller for the Atari, adding a 6502 cpu into the mix, although even if present, the 8088 would not be used if using the ATR8000 as an Atari controller.

    – rcgldr
    Mar 29 at 9:05






  • 1





    Fun fact: New Phones have a similar model; they have a set of several processors of varying power needs/capabilities (at face value, to keep lower-need tasks on lower-power cores to save battery life). Could be worth looking into those for a modern approach to the given problem. IIRC in phones' case, though, it's all handled by the OS.

    – Delioth
    Mar 29 at 20:58







  • 2





    @Delioth While new phones have multiple cores of different speed (i.e. big.LITTLE), they all run the exact same ISA and are completely coherent, so it is transparent to the programmer. The modern equivalent to this problem is more like GPU vs CPU computing.

    – user71659
    Mar 30 at 7:03















30















I'm specifically interested in the Sega Mega Drive/Genesis, which used a 68000 CPU, but also a Z80, mainly used to control the sound hardware and provide backward compatibility with the Master System.



There was also the Atari Jaguar, with it's Tom and Jerry RISC chips, the Sega Saturn, Featuring a total of eight processors, and probably a lot more.



When writing code (assuming ASM), how would these additional processors be used/accessed? Did one write regular 68000 code (even for sound) and the 68000 itself handled talking to the Z80? Did one need to write two different programs, one for each CPU? If yes, how did they communicate with each other? Or is memory mapping used, which would require a binary that has both 68000 and Z80 instructions in them, making sure that the Z80 code is in a specific memory region?



(This isn't about "regular" multi-processing, like on newer consoles with multi-core CPUs that are all the same. This is about consoles with a main CPU and specialized co-processors for e.g., Sound. Basically, the Sega Genesis, though I'm looking at building my own custom system, so I'm more interested in the basic principles.)










share|improve this question

















  • 3





    "CPU" probably isn't the best term here, though I'm not certain what the idiomatic one of the time is; while you could have a 68k and a Z80, it was also common to see more specialized support chips. The general concept is called asymmetric multiprocessing.

    – chrylis
    Mar 29 at 3:29







  • 1





    Although not a console, in the 1980's, the ATR8000 was a Z80 CP/M system that had an option of replacing the socketed Z80 with a socketed small board that contained a Z80 and a 8088 and 512KB of ram. The 8088 could run MSDOS 2.11, using the Z80 to interface with the peripherals, floppy disks, serial port, printer, and a second serial port used for the ASCII terminal. In CP/M mode, the 512KB of ram could be used as a ramdisk. There was an 8 bit bus used to communicate between the Z80 and the 8088.

    – rcgldr
    Mar 29 at 8:59






  • 1





    The ATR8000 could also be used with an 8 bit Atari 400/800/65XE/130XE, with the Atari used as a terminal, or with the ATR8000 used as a peripheral controller for the Atari, adding a 6502 cpu into the mix, although even if present, the 8088 would not be used if using the ATR8000 as an Atari controller.

    – rcgldr
    Mar 29 at 9:05






  • 1





    Fun fact: New Phones have a similar model; they have a set of several processors of varying power needs/capabilities (at face value, to keep lower-need tasks on lower-power cores to save battery life). Could be worth looking into those for a modern approach to the given problem. IIRC in phones' case, though, it's all handled by the OS.

    – Delioth
    Mar 29 at 20:58







  • 2





    @Delioth While new phones have multiple cores of different speed (i.e. big.LITTLE), they all run the exact same ISA and are completely coherent, so it is transparent to the programmer. The modern equivalent to this problem is more like GPU vs CPU computing.

    – user71659
    Mar 30 at 7:03













30












30








30


6






I'm specifically interested in the Sega Mega Drive/Genesis, which used a 68000 CPU, but also a Z80, mainly used to control the sound hardware and provide backward compatibility with the Master System.



There was also the Atari Jaguar, with it's Tom and Jerry RISC chips, the Sega Saturn, Featuring a total of eight processors, and probably a lot more.



When writing code (assuming ASM), how would these additional processors be used/accessed? Did one write regular 68000 code (even for sound) and the 68000 itself handled talking to the Z80? Did one need to write two different programs, one for each CPU? If yes, how did they communicate with each other? Or is memory mapping used, which would require a binary that has both 68000 and Z80 instructions in them, making sure that the Z80 code is in a specific memory region?



(This isn't about "regular" multi-processing, like on newer consoles with multi-core CPUs that are all the same. This is about consoles with a main CPU and specialized co-processors for e.g., Sound. Basically, the Sega Genesis, though I'm looking at building my own custom system, so I'm more interested in the basic principles.)










share|improve this question














I'm specifically interested in the Sega Mega Drive/Genesis, which used a 68000 CPU, but also a Z80, mainly used to control the sound hardware and provide backward compatibility with the Master System.



There was also the Atari Jaguar, with it's Tom and Jerry RISC chips, the Sega Saturn, Featuring a total of eight processors, and probably a lot more.



When writing code (assuming ASM), how would these additional processors be used/accessed? Did one write regular 68000 code (even for sound) and the 68000 itself handled talking to the Z80? Did one need to write two different programs, one for each CPU? If yes, how did they communicate with each other? Or is memory mapping used, which would require a binary that has both 68000 and Z80 instructions in them, making sure that the Z80 code is in a specific memory region?



(This isn't about "regular" multi-processing, like on newer consoles with multi-core CPUs that are all the same. This is about consoles with a main CPU and specialized co-processors for e.g., Sound. Basically, the Sega Genesis, though I'm looking at building my own custom system, so I'm more interested in the basic principles.)







software-development cpu sega-genesis






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Mar 29 at 0:49









Michael StumMichael Stum

25336




25336







  • 3





    "CPU" probably isn't the best term here, though I'm not certain what the idiomatic one of the time is; while you could have a 68k and a Z80, it was also common to see more specialized support chips. The general concept is called asymmetric multiprocessing.

    – chrylis
    Mar 29 at 3:29







  • 1





    Although not a console, in the 1980's, the ATR8000 was a Z80 CP/M system that had an option of replacing the socketed Z80 with a socketed small board that contained a Z80 and a 8088 and 512KB of ram. The 8088 could run MSDOS 2.11, using the Z80 to interface with the peripherals, floppy disks, serial port, printer, and a second serial port used for the ASCII terminal. In CP/M mode, the 512KB of ram could be used as a ramdisk. There was an 8 bit bus used to communicate between the Z80 and the 8088.

    – rcgldr
    Mar 29 at 8:59






  • 1





    The ATR8000 could also be used with an 8 bit Atari 400/800/65XE/130XE, with the Atari used as a terminal, or with the ATR8000 used as a peripheral controller for the Atari, adding a 6502 cpu into the mix, although even if present, the 8088 would not be used if using the ATR8000 as an Atari controller.

    – rcgldr
    Mar 29 at 9:05






  • 1





    Fun fact: New Phones have a similar model; they have a set of several processors of varying power needs/capabilities (at face value, to keep lower-need tasks on lower-power cores to save battery life). Could be worth looking into those for a modern approach to the given problem. IIRC in phones' case, though, it's all handled by the OS.

    – Delioth
    Mar 29 at 20:58







  • 2





    @Delioth While new phones have multiple cores of different speed (i.e. big.LITTLE), they all run the exact same ISA and are completely coherent, so it is transparent to the programmer. The modern equivalent to this problem is more like GPU vs CPU computing.

    – user71659
    Mar 30 at 7:03












  • 3





    "CPU" probably isn't the best term here, though I'm not certain what the idiomatic one of the time is; while you could have a 68k and a Z80, it was also common to see more specialized support chips. The general concept is called asymmetric multiprocessing.

    – chrylis
    Mar 29 at 3:29







  • 1





    Although not a console, in the 1980's, the ATR8000 was a Z80 CP/M system that had an option of replacing the socketed Z80 with a socketed small board that contained a Z80 and a 8088 and 512KB of ram. The 8088 could run MSDOS 2.11, using the Z80 to interface with the peripherals, floppy disks, serial port, printer, and a second serial port used for the ASCII terminal. In CP/M mode, the 512KB of ram could be used as a ramdisk. There was an 8 bit bus used to communicate between the Z80 and the 8088.

    – rcgldr
    Mar 29 at 8:59






  • 1





    The ATR8000 could also be used with an 8 bit Atari 400/800/65XE/130XE, with the Atari used as a terminal, or with the ATR8000 used as a peripheral controller for the Atari, adding a 6502 cpu into the mix, although even if present, the 8088 would not be used if using the ATR8000 as an Atari controller.

    – rcgldr
    Mar 29 at 9:05






  • 1





    Fun fact: New Phones have a similar model; they have a set of several processors of varying power needs/capabilities (at face value, to keep lower-need tasks on lower-power cores to save battery life). Could be worth looking into those for a modern approach to the given problem. IIRC in phones' case, though, it's all handled by the OS.

    – Delioth
    Mar 29 at 20:58







  • 2





    @Delioth While new phones have multiple cores of different speed (i.e. big.LITTLE), they all run the exact same ISA and are completely coherent, so it is transparent to the programmer. The modern equivalent to this problem is more like GPU vs CPU computing.

    – user71659
    Mar 30 at 7:03







3




3





"CPU" probably isn't the best term here, though I'm not certain what the idiomatic one of the time is; while you could have a 68k and a Z80, it was also common to see more specialized support chips. The general concept is called asymmetric multiprocessing.

– chrylis
Mar 29 at 3:29






"CPU" probably isn't the best term here, though I'm not certain what the idiomatic one of the time is; while you could have a 68k and a Z80, it was also common to see more specialized support chips. The general concept is called asymmetric multiprocessing.

– chrylis
Mar 29 at 3:29





1




1





Although not a console, in the 1980's, the ATR8000 was a Z80 CP/M system that had an option of replacing the socketed Z80 with a socketed small board that contained a Z80 and a 8088 and 512KB of ram. The 8088 could run MSDOS 2.11, using the Z80 to interface with the peripherals, floppy disks, serial port, printer, and a second serial port used for the ASCII terminal. In CP/M mode, the 512KB of ram could be used as a ramdisk. There was an 8 bit bus used to communicate between the Z80 and the 8088.

– rcgldr
Mar 29 at 8:59





Although not a console, in the 1980's, the ATR8000 was a Z80 CP/M system that had an option of replacing the socketed Z80 with a socketed small board that contained a Z80 and a 8088 and 512KB of ram. The 8088 could run MSDOS 2.11, using the Z80 to interface with the peripherals, floppy disks, serial port, printer, and a second serial port used for the ASCII terminal. In CP/M mode, the 512KB of ram could be used as a ramdisk. There was an 8 bit bus used to communicate between the Z80 and the 8088.

– rcgldr
Mar 29 at 8:59




1




1





The ATR8000 could also be used with an 8 bit Atari 400/800/65XE/130XE, with the Atari used as a terminal, or with the ATR8000 used as a peripheral controller for the Atari, adding a 6502 cpu into the mix, although even if present, the 8088 would not be used if using the ATR8000 as an Atari controller.

– rcgldr
Mar 29 at 9:05





The ATR8000 could also be used with an 8 bit Atari 400/800/65XE/130XE, with the Atari used as a terminal, or with the ATR8000 used as a peripheral controller for the Atari, adding a 6502 cpu into the mix, although even if present, the 8088 would not be used if using the ATR8000 as an Atari controller.

– rcgldr
Mar 29 at 9:05




1




1





Fun fact: New Phones have a similar model; they have a set of several processors of varying power needs/capabilities (at face value, to keep lower-need tasks on lower-power cores to save battery life). Could be worth looking into those for a modern approach to the given problem. IIRC in phones' case, though, it's all handled by the OS.

– Delioth
Mar 29 at 20:58






Fun fact: New Phones have a similar model; they have a set of several processors of varying power needs/capabilities (at face value, to keep lower-need tasks on lower-power cores to save battery life). Could be worth looking into those for a modern approach to the given problem. IIRC in phones' case, though, it's all handled by the OS.

– Delioth
Mar 29 at 20:58





2




2





@Delioth While new phones have multiple cores of different speed (i.e. big.LITTLE), they all run the exact same ISA and are completely coherent, so it is transparent to the programmer. The modern equivalent to this problem is more like GPU vs CPU computing.

– user71659
Mar 30 at 7:03





@Delioth While new phones have multiple cores of different speed (i.e. big.LITTLE), they all run the exact same ISA and are completely coherent, so it is transparent to the programmer. The modern equivalent to this problem is more like GPU vs CPU computing.

– user71659
Mar 30 at 7:03










2 Answers
2






active

oldest

votes


















37














It varies machine to machine; at the simplest end is the Neo Geo — its 68000 and Z80 have completely independent buses. You write one program for the 68000 and one for the Z80 and a single pipe of communication joins the two: post a byte to the Z80 and it'll trigger an NMI; the Z80 can read the command byte from a certain port and write a response to another, the 68000 can poll for the response. Neo Geo also supplied a sample set of Z80 code so you could just treat it as an advanced sound generator and not worry about the implementation if you prefer.



The Mega Drive has a more complicated system of shared buses; the Z80 has some memory on a private bus but the cartridge bus is a shared resource and I think the Z80 can also share some RAM. In that system the VDP can also act as a bus master so in net it's the Z80 getting access to the shared resources only when nobody else is attempting an access, the 68000 having priority only when it doesn't chose to start a VDP transfer, and the VDP having top priority for those periods when the 68000 has command it to do something.



If you ever hear scratchy sampled audio in a Mega Drive game then it's likely to be the Z80 trying to stream from the cartridge but frequently losing out on access slots.



The Saturn is like a more advanced Mega Drive except that the main CPUs have caches that can also be configured as small local memory pools. So if you're careful you can mostly keep them off the shared bus, gaining a significant performance benefit — Virtua Fighter 2 manages to keep most of the data for each player local to a single CPU for most of a frame, the laziest PlayStation ports do nothing in particular and either end up only using a single CPU or effectively doing so as a result of collection.



The Jaguar is supposed to work similarly to the Saturn but, quelle surprise, Atari rushed it to market so there's a significant bug affecting the RISC CPU's accesses to RAM when performing certain types of jump. That's how it often ends up being treated as a machine with a 68000 central processor when really the 68000 was intended just to be an intelligent scheduler.



So: across these systems one generally writes a different program for each processor, and either nominates one as a coordinator or uses a series of ad hoc means of point-to-point communication.



If it sounds hard to get right, that's because it is — programmers much prefer systems like the original PlayStation with a single CPU that just goes quickly.






share|improve this answer























  • Thank you for pointing out the Neo Geo, I found this article about the communication and this makes a lot of sense - basically two independent CPUs, with the 68k in the drivers seat, and literally different ROMs for each CPU. This looks more elegant than the shared memory approach that e.g., the C64 used, though I'm still doing research.

    – Michael Stum
    Mar 31 at 5:02






  • 1





    Yeah — if you check out the connector on a Neo Geo cartridge e.g. hit930.sakura.ne.jp/hitjapan/NeoGeoAES2/17011308023.jpg you'll notice it has two exposed PCBs rather than the usual one; that's because of the three independent buses in the system (the video system being the third) so there's a lot more than usual to connect.

    – Tommy
    Mar 31 at 18:46


















10














There are two basic techniques: shared memory and dedicated communication ports.



Shared memory simply allows both processors to access the same memory bus. There are some issues, as the bus has to be shared and one CPU has to get priority so code must be designed to take unpredictable extra delays into account. The Megadrive is a good example of that, with the Z80 CPU losing cycles to the 68000 and the graphics subsystem.



It's actually a quite awkward system but they wanted the Z80 for backwards compatibility with Master System games. The system has a dedicated sound chip and the overhead for playing back music and sound effects is so low that there is little benefit to offloading it from the 68000.



The other issue with shared memory is that if one CPU is writing to it while the other is reading it, the reading CPU can end up with corrupt data. Therefore some kind of arbitration is needed, often based on atomic update operations.



Communication ports allow two CPUs on separate buses to communicate. Each CPU has its own bus, its own RAM, its own peripherals and a single I/O port that lets it communicate with the other CPU(s). The port usually allows commands and small amounts of data to be sent, often one way, from one CPU to another and an acknowledgement to be sent back. The Neo Geo is an example of a system that works that, or more common in the west was BBC Micro with its optional second processor via the "tube".



Software for each CPU was written and debugged separately.






share|improve this answer























    Your Answer








    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "648"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    noCode: true, onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fretrocomputing.stackexchange.com%2fquestions%2f9458%2fhow-did-people-program-for-consoles-with-multiple-cpus%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    37














    It varies machine to machine; at the simplest end is the Neo Geo — its 68000 and Z80 have completely independent buses. You write one program for the 68000 and one for the Z80 and a single pipe of communication joins the two: post a byte to the Z80 and it'll trigger an NMI; the Z80 can read the command byte from a certain port and write a response to another, the 68000 can poll for the response. Neo Geo also supplied a sample set of Z80 code so you could just treat it as an advanced sound generator and not worry about the implementation if you prefer.



    The Mega Drive has a more complicated system of shared buses; the Z80 has some memory on a private bus but the cartridge bus is a shared resource and I think the Z80 can also share some RAM. In that system the VDP can also act as a bus master so in net it's the Z80 getting access to the shared resources only when nobody else is attempting an access, the 68000 having priority only when it doesn't chose to start a VDP transfer, and the VDP having top priority for those periods when the 68000 has command it to do something.



    If you ever hear scratchy sampled audio in a Mega Drive game then it's likely to be the Z80 trying to stream from the cartridge but frequently losing out on access slots.



    The Saturn is like a more advanced Mega Drive except that the main CPUs have caches that can also be configured as small local memory pools. So if you're careful you can mostly keep them off the shared bus, gaining a significant performance benefit — Virtua Fighter 2 manages to keep most of the data for each player local to a single CPU for most of a frame, the laziest PlayStation ports do nothing in particular and either end up only using a single CPU or effectively doing so as a result of collection.



    The Jaguar is supposed to work similarly to the Saturn but, quelle surprise, Atari rushed it to market so there's a significant bug affecting the RISC CPU's accesses to RAM when performing certain types of jump. That's how it often ends up being treated as a machine with a 68000 central processor when really the 68000 was intended just to be an intelligent scheduler.



    So: across these systems one generally writes a different program for each processor, and either nominates one as a coordinator or uses a series of ad hoc means of point-to-point communication.



    If it sounds hard to get right, that's because it is — programmers much prefer systems like the original PlayStation with a single CPU that just goes quickly.






    share|improve this answer























    • Thank you for pointing out the Neo Geo, I found this article about the communication and this makes a lot of sense - basically two independent CPUs, with the 68k in the drivers seat, and literally different ROMs for each CPU. This looks more elegant than the shared memory approach that e.g., the C64 used, though I'm still doing research.

      – Michael Stum
      Mar 31 at 5:02






    • 1





      Yeah — if you check out the connector on a Neo Geo cartridge e.g. hit930.sakura.ne.jp/hitjapan/NeoGeoAES2/17011308023.jpg you'll notice it has two exposed PCBs rather than the usual one; that's because of the three independent buses in the system (the video system being the third) so there's a lot more than usual to connect.

      – Tommy
      Mar 31 at 18:46















    37














    It varies machine to machine; at the simplest end is the Neo Geo — its 68000 and Z80 have completely independent buses. You write one program for the 68000 and one for the Z80 and a single pipe of communication joins the two: post a byte to the Z80 and it'll trigger an NMI; the Z80 can read the command byte from a certain port and write a response to another, the 68000 can poll for the response. Neo Geo also supplied a sample set of Z80 code so you could just treat it as an advanced sound generator and not worry about the implementation if you prefer.



    The Mega Drive has a more complicated system of shared buses; the Z80 has some memory on a private bus but the cartridge bus is a shared resource and I think the Z80 can also share some RAM. In that system the VDP can also act as a bus master so in net it's the Z80 getting access to the shared resources only when nobody else is attempting an access, the 68000 having priority only when it doesn't chose to start a VDP transfer, and the VDP having top priority for those periods when the 68000 has command it to do something.



    If you ever hear scratchy sampled audio in a Mega Drive game then it's likely to be the Z80 trying to stream from the cartridge but frequently losing out on access slots.



    The Saturn is like a more advanced Mega Drive except that the main CPUs have caches that can also be configured as small local memory pools. So if you're careful you can mostly keep them off the shared bus, gaining a significant performance benefit — Virtua Fighter 2 manages to keep most of the data for each player local to a single CPU for most of a frame, the laziest PlayStation ports do nothing in particular and either end up only using a single CPU or effectively doing so as a result of collection.



    The Jaguar is supposed to work similarly to the Saturn but, quelle surprise, Atari rushed it to market so there's a significant bug affecting the RISC CPU's accesses to RAM when performing certain types of jump. That's how it often ends up being treated as a machine with a 68000 central processor when really the 68000 was intended just to be an intelligent scheduler.



    So: across these systems one generally writes a different program for each processor, and either nominates one as a coordinator or uses a series of ad hoc means of point-to-point communication.



    If it sounds hard to get right, that's because it is — programmers much prefer systems like the original PlayStation with a single CPU that just goes quickly.






    share|improve this answer























    • Thank you for pointing out the Neo Geo, I found this article about the communication and this makes a lot of sense - basically two independent CPUs, with the 68k in the drivers seat, and literally different ROMs for each CPU. This looks more elegant than the shared memory approach that e.g., the C64 used, though I'm still doing research.

      – Michael Stum
      Mar 31 at 5:02






    • 1





      Yeah — if you check out the connector on a Neo Geo cartridge e.g. hit930.sakura.ne.jp/hitjapan/NeoGeoAES2/17011308023.jpg you'll notice it has two exposed PCBs rather than the usual one; that's because of the three independent buses in the system (the video system being the third) so there's a lot more than usual to connect.

      – Tommy
      Mar 31 at 18:46













    37












    37








    37







    It varies machine to machine; at the simplest end is the Neo Geo — its 68000 and Z80 have completely independent buses. You write one program for the 68000 and one for the Z80 and a single pipe of communication joins the two: post a byte to the Z80 and it'll trigger an NMI; the Z80 can read the command byte from a certain port and write a response to another, the 68000 can poll for the response. Neo Geo also supplied a sample set of Z80 code so you could just treat it as an advanced sound generator and not worry about the implementation if you prefer.



    The Mega Drive has a more complicated system of shared buses; the Z80 has some memory on a private bus but the cartridge bus is a shared resource and I think the Z80 can also share some RAM. In that system the VDP can also act as a bus master so in net it's the Z80 getting access to the shared resources only when nobody else is attempting an access, the 68000 having priority only when it doesn't chose to start a VDP transfer, and the VDP having top priority for those periods when the 68000 has command it to do something.



    If you ever hear scratchy sampled audio in a Mega Drive game then it's likely to be the Z80 trying to stream from the cartridge but frequently losing out on access slots.



    The Saturn is like a more advanced Mega Drive except that the main CPUs have caches that can also be configured as small local memory pools. So if you're careful you can mostly keep them off the shared bus, gaining a significant performance benefit — Virtua Fighter 2 manages to keep most of the data for each player local to a single CPU for most of a frame, the laziest PlayStation ports do nothing in particular and either end up only using a single CPU or effectively doing so as a result of collection.



    The Jaguar is supposed to work similarly to the Saturn but, quelle surprise, Atari rushed it to market so there's a significant bug affecting the RISC CPU's accesses to RAM when performing certain types of jump. That's how it often ends up being treated as a machine with a 68000 central processor when really the 68000 was intended just to be an intelligent scheduler.



    So: across these systems one generally writes a different program for each processor, and either nominates one as a coordinator or uses a series of ad hoc means of point-to-point communication.



    If it sounds hard to get right, that's because it is — programmers much prefer systems like the original PlayStation with a single CPU that just goes quickly.






    share|improve this answer













    It varies machine to machine; at the simplest end is the Neo Geo — its 68000 and Z80 have completely independent buses. You write one program for the 68000 and one for the Z80 and a single pipe of communication joins the two: post a byte to the Z80 and it'll trigger an NMI; the Z80 can read the command byte from a certain port and write a response to another, the 68000 can poll for the response. Neo Geo also supplied a sample set of Z80 code so you could just treat it as an advanced sound generator and not worry about the implementation if you prefer.



    The Mega Drive has a more complicated system of shared buses; the Z80 has some memory on a private bus but the cartridge bus is a shared resource and I think the Z80 can also share some RAM. In that system the VDP can also act as a bus master so in net it's the Z80 getting access to the shared resources only when nobody else is attempting an access, the 68000 having priority only when it doesn't chose to start a VDP transfer, and the VDP having top priority for those periods when the 68000 has command it to do something.



    If you ever hear scratchy sampled audio in a Mega Drive game then it's likely to be the Z80 trying to stream from the cartridge but frequently losing out on access slots.



    The Saturn is like a more advanced Mega Drive except that the main CPUs have caches that can also be configured as small local memory pools. So if you're careful you can mostly keep them off the shared bus, gaining a significant performance benefit — Virtua Fighter 2 manages to keep most of the data for each player local to a single CPU for most of a frame, the laziest PlayStation ports do nothing in particular and either end up only using a single CPU or effectively doing so as a result of collection.



    The Jaguar is supposed to work similarly to the Saturn but, quelle surprise, Atari rushed it to market so there's a significant bug affecting the RISC CPU's accesses to RAM when performing certain types of jump. That's how it often ends up being treated as a machine with a 68000 central processor when really the 68000 was intended just to be an intelligent scheduler.



    So: across these systems one generally writes a different program for each processor, and either nominates one as a coordinator or uses a series of ad hoc means of point-to-point communication.



    If it sounds hard to get right, that's because it is — programmers much prefer systems like the original PlayStation with a single CPU that just goes quickly.







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered Mar 29 at 1:27









    TommyTommy

    16k14678




    16k14678












    • Thank you for pointing out the Neo Geo, I found this article about the communication and this makes a lot of sense - basically two independent CPUs, with the 68k in the drivers seat, and literally different ROMs for each CPU. This looks more elegant than the shared memory approach that e.g., the C64 used, though I'm still doing research.

      – Michael Stum
      Mar 31 at 5:02






    • 1





      Yeah — if you check out the connector on a Neo Geo cartridge e.g. hit930.sakura.ne.jp/hitjapan/NeoGeoAES2/17011308023.jpg you'll notice it has two exposed PCBs rather than the usual one; that's because of the three independent buses in the system (the video system being the third) so there's a lot more than usual to connect.

      – Tommy
      Mar 31 at 18:46

















    • Thank you for pointing out the Neo Geo, I found this article about the communication and this makes a lot of sense - basically two independent CPUs, with the 68k in the drivers seat, and literally different ROMs for each CPU. This looks more elegant than the shared memory approach that e.g., the C64 used, though I'm still doing research.

      – Michael Stum
      Mar 31 at 5:02






    • 1





      Yeah — if you check out the connector on a Neo Geo cartridge e.g. hit930.sakura.ne.jp/hitjapan/NeoGeoAES2/17011308023.jpg you'll notice it has two exposed PCBs rather than the usual one; that's because of the three independent buses in the system (the video system being the third) so there's a lot more than usual to connect.

      – Tommy
      Mar 31 at 18:46
















    Thank you for pointing out the Neo Geo, I found this article about the communication and this makes a lot of sense - basically two independent CPUs, with the 68k in the drivers seat, and literally different ROMs for each CPU. This looks more elegant than the shared memory approach that e.g., the C64 used, though I'm still doing research.

    – Michael Stum
    Mar 31 at 5:02





    Thank you for pointing out the Neo Geo, I found this article about the communication and this makes a lot of sense - basically two independent CPUs, with the 68k in the drivers seat, and literally different ROMs for each CPU. This looks more elegant than the shared memory approach that e.g., the C64 used, though I'm still doing research.

    – Michael Stum
    Mar 31 at 5:02




    1




    1





    Yeah — if you check out the connector on a Neo Geo cartridge e.g. hit930.sakura.ne.jp/hitjapan/NeoGeoAES2/17011308023.jpg you'll notice it has two exposed PCBs rather than the usual one; that's because of the three independent buses in the system (the video system being the third) so there's a lot more than usual to connect.

    – Tommy
    Mar 31 at 18:46





    Yeah — if you check out the connector on a Neo Geo cartridge e.g. hit930.sakura.ne.jp/hitjapan/NeoGeoAES2/17011308023.jpg you'll notice it has two exposed PCBs rather than the usual one; that's because of the three independent buses in the system (the video system being the third) so there's a lot more than usual to connect.

    – Tommy
    Mar 31 at 18:46











    10














    There are two basic techniques: shared memory and dedicated communication ports.



    Shared memory simply allows both processors to access the same memory bus. There are some issues, as the bus has to be shared and one CPU has to get priority so code must be designed to take unpredictable extra delays into account. The Megadrive is a good example of that, with the Z80 CPU losing cycles to the 68000 and the graphics subsystem.



    It's actually a quite awkward system but they wanted the Z80 for backwards compatibility with Master System games. The system has a dedicated sound chip and the overhead for playing back music and sound effects is so low that there is little benefit to offloading it from the 68000.



    The other issue with shared memory is that if one CPU is writing to it while the other is reading it, the reading CPU can end up with corrupt data. Therefore some kind of arbitration is needed, often based on atomic update operations.



    Communication ports allow two CPUs on separate buses to communicate. Each CPU has its own bus, its own RAM, its own peripherals and a single I/O port that lets it communicate with the other CPU(s). The port usually allows commands and small amounts of data to be sent, often one way, from one CPU to another and an acknowledgement to be sent back. The Neo Geo is an example of a system that works that, or more common in the west was BBC Micro with its optional second processor via the "tube".



    Software for each CPU was written and debugged separately.






    share|improve this answer



























      10














      There are two basic techniques: shared memory and dedicated communication ports.



      Shared memory simply allows both processors to access the same memory bus. There are some issues, as the bus has to be shared and one CPU has to get priority so code must be designed to take unpredictable extra delays into account. The Megadrive is a good example of that, with the Z80 CPU losing cycles to the 68000 and the graphics subsystem.



      It's actually a quite awkward system but they wanted the Z80 for backwards compatibility with Master System games. The system has a dedicated sound chip and the overhead for playing back music and sound effects is so low that there is little benefit to offloading it from the 68000.



      The other issue with shared memory is that if one CPU is writing to it while the other is reading it, the reading CPU can end up with corrupt data. Therefore some kind of arbitration is needed, often based on atomic update operations.



      Communication ports allow two CPUs on separate buses to communicate. Each CPU has its own bus, its own RAM, its own peripherals and a single I/O port that lets it communicate with the other CPU(s). The port usually allows commands and small amounts of data to be sent, often one way, from one CPU to another and an acknowledgement to be sent back. The Neo Geo is an example of a system that works that, or more common in the west was BBC Micro with its optional second processor via the "tube".



      Software for each CPU was written and debugged separately.






      share|improve this answer

























        10












        10








        10







        There are two basic techniques: shared memory and dedicated communication ports.



        Shared memory simply allows both processors to access the same memory bus. There are some issues, as the bus has to be shared and one CPU has to get priority so code must be designed to take unpredictable extra delays into account. The Megadrive is a good example of that, with the Z80 CPU losing cycles to the 68000 and the graphics subsystem.



        It's actually a quite awkward system but they wanted the Z80 for backwards compatibility with Master System games. The system has a dedicated sound chip and the overhead for playing back music and sound effects is so low that there is little benefit to offloading it from the 68000.



        The other issue with shared memory is that if one CPU is writing to it while the other is reading it, the reading CPU can end up with corrupt data. Therefore some kind of arbitration is needed, often based on atomic update operations.



        Communication ports allow two CPUs on separate buses to communicate. Each CPU has its own bus, its own RAM, its own peripherals and a single I/O port that lets it communicate with the other CPU(s). The port usually allows commands and small amounts of data to be sent, often one way, from one CPU to another and an acknowledgement to be sent back. The Neo Geo is an example of a system that works that, or more common in the west was BBC Micro with its optional second processor via the "tube".



        Software for each CPU was written and debugged separately.






        share|improve this answer













        There are two basic techniques: shared memory and dedicated communication ports.



        Shared memory simply allows both processors to access the same memory bus. There are some issues, as the bus has to be shared and one CPU has to get priority so code must be designed to take unpredictable extra delays into account. The Megadrive is a good example of that, with the Z80 CPU losing cycles to the 68000 and the graphics subsystem.



        It's actually a quite awkward system but they wanted the Z80 for backwards compatibility with Master System games. The system has a dedicated sound chip and the overhead for playing back music and sound effects is so low that there is little benefit to offloading it from the 68000.



        The other issue with shared memory is that if one CPU is writing to it while the other is reading it, the reading CPU can end up with corrupt data. Therefore some kind of arbitration is needed, often based on atomic update operations.



        Communication ports allow two CPUs on separate buses to communicate. Each CPU has its own bus, its own RAM, its own peripherals and a single I/O port that lets it communicate with the other CPU(s). The port usually allows commands and small amounts of data to be sent, often one way, from one CPU to another and an acknowledgement to be sent back. The Neo Geo is an example of a system that works that, or more common in the west was BBC Micro with its optional second processor via the "tube".



        Software for each CPU was written and debugged separately.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Mar 29 at 9:52









        useruser

        4,015818




        4,015818



























            draft saved

            draft discarded
















































            Thanks for contributing an answer to Retrocomputing Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fretrocomputing.stackexchange.com%2fquestions%2f9458%2fhow-did-people-program-for-consoles-with-multiple-cpus%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Boston (Lincolnshire) Stedsbyld | Berne yn Boston | NavigaasjemenuBoston Borough CouncilBoston, Lincolnshire

            Ballerup Komuun Stääden an saarpen | Futnuuten | Luke uk diar | Nawigatsjuunwww.ballerup.dkwww.statistikbanken.dk: Tabelle BEF44 (Folketal pr. 1. januar fordelt på byer)Commonskategorii: Ballerup Komuun55° 44′ N, 12° 22′ O

            Serbia Índice Etimología Historia Geografía Entorno natural División administrativa Política Demografía Economía Cultura Deportes Véase también Notas Referencias Bibliografía Enlaces externos Menú de navegación44°49′00″N 20°28′00″E / 44.816666666667, 20.46666666666744°49′00″N 20°28′00″E / 44.816666666667, 20.466666666667U.S. Department of Commerce (2015)«Informe sobre Desarrollo Humano 2018»Kosovo-Metohija.Neutralna Srbija u NATO okruzenju.The SerbsTheories on the Origin of the Serbs.Serbia.Earls: Webster's Quotations, Facts and Phrases.Egeo y Balcanes.Kalemegdan.Southern Pannonia during the age of the Great Migrations.Culture in Serbia.History.The Serbian Origin of the Montenegrins.Nemanjics' period (1186-1353).Stefan Uros (1355-1371).Serbian medieval history.Habsburg–Ottoman Wars (1525–1718).The Ottoman Empire, 1700-1922.The First Serbian Uprising.Miloš, prince of Serbia.3. Bosnia-Hercegovina and the Congress of Berlin.The Balkan Wars and the Partition of Macedonia.The Falcon and the Eagle: Montenegro and Austria-Hungary, 1908-1914.Typhus fever on the eastern front in World War I.Anniversary of WWI battle marked in Serbia.La derrota austriaca en los Balcanes. Fin del Imperio Austro-Húngaro.Imperio austriaco y Reino de Hungría.Los tiempos modernos: del capitalismo a la globalización, siglos XVII al XXI.The period of Croatia within ex-Yugoslavia.Yugoslavia: Much in a Name.Las dictaduras europeas.Croacia: mito y realidad."Crods ask arms".Prólogo a la invasión.La campaña de los Balcanes.La resistencia en Yugoslavia.Jasenovac Research Institute.Día en memoria de las víctimas del genocidio en la Segunda Guerra Mundial.El infierno estuvo en Jasenovac.Croacia empieza a «desenterrar» a sus muertos de Jasenovac.World fascism: a historical encyclopedia, Volumen 1.Tito. Josip Broz.El nuevo orden y la resistencia.La conquista del poder.Algunos aspectos de la economía yugoslava a mediados de 1962.Albania-Kosovo crisis.De Kosovo a Kosova: una visión demográfica.La crisis de la economía yugoslava y la política de "estabilización".Milosevic: el poder de un absolutista."Serbia under Milošević: politics in the 1990s"Milosevic cavó en Kosovo la tumba de la antigua Yugoslavia.La ONU exculpa a Serbia de genocidio en la guerra de Bosnia.Slobodan Milosevic, el burócrata que supo usar el odio.Es la fuerza contra el sufrimiento de muchos inocentes.Matanza de civiles al bombardear la OTAN un puente mientras pasaba un tren.Las consecuencias negativas de los bombardeos de Yugoslavia se sentirán aún durante largo tiempo.Kostunica advierte que la misión de Europa en Kosovo es ilegal.Las 24 horas más largas en la vida de Slobodan Milosevic.Serbia declara la guerra a la mafia por matar a Djindjic.Tadic presentará "quizás en diciembre" la solicitud de entrada en la UE.Montenegro declara su independencia de Serbia.Serbia se declara estado soberano tras separación de Montenegro.«Accordance with International Law of the Unilateral Declaration of Independence by the Provisional Institutions of Self-Government of Kosovo (Request for Advisory Opinion)»Mladic pasa por el médico antes de la audiencia para extraditarloDatos de Serbia y Kosovo.The Carpathian Mountains.Position, Relief, Climate.Transport.Finding birds in Serbia.U Srbiji do 2010. godine 10% teritorije nacionalni parkovi.Geography.Serbia: Climate.Variability of Climate In Serbia In The Second Half of The 20thc Entury.BASIC CLIMATE CHARACTERISTICS FOR THE TERRITORY OF SERBIA.Fauna y flora: Serbia.Serbia and Montenegro.Información general sobre Serbia.Republic of Serbia Environmental Protection Agency (SEPA).Serbia recycling 15% of waste.Reform process of the Serbian energy sector.20-MW Wind Project Being Developed in Serbia.Las Naciones Unidas. Paz para Kosovo.Aniversario sin fiesta.Population by national or ethnic groups by Census 2002.Article 7. Coat of arms, flag and national anthem.Serbia, flag of.Historia.«Serbia and Montenegro in Pictures»Serbia.Serbia aprueba su nueva Constitución con un apoyo de más del 50%.Serbia. Population.«El nacionalista Nikolic gana las elecciones presidenciales en Serbia»El europeísta Borís Tadic gana la segunda vuelta de las presidenciales serbias.Aleksandar Vucic, de ultranacionalista serbio a fervoroso europeístaKostunica condena la declaración del "falso estado" de Kosovo.Comienza el debate sobre la independencia de Kosovo en el TIJ.La Corte Internacional de Justicia dice que Kosovo no violó el derecho internacional al declarar su independenciaKosovo: Enviado de la ONU advierte tensiones y fragilidad.«Bruselas recomienda negociar la adhesión de Serbia tras el acuerdo sobre Kosovo»Monografía de Serbia.Bez smanjivanja Vojske Srbije.Military statistics Serbia and Montenegro.Šutanovac: Vojni budžet za 2009. godinu 70 milijardi dinara.Serbia-Montenegro shortens obligatory military service to six months.No hay justicia para las víctimas de los bombardeos de la OTAN.Zapatero reitera la negativa de España a reconocer la independencia de Kosovo.Anniversary of the signing of the Stabilisation and Association Agreement.Detenido en Serbia Radovan Karadzic, el criminal de guerra más buscado de Europa."Serbia presentará su candidatura de acceso a la UE antes de fin de año".Serbia solicita la adhesión a la UE.Detenido el exgeneral serbobosnio Ratko Mladic, principal acusado del genocidio en los Balcanes«Lista de todos los Estados Miembros de las Naciones Unidas que son parte o signatarios en los diversos instrumentos de derechos humanos de las Naciones Unidas»versión pdfProtocolo Facultativo de la Convención sobre la Eliminación de todas las Formas de Discriminación contra la MujerConvención contra la tortura y otros tratos o penas crueles, inhumanos o degradantesversión pdfProtocolo Facultativo de la Convención sobre los Derechos de las Personas con DiscapacidadEl ACNUR recibe con beneplácito el envío de tropas de la OTAN a Kosovo y se prepara ante una posible llegada de refugiados a Serbia.Kosovo.- El jefe de la Minuk denuncia que los serbios boicotearon las legislativas por 'presiones'.Bosnia and Herzegovina. Population.Datos básicos de Montenegro, historia y evolución política.Serbia y Montenegro. Indicador: Tasa global de fecundidad (por 1000 habitantes).Serbia y Montenegro. Indicador: Tasa bruta de mortalidad (por 1000 habitantes).Population.Falleció el patriarca de la Iglesia Ortodoxa serbia.Atacan en Kosovo autobuses con peregrinos tras la investidura del patriarca serbio IrinejSerbian in Hungary.Tasas de cambio."Kosovo es de todos sus ciudadanos".Report for Serbia.Country groups by income.GROSS DOMESTIC PRODUCT (GDP) OF THE REPUBLIC OF SERBIA 1997–2007.Economic Trends in the Republic of Serbia 2006.National Accounts Statitics.Саопштења за јавност.GDP per inhabitant varied by one to six across the EU27 Member States.Un pacto de estabilidad para Serbia.Unemployment rate rises in Serbia.Serbia, Belarus agree free trade to woo investors.Serbia, Turkey call investors to Serbia.Success Stories.U.S. Private Investment in Serbia and Montenegro.Positive trend.Banks in Serbia.La Cámara de Comercio acompaña a empresas madrileñas a Serbia y Croacia.Serbia Industries.Energy and mining.Agriculture.Late crops, fruit and grapes output, 2008.Rebranding Serbia: A Hobby Shortly to Become a Full-Time Job.Final data on livestock statistics, 2008.Serbian cell-phone users.U Srbiji sve više računara.Телекомуникације.U Srbiji 27 odsto gradjana koristi Internet.Serbia and Montenegro.Тренд гледаности програма РТС-а у 2008. и 2009.години.Serbian railways.General Terms.El mercado del transporte aéreo en Serbia.Statistics.Vehículos de motor registrados.Planes ambiciosos para el transporte fluvial.Turismo.Turistički promet u Republici Srbiji u periodu januar-novembar 2007. godine.Your Guide to Culture.Novi Sad - city of culture.Nis - european crossroads.Serbia. Properties inscribed on the World Heritage List .Stari Ras and Sopoćani.Studenica Monastery.Medieval Monuments in Kosovo.Gamzigrad-Romuliana, Palace of Galerius.Skiing and snowboarding in Kopaonik.Tara.New7Wonders of Nature Finalists.Pilgrimage of Saint Sava.Exit Festival: Best european festival.Banje u Srbiji.«The Encyclopedia of world history»Culture.Centenario del arte serbio.«Djordje Andrejevic Kun: el único pintor de los brigadistas yugoslavos de la guerra civil española»About the museum.The collections.Miroslav Gospel – Manuscript from 1180.Historicity in the Serbo-Croatian Heroic Epic.Culture and Sport.Conversación con el rector del Seminario San Sava.'Reina Margot' funde drama, historia y gesto con música de Goran Bregovic.Serbia gana Eurovisión y España decepciona de nuevo con un vigésimo puesto.Home.Story.Emir Kusturica.Tercer oro para Paskaljevic.Nikola Tesla Year.Home.Tesla, un genio tomado por loco.Aniversario de la muerte de Nikola Tesla.El Museo Nikola Tesla en Belgrado.El inventor del mundo actual.República de Serbia.University of Belgrade official statistics.University of Novi Sad.University of Kragujevac.University of Nis.Comida. Cocina serbia.Cooking.Montenegro se convertirá en el miembro 204 del movimiento olímpico.España, campeona de Europa de baloncesto.El Partizan de Belgrado se corona campeón por octava vez consecutiva.Serbia se clasifica para el Mundial de 2010 de Sudáfrica.Serbia Name Squad For Northern Ireland And South Korea Tests.Fútbol.- El Partizán de Belgrado se proclama campeón de la Liga serbia.Clasificacion final Mundial de balonmano Croacia 2009.Serbia vence a España y se consagra campeón mundial de waterpolo.Novak Djokovic no convence pero gana en Australia.Gana Ana Ivanovic el Roland Garros.Serena Williams gana el US Open por tercera vez.Biography.Bradt Travel Guide SerbiaThe Encyclopedia of World War IGobierno de SerbiaPortal del Gobierno de SerbiaPresidencia de SerbiaAsamblea Nacional SerbiaMinisterio de Asuntos exteriores de SerbiaBanco Nacional de SerbiaAgencia Serbia para la Promoción de la Inversión y la ExportaciónOficina de Estadísticas de SerbiaCIA. Factbook 2008Organización nacional de turismo de SerbiaDiscover SerbiaConoce SerbiaNoticias de SerbiaSerbiaWorldCat1512028760000 0000 9526 67094054598-2n8519591900570825ge1309191004530741010url17413117006669D055771Serbia