Demonstration of a very simple unix-like shell. Based on integrating both Klaus Bu\'s SDHCFileSystem and the FATFileSystem library out of Thomas Hamilton\'s SDCard program. Result: you get high capacity + a plethora of filesystem functions.

Dependencies:   mbed

Committer:
shimniok
Date:
Tue Oct 11 15:13:42 2011 +0000
Revision:
0:792bddcf799d
Initial

Who changed what in which revision?

UserRevisionLine numberNew contents of line
shimniok 0:792bddcf799d 1 /*-----------------------------------------------------------------------
shimniok 0:792bddcf799d 2 / Low level disk interface module include file R0.06 (C)ChaN, 2007
shimniok 0:792bddcf799d 3 /-----------------------------------------------------------------------*/
shimniok 0:792bddcf799d 4
shimniok 0:792bddcf799d 5 //Modified by Thomas Hamilton, Copyright 2010
shimniok 0:792bddcf799d 6
shimniok 0:792bddcf799d 7 #ifndef _DISKIO
shimniok 0:792bddcf799d 8 #define _DISKIO
shimniok 0:792bddcf799d 9
shimniok 0:792bddcf799d 10 #define _READONLY 0
shimniok 0:792bddcf799d 11 #define _USE_IOCTL 1
shimniok 0:792bddcf799d 12
shimniok 0:792bddcf799d 13 #include "integer.h"
shimniok 0:792bddcf799d 14 #include "FATFileSystem.h"
shimniok 0:792bddcf799d 15 #include <stdio.h>
shimniok 0:792bddcf799d 16
shimniok 0:792bddcf799d 17 /* Status of Disk Functions */
shimniok 0:792bddcf799d 18 typedef BYTE DSTATUS;
shimniok 0:792bddcf799d 19 #define STA_NOINIT 0x01 /* Drive not initialized */
shimniok 0:792bddcf799d 20 #define STA_NODISK 0x02 /* No medium in the drive */
shimniok 0:792bddcf799d 21 #define STA_PROTECT 0x04 /* Write protected */
shimniok 0:792bddcf799d 22 /* Results of Disk Functions */
shimniok 0:792bddcf799d 23 typedef enum
shimniok 0:792bddcf799d 24 {
shimniok 0:792bddcf799d 25 RES_OK = 0, /* 0: Successful */
shimniok 0:792bddcf799d 26 RES_ERROR, /* 1: R/W Error */
shimniok 0:792bddcf799d 27 RES_WRPRT, /* 2: Write Protected */
shimniok 0:792bddcf799d 28 RES_NOTRDY, /* 3: Not Ready */
shimniok 0:792bddcf799d 29 RES_PARERR /* 4: Invalid Parameter */
shimniok 0:792bddcf799d 30 } DRESULT;
shimniok 0:792bddcf799d 31
shimniok 0:792bddcf799d 32 /* Prototypes for disk control functions */
shimniok 0:792bddcf799d 33 DSTATUS disk_initialize (BYTE);
shimniok 0:792bddcf799d 34 DSTATUS disk_status (BYTE);
shimniok 0:792bddcf799d 35 DRESULT disk_read (BYTE, BYTE*, DWORD, BYTE);
shimniok 0:792bddcf799d 36 #if _READONLY == 0
shimniok 0:792bddcf799d 37 DRESULT disk_write (BYTE, const BYTE*, DWORD, BYTE);
shimniok 0:792bddcf799d 38 #endif
shimniok 0:792bddcf799d 39 DRESULT disk_ioctl (BYTE, BYTE, void*);
shimniok 0:792bddcf799d 40 /* Command code for disk_ioctrl() */
shimniok 0:792bddcf799d 41 #define CTRL_SYNC 0 /* Mandatory for read/write configuration */
shimniok 0:792bddcf799d 42 #define GET_SECTOR_COUNT 1 /* Mandatory for only f_mkfs() */
shimniok 0:792bddcf799d 43 #define GET_SECTOR_SIZE 2
shimniok 0:792bddcf799d 44 #define GET_BLOCK_SIZE 3 /* Mandatory for only f_mkfs() */
shimniok 0:792bddcf799d 45 #define CTRL_POWER 4
shimniok 0:792bddcf799d 46 #define CTRL_LOCK 5
shimniok 0:792bddcf799d 47 #define CTRL_EJECT 6
shimniok 0:792bddcf799d 48 #define MMC_GET_TYPE 10 /* MMC/SDC command */
shimniok 0:792bddcf799d 49 #define MMC_GET_CSD 11
shimniok 0:792bddcf799d 50 #define MMC_GET_CID 12
shimniok 0:792bddcf799d 51 #define MMC_GET_OCR 13
shimniok 0:792bddcf799d 52 #define MMC_GET_SDSTAT 14
shimniok 0:792bddcf799d 53 #define ATA_GET_REV 20 /* ATA/CF command */
shimniok 0:792bddcf799d 54 #define ATA_GET_MODEL 21
shimniok 0:792bddcf799d 55 #define ATA_GET_SN 22
shimniok 0:792bddcf799d 56
shimniok 0:792bddcf799d 57 #endif