libctr9
Nintendo 3DS ARM9 library
diskio.h
1 /*-----------------------------------------------------------------------/
2 / Low level disk interface modlue include file (C)ChaN, 2014 /
3 /-----------------------------------------------------------------------*/
4 
5 #ifndef _DISKIO_DEFINED
6 #define _DISKIO_DEFINED
7 
8 #ifdef __cplusplus
9 extern "C" {
10 #endif
11 
12 #include "integer.h"
13 #include <stddef.h>
14 
15 /* Status of Disk Functions */
16 typedef BYTE DSTATUS;
17 
18 /* Results of Disk Functions */
19 typedef enum {
20  RES_OK = 0, /* 0: Successful */
21  RES_ERROR, /* 1: R/W Error */
22  RES_WRPRT, /* 2: Write Protected */
23  RES_NOTRDY, /* 3: Not Ready */
24  RES_PARERR /* 4: Invalid Parameter */
25 } DRESULT;
26 
27 
28 /*---------------------------------------*/
29 /* Prototypes for disk control functions */
30 
31 DSTATUS disk_initialize (BYTE pdrv);
32 DSTATUS disk_status (BYTE pdrv);
33 DRESULT disk_read (BYTE pdrv, BYTE* buff, DWORD sector, UINT count);
34 DRESULT disk_write (BYTE pdrv, const BYTE* buff, DWORD sector, UINT count);
35 DRESULT disk_ioctl (BYTE pdrv, BYTE cmd, void* buff);
36 
37 
38 /* Disk Status Bits (DSTATUS) */
39 
40 #define STA_NOINIT 0x01 /* Drive not initialized */
41 #define STA_NODISK 0x02 /* No medium in the drive */
42 #define STA_PROTECT 0x04 /* Write protected */
43 
44 
45 /* Command code for disk_ioctrl fucntion */
46 
47 /* Generic command (Used by FatFs) */
48 #define CTRL_SYNC 0 /* Complete pending write process (needed at _FS_READONLY == 0) */
49 #define GET_SECTOR_COUNT 1 /* Get media size (needed at _USE_MKFS == 1) */
50 #define GET_SECTOR_SIZE 2 /* Get sector size (needed at _MAX_SS != _MIN_SS) */
51 #define GET_BLOCK_SIZE 3 /* Get erase block size (needed at _USE_MKFS == 1) */
52 #define CTRL_TRIM 4 /* Inform device that the data on the block of sectors is no longer used (needed at _USE_TRIM == 1) */
53 
54 /* Generic command (Not used by FatFs) */
55 #define CTRL_POWER 5 /* Get/Set power status */
56 #define CTRL_LOCK 6 /* Lock/Unlock media removal */
57 #define CTRL_EJECT 7 /* Eject media */
58 #define CTRL_FORMAT 8 /* Create physical format on the media */
59 
60 /* MMC/SDC specific ioctl command */
61 #define MMC_GET_TYPE 10 /* Get card type */
62 #define MMC_GET_CSD 11 /* Get CSD */
63 #define MMC_GET_CID 12 /* Get CID */
64 #define MMC_GET_OCR 13 /* Get OCR */
65 #define MMC_GET_SDSTAT 14 /* Get SD status */
66 #define ISDIO_READ 55 /* Read data form SD iSDIO register */
67 #define ISDIO_WRITE 56 /* Write data to SD iSDIO register */
68 #define ISDIO_MRITE 57 /* Masked write data to SD iSDIO register */
69 
70 /* ATA/CF specific ioctl command */
71 #define ATA_GET_REV 20 /* Get F/W revision */
72 #define ATA_GET_MODEL 21 /* Get model name */
73 #define ATA_GET_SN 22 /* Get serial number */
74 
75 /* Custom IOCTLs */
76 #define CTR_SETUP_DISK 23 //Set up fatfs disk with the io interface
77 
80 typedef struct
81 {
82  void *io; //io interface to load into fatfs
83  size_t sector_offset; //offset in sectors from beginning of partition
84  size_t sectors; //Size in sectors of partition
86 
87 #ifdef __cplusplus
88 }
89 #endif
90 
91 #endif
Structure used for CTR_SETUP_DISK ioctl.
Definition: diskio.h:80