cdvdman imported functions

Discuss the development of software, tools, libraries and anything else that helps make ps2dev happen.

Moderators: cheriff, Herben

Post Reply
tumnes
Posts: 23
Joined: Fri Sep 17, 2004 12:02 pm
Contact:

cdvdman imported functions

Post by tumnes »

I was reading through the source to libcdvd and traced some of the functions, like CdInit(), to cdvdman.h in ps2sdk. From there I noticed that CdInit is the same as sceCdInit which is imported from elsewhere. I was wondering where this function is imported from?
pixel
Posts: 791
Joined: Fri Jan 30, 2004 11:43 pm

Post by pixel »

Okay. You have to understand the mechanism used into the PS2. Here is a quick scheme.

You have two processors. The "main" one, the 'EE', and a "slave" one, the 'IOP'. On the IOP, you have modules, called 'IRX' files. Lot of modules exists into the BIOS, and 'CDVDMAN' is one of them.

When the EE wants to call back an IOP's IRX function, it has to use 'RPC' (Remote Procedure Call).

Now, inside ps2sdk, you can find a file, called libcdvd.c, which contains the reversed RPC to call CDVDMAN's functions. That's when EE wants to call CDVDMAN.

When an IOP's IRX wants to call CDVDMAN's functions, it has to go thru another (simple) mechanism: function imports. You (more or less) only have to include the file cdvdman.h, which will build up some code for you, that will create "stubs" into the IRX. These stubs, in asm, looks like:

Code: Select all

CdInit:
        j       $31
        li      $0, 4
(you can see the file cdvdman.s for a complete sample of what such a stub would look like)

The "4" here is the import number that will get called "for real".


So, in short, when you want to call an IRX from another IRX, say, foo.irx wants to call CDVDMAN, then foo.irx has to contain the cdvdman.s stub (or parts of it). Then, to create the stub file, you have to know the list of imports of the imported irx. Such a list could be, like:

Code: Select all

4 sceCdInit
5 sceCdStandby
6 sceCdRead
7 sceCdSeek
8 sceCdGetError
9 sceCdGetToc
...
Finally: usually, sce-prefixed function names are immediately aliased to their non-prefixed equivalents. For example, see cdvdman.h:

Code: Select all

#define CdInit sceCdInit
#define CdStandby sceCdStandby
#define CdRead sceCdRead
#define CdSeek sceCdSeek
#define CdGetError sceCdGetError
#define CdGetToc sceCdGetToc
...


Hope I was clear...
pixel: A mischievous magical spirit associated with screen displays. The computer industry has frequently borrowed from mythology. Witness the sprites in computer graphics, the demons in artificial intelligence and the trolls in the marketing department.
tumnes
Posts: 23
Joined: Fri Sep 17, 2004 12:02 pm
Contact:

Post by tumnes »

That seems clear enough. So basically cdvdman is an irx module that is always present in the ps2 bios and cdvdman.h provides a way to use that module, correct?
ooPo
Site Admin
Posts: 2023
Joined: Sat Jan 17, 2004 9:56 am
Location: Canada
Contact:

Post by ooPo »

Ding.
Post Reply