SceSdstor: Difference between revisions
Jump to navigation
Jump to search
No edit summary |
(→Types) |
||
Line 204: | Line 204: | ||
uint32_t unk_20; // = 0 | uint32_t unk_20; // = 0 | ||
uint8_t intr_table_index; | uint8_t intr_table_index; // check interrupt table section | ||
uint8_t unk_25; // = 0 | uint8_t unk_25; // = 0 | ||
uint8_t unk_26; // = 0 | uint8_t unk_26; // = 0 | ||
Line 218: | Line 218: | ||
insert_handler* SceSdstorCardInsert_handler; | insert_handler* SceSdstorCardInsert_handler; | ||
remove_handler* SceSdstorCardRemove_handler; | remove_handler* SceSdstorCardRemove_handler; | ||
uint8_t intr_table_index; | uint8_t intr_table_index; // check interrupt table section | ||
uint8_t SceSdstorCardInsert_subintr_code; | uint8_t SceSdstorCardInsert_subintr_code; | ||
uint8_t SceSdstorCardRemove_subintr_code; | uint8_t SceSdstorCardRemove_subintr_code; |
Revision as of 21:53, 11 July 2017
Module
SceSdstor module does not export any functions exсept module_start.
This module is responsible for initializing all storage devices. This includes:
- eMMC
- Game gard
- Memory card
- Usb Mass Storage (unknown SceUsbMassForDriver)
Based on layout of data segment and code of some subroutines (mbr table init, partition entry table init etc) it can be said that there are 5 devices in total. However only first 3 devices are known at the moment.
Known NIDs
Version | Name | World | Privilege | NID |
---|---|---|---|---|
1.69 | SceSdstor | Non-secure | Kernel | 0x5804A397 |
3.60 | SceSdstor | ? | Kernel | 0xD7FBAE7C |
Libraries
Known NIDs
Version | Name | World | Visibility | NID |
---|
Interrupt Table
Index | Code | Name |
---|---|---|
0 | 0xDC | SceSdif0 |
1 | 0xDD | SceSdif1 |
2 | 0x3C | SceMsifIns |
3 | 0xF | |
4 | 0xDF | SceSdif3 |
Types
Looks like SceSdstor driver uses its own device type
Device Type Index | Description |
---|---|
0 | MMC card |
1 | SD card |
2 | Memory Card |
3 | USB Mass Storage |
typedef struct partition_entry_raw { uint32_t partitionOffset; uint32_t partitionSize; uint8_t partitionCode; uint8_t partitionType; uint8_t partitionActive; uint32_t flags; uint16_t unk; }partition_entry_raw; typedef struct partition_entry //size is 0x1C { uint32_t partitionOffset; //from MBR uint32_t partitionSize; //from MBR sdstor_mbr_ctx* ctx; partition_entry_raw* partitionEntryPtr; //pointer to raw partition entry in MBR char numericName[4]; //null terminated name (000, 001, ...) uint32_t flags1; //from MBR uint16_t unk2; //from MBR uint16_t unk3; //? }partition_entry; typedef struct sdstor_mbr_ctx //size is 0x238 { uint32_t fast_mutex_SceSdStorPartitionTable; uint32_t unk_4; uint32_t unk_8; uint32_t unk_C; uint8_t unk_0[0x30]; uint32_t unk_40; sd_stor_device* dev; uint32_t unk_48; uint32_t unk_4C; uint32_t unk_50; void* mbr_ptr; //pointer to corresponding MBR record in array (offset 0x40) partition_entry partitions[17]; // 16 real partition entries from MBR + some hardcoded 17th partition entry uint8_t unk_234; //some initialization flag (0, 1, 2) uint8_t unk_235; uint8_t unk_236; //some initialization flag (set to 0 if partition table is initialized) uint8_t unk_237; }sdstor_mbr_ctx; //named after "SceSdStorDevice" mutex typedef struct sd_stor_device //size is 0x54 { uint32_t fast_mutex_SceSdStorDevice; uint32_t unk_4; uint32_t unk_8; uint32_t unk_C; uint32_t unk_10; uint32_t unk_14; uint32_t unk_18; uint32_t unk_1C; uint32_t unk_20; uint32_t unk_24; uint32_t unk_28; uint32_t unk_2C; uint32_t unk_30; uint32_t unk_34; uint32_t unk_38; uint32_t unk_3C; char index1; // (0x00, 0x01, 0xFF, 0xFF, 0x03) // sd ctx index used to get sd_context_part* (0, 1 confirmed) (3 unknown) char index2; // (0x00, 0x00 / 0x01, 0x02, 0x03, 0x01) // device type idx , not related to sdif type! char unk_42; // (0, 1) looks like init flag. 1 means that device is initialized and can be accessed char unk_43; uint32_t unk_44; uint32_t unk_48; uint32_t unk_4C; void* devCtx; //pointer to dev ctx (sd_context_part_mmc*) or zero }sd_stor_device; //named after SceSdStorDeviceHandle mutex and pool typedef struct sd_stor_device_handle //size is 0x58 { uint32_t fast_mutex_SceSdStorDeviceHandle; uint32_t unk_4; uint32_t unk_8; uint32_t unk_C; uint32_t unk_10; uint32_t unk_14; uint32_t unk_18; uint32_t unk_1C; uint32_t unk_20; uint32_t unk_24; uint32_t unk_28; uint32_t unk_2C; uint32_t unk_30; uint32_t unk_34; uint32_t unk_38; uint32_t unk_3C; uint32_t unk_40; uint32_t partitionOffset; uint32_t partitionSize; uint32_t unk_4C; partition_entry* pentry; sd_stor_device* dev; }sd_stor_device_handle; typedef struct unknown_1C2C //size is 0x1C { uint8_t data[0x1C]; }unknown_1C2C; typedef struct interrupt_argument //size is 0x28 { uint32_t unk_0; SceUID SceSdstorRequest_evid; // event id SceUID SceSdstorOpSync_evid; // event id interrupt_info* intr_info; // unknown_1C2C* unk_10; uint32_t unk_14; // = 0 uint32_t unk_18; // = 0 uint32_t unk_1C; // = 0 uint32_t unk_20; // = 0 uint8_t intr_table_index; // check interrupt table section uint8_t unk_25; // = 0 uint8_t unk_26; // = 0 uint8_t unk_27; } interrupt_argument; typedef int(insert_handler)(int unk, interrupt_argument* arg); typedef int(remove_handler)(int unk, interrupt_argument* arg); typedef struct interrupt_info //size is 0xC { insert_handler* SceSdstorCardInsert_handler; remove_handler* SceSdstorCardRemove_handler; uint8_t intr_table_index; // check interrupt table section uint8_t SceSdstorCardInsert_subintr_code; uint8_t SceSdstorCardRemove_subintr_code; uint8_t unk_B; } interrupt_info;
Data segment layout
Address | Size | Description |
---|---|---|
0x0000 | 0x20 | unknown |
0x0020 | 0x14 | array of 5 integers (number created device handles?) (each corresponds to sd_stor_device) |
0x0034 | 0x4 | unknown |
0x0038 | 0x4 | SceSdStorDeviceHandle mempool SceUID of size 0x2000
|
0x003C | 0x4 | unknown |
0x0040 | 0x200 | MBR of eMMC |
0x0240 | 0x200 | MBR of Game gard |
0x0440 | 0x200 | MBR of Memory card |
0x0640 | 0x200 | unknown (most likely for MBR since there are 5 elements in all arrays) |
0x0840 | 0x200 | unknown (most likely for MBR since there are 5 elements in all arrays) |
0x0A40 | 0x238 | sdstor_mbr_ctx element 0 |
0x0C78 | 0x238 | sdstor_mbr_ctx element 1 |
0x0EB0 | 0x238 | sdstor_mbr_ctx element 2 |
0x10E8 | 0x238 | sdstor_mbr_ctx element 3 |
0x1320 | 0x238 | sdstor_mbr_ctx element 4 |
0x1558 | 0x54 | sd_stor_device element 0 |
0x15AC | 0x54 | sd_stor_device element 1 |
0x1600 | 0x54 | sd_stor_device element 2 |
0x1654 | 0x54 | sd_stor_device element 3 |
0x16A8 | 0x54 | sd_stor_device element 4 |
0x16FC | 0x20 | vfs_add_data sdstor_dev_fs node
|
0x171C | 0x04 | SceSdStorVfs mempool SceUID of size 0x2000
|
0x1720 | 0x200 | unknown |
0x1920 | 0x200 | unknown |
0x1B20 | 0xC8 | array of 5 structures of size 0x28 |
0x1BE8 | 0x8 | suspend_register_callback opt |
0x1BF0 | 0x3C | array of 5 structures of size 0xC |
0x1C2C | 0x8C | array of 5 structures of size 0x1C |
0x1CB8 | 0x8 | unknown |
0x1CC0 | 0x200 | MBR of Game card |
SceSdstor
module_start
Version | NID |
---|---|
3.60 | 0x935cd196 |
int module_start();