Multi Media Card Library
The Multi Media Card (MMC) is a Flash memory card standard. MMC cards are currently available in sizes up to and including 32 GB and are used in cellular phones, digital audio players, digital cameras and PDA’s. 
mikroBasic PRO for PIC32 provides a library for accessing data on Multi Media Card via SPI communication. This library also supports SD (Secure Digital) and high capacity SDHC (Secure Digital High Capacity) memory cards .
Secure Digital Card
Secure Digital (SD) is a Flash memory card standard, based on the older Multi Media Card (MMC) format. 
SD cards are currently available in sizes of up to and including 2 GB, and are used in digital cameras, digital camcorders, handheld computers, media players, mobile phones, GPS receivers, video games and PDAs.
Secure Digital High Capacity Card
SDHC (Secure Digital High Capacity, SD 2.0) is an extension of the SD standard which increases card's storage capacity up to 32 GB by using sector addressing instead of byte addressing in the previous SD standard. 
  
SDHC cards share the same physical and electrical form factor as older (SD 1.x) cards, allowing SDHC-devices to support both newer SDHC cards and older SD-cards. The current standard limits the maximum capacity of an SDHC card to 32 GB.
 Important :
  Important :   
      - Routines for file handling can be used only with FAT16 file system.
- Library functions create and read files from the root directory only.
- Library functions populate both FAT1 and FAT2 tables when writing to files, but the file data is being read from the FAT1 table only; i.e. there is no recovery if the FAT1 table gets corrupted.
- If MMC/SD card has Master Boot Record (MBR), the library will work with the first available primary (logical) partition that has non-zero size. If MMC/SD card has Volume Boot Record (i.e. there is only one logical partition and no MBRs), the library works with entire card as a single partition. For more information on MBR, physical and logical drives, primary/secondary partitions and partition tables, please consult other resources, e.g. Wikipedia and similar.
- Before write operation, make sure you don’t overwrite boot or FAT sector as it could make your card on PC or digital camera unreadable. Drive mapping tools, such as Winhex, can be of a great assistance.
- Library uses SPI module for communication. The user must initialize the appropriate SPI module before using the MMC Library.
- For MCUs with multiple SPI modules it is possible to initialize all of them and then switch by using the SPI_Set_Active()function. See the SPI Library functions.
The SPI module has to be initialized through SPIx_Init_Advanced routine with the following parameters:
- SPI Master
- 8bit mode
- secondary prescaler 1
- primary prescaler 64
- Slave Select disabled
- data sampled in the middle of data output time
- clock idle high
- Serial output data changes on transition from active clock state to idle clock state
 Tip :  
	  Once the MMC/SD card is initialized, SPI module can be reinitialized at higher a speed. See the Mmc_Init and Mmc_Fat_Init routines.
  Tip :  
	  Once the MMC/SD card is initialized, SPI module can be reinitialized at higher a speed. See the Mmc_Init and Mmc_Fat_Init routines.
    Library Dependency Tree
 
  
    
    External dependencies of MMC Library
| The following variable must be defined in all projects using MMC library: | Description : | Example : | 
|---|---|---|
| dim Mmc_Chip_Select as sbit sfr atomic external | Chip select pin. | dim Mmc_Chip_Select as sbit at LATF0_bit | 
| dim Mmc_Chip_Select_Direction as sbit sfr atomic external | Direction of the chip select pin. | dim Mmc_Chip_Select_Direction as sbit at TRISF0_bit | 
Library Routines
- Mmc_Init
- Mmc_Read_Sector
- Mmc_Write_Sector
- Mmc_Read_Cid
- Mmc_Read_Csd
- Mmc_Multi_Read_Start
- Mmc_Multi_Read_Sector
- Mmc_Multi_Read_Stop
Routines for file handling:
- Mmc_Fat_Init
- Mmc_Fat_QuickFormat
- Mmc_Fat_Assign
- Mmc_Fat_Reset
- Mmc_Fat_Read
- Mmc_Fat_Rewrite
- Mmc_Fat_Append
- Mmc_Fat_Delete
- Mmc_Fat_Write
- Mmc_Fat_Set_File_Date
- Mmc_Fat_Get_File_Date
- Mmc_Fat_Get_File_Date_Modified
- Mmc_Fat_Get_File_Size
- Mmc_Get_File_Write_Sector
- Mmc_Fat_Get_Swap_File
- Mmc_Fat_Tell
- Mmc_Fat_Seek
- Mmc_Fat_Rename
- Mmc_Fat_MakeDir
- Mmc_Fat_RenameDir
- Mmc_Fat_RemoveDir
- Mmc_Fat_ChangeDir
- Mmc_Fat_Exists
- Mmc_Fat_Dir
- Mmc_Fat_ReadDir
- Mmc_Fat_Activate
- Mmc_Fat_ReadN
- Mmc_Fat_Open
- Mmc_Fat_Close
- Mmc_Fat_EOF
Mmc_Init
| Prototype | sub function Mmc_Init() as word | 
|---|---|
| Description | Initializes MMC through hardware SPI interface. Mmc_Init needs to be called before using other functions of this library. | 
| Parameters | None. | 
| Returns | 
 
 | 
| Requires | The appropriate hardware SPI module must be previously initialized.Global variables : 
 | 
| Example | ' MMC module connections dim Mmc_Chip_Select as sbit at LATF0_bit ' for writing to output pin always use latch (PIC18 family) dim Mmc_Chip_Select_Direction as sbit at TRISF0_bit ' MMC module connections dim error as byte ... ' Initialize the SPI module SPI1_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, 64,_SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE) ' Loop until MMC is initialized Mmc_Init() ' Reinitialize the SPI module at higher speed (change primary prescaler). SPI1_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, 8,_SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE) | 
| Notes | None. | 
Mmc_Read_Sector
| Prototype | sub function Mmc_Read_Sector(dim sector as longword, dim byref dbuff as byte[512]) as word | 
|---|---|
| Description | The function reads one sector (512 bytes) from MMC card. | 
| Parameters | 
 | 
| Returns | 
 
 | 
| Requires | MMC/SD card must be initialized. See Mmc_Init. | 
| Example | 
' read sector 510 of the MMC/SD card
dim error as word
    sectorNo as longword
    dataBuffer as byte[512]
...
sectorNo = 510
error = Mmc_Read_Sector(sectorNo, dataBuffer) | 
| Notes | None. | 
Mmc_Write_Sector
| Prototype | sub function Mmc_Write_Sector(dim sector as longword, dim byref data as byte[512]) as word | 
|---|---|
| Description | The function writes 512 bytes of data to one MMC card sector. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card must be initialized. See Mmc_Init. | 
| Example | 
' write to sector 510 of the MMC/SD card
dim error as word
    sectorNo as longword
    dataBuffer as byte[512]
...
sectorNo = 510
error = Mmc_Write_Sector(sectorNo, dataBuffer) | 
| Notes | None. | 
Mmc_Read_Cid
| Prototype | sub function Mmc_Read_Cid(dim byref data_cid as byte[16]) as byte | 
|---|---|
| Description | The function reads 16-byte CID register. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card must be initialized. See Mmc_Init. | 
| Example | 
dim error as word
    dataBuffer as byte[512]
...
error = Mmc_Read_Cid(dataBuffer) | 
| Notes | None. | 
Mmc_Read_Csd
| Prototype | sub function Mmc_Read_Csd(dim byref data_csd as byte[16]) as word | 
|---|---|
| Description | The function reads 16-byte CSD register. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card must be initialized. See Mmc_Init. | 
| Example | 
dim error as word
    dataBuffer as byte[512]
...
error = Mmc_Read_Csd(dataBuffer) | 
| Notes | None. | 
Mmc_Multi_Read_Start
| Prototype | sub function Mmc_Multi_Read_Start(dim sector as longword) as word | 
|---|---|
| Description | The function starts multi read mode, sectors are sequentially read starting from the sector given in the function argument. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card must be initialized. See Mmc_Init. | 
| Example | dim error as word dim sector as longword ... error = Mmc_Multi_Read_Start(sector) | 
| Notes | None. | 
Mmc_Multi_Read_Sector
| Prototype | sub procedure Mmc_Multi_Read_Sector(dim byref dbuff as byte[512]) | 
|---|---|
| Description | The procedure reads sectors in multi read mode and places them in the buffer given as the function argument. Next function call reads the subsequent sector. Buffer size should be 512B. | 
| Parameters | 
 | 
| Returns | Nothing. | 
| Requires | MMC/SD card must be initialized. See Mmc_Init. | 
| Example | dim dataBuffer as byte[512] ... Mmc_Multi_Read_Sector(dataBuffer) | 
| Notes | None. | 
Mmc_Multi_Read_Stop
| Prototype | sub function Mmc_Multi_Read_Stop() as word | 
|---|---|
| Description | The function stops multi read mode sequence. | 
| Parameters | None. | 
| Returns | 
 | 
| Requires | MMC/SD card must be initialized. See Mmc_Init. | 
| Example | error = Mmc_Multi_Read_Stop() | 
| Notes | None. | 
Mmc_Fat_Init
| Prototype | sub function Mmc_Fat_Init() as word | 
|---|---|
| Description | Initializes MMC/SD card, reads MMC/SD FAT16 boot sector and extracts necessary data needed by the library. | 
| Parameters | None. | 
| Returns | 
 | 
| Requires | Global variables : 
 The appropriate hardware SPI module must be previously initialized. See the SPIx_Init, SPIx_Init_Advanced routines. | 
| Example | ' MMC module connections dim Mmc_Chip_Select as sbit sfr at LATF0_bit dim Mmc_Chip_Select_Direction as sbit sfr at TRISF0_bit ' MMC module connections ... ' Initialize the SPI module SPI1_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, _SPI_PRESCALE_SEC_1, _SPI_PRESCALE_PRI_64,_SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE) ' Initialize MMC/SD card and MMC_FAT16 library globals Mmc_Fat_Init() ' Reinitialize the SPI module at higher speed (change primary prescaler). SPI1_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, _SPI_PRESCALE_SEC_1, _SPI_PRESCALE_PRI_4,_SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE) | 
| Notes | MMC/SD card has to be formatted to FAT16 file system. | 
Mmc_Fat_QuickFormat
| Prototype | sub function Mmc_Fat_QuickFormat(dim byref mmc_fat_label as string[11]) as word | 
|---|---|
| Description | Formats to FAT16 and initializes MMC/SD card. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | The appropriate hardware SPI module must be previously initialized. | 
| Example | 
' Initialize the SPI module
SPI1_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, _SPI_PRESCALE_SEC_1, _SPI_PRESCALE_PRI_64, _SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE)
' Format and initialize MMC/SD card and MMC_FAT16 library globals
Mmc_Fat_QuickFormat("mikroE")
' Reinitialize the SPI module at higher speed (change primary prescaler).
SPI1_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, _SPI_PRESCALE_SEC_1, _SPI_PRESCALE_PRI_4,_SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE)
 | 
| Notes | This routine can be used instead or in conjunction with Mmc_Fat_Init routine. If MMC/SD card already contains a valid boot sector, it will remain unchanged (except volume label field) and only FAT and ROOT tables will be erased. Also, the new volume label will be set. | 
Mmc_Fat_Assign
| Prototype | sub function Mmc_Fat_Assign(dim byref filename as char[11], dim file_cre_attr as byte) as word | |||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Description | Assigns file for file operations (read, write, delete...). All subsequent file operations will be applied on an assigned file. | |||||||||||||||||||||||||||
| Parameters | 
 
 
 | |||||||||||||||||||||||||||
| Returns | 
 | |||||||||||||||||||||||||||
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | |||||||||||||||||||||||||||
| Example | 
' create file with archive attribut if it does not already exist
Mmc_Fat_Assign("MIKRO007.TXT",0xA0) | |||||||||||||||||||||||||||
| Notes | Long File Names (LFN) are not supported. | 
Mmc_Fat_Reset
| Prototype | sub procedure Mmc_Fat_Reset(dim byref size as longword) | 
|---|---|
| Description | Procedure resets the file pointer (moves it to the start of the file) of the assigned file, so that the file can be read. | 
| Parameters | 
 | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | dim size as longword ... Mmc_Fat_Reset(size) | 
| Notes | None. | 
Mmc_Fat_Read
| Prototype | sub procedure Mmc_Fat_Read(dim byref bdata as byte) | 
|---|---|
| Description | Reads a byte from the currently assigned file opened for reading. Upon function execution file pointers will be set to the next character in the file. | 
| Parameters | 
 | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. The file must be opened for reading. See Mmc_Fat_Reset. | 
| Example | dim character as byte ... Mmc_Fat_Read(character) | 
| Notes | None. | 
Mmc_Fat_Rewrite
| Prototype | sub procedure Mmc_Fat_Rewrite() | 
|---|---|
| Description | Opens the currently assigned file for writing. If the file is not empty its content will be erased. | 
| Parameters | None. | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | ' open file for writing Mmc_Fat_Rewrite() | 
| Notes | None. | 
Mmc_Fat_Append
| Prototype | sub procedure Mmc_Fat_Append() | 
|---|---|
| Description | Opens the currently assigned file for appending. Upon this function execution file pointers will be positioned after the last byte in the file, so any subsequent file write operation will start from there. | 
| Parameters | None. | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | ' open file for appending Mmc_Fat_Append() | 
| Notes | None. | 
Mmc_Fat_Delete
| Prototype | sub procedure Mmc_Fat_Delete() | 
|---|---|
| Description | Deletes currently assigned file from MMC/SD card. | 
| Parameters | None. | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | ' delete current file Mmc_Fat_Delete() | 
| Notes | None. | 
Mmc_Fat_Write
| Prototype | sub procedure Mmc_Fat_Write(dim byref fdata as byte[512], dim data_len as word) | 
|---|---|
| Description | Writes requested number of bytes to the currently assigned file opened for writing. | 
| Parameters | 
 | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. The file must be opened for writing. See Mmc_Fat_Rewrite or Mmc_Fat_Append. | 
| Example | dim file_contents as byte[42] ... Mmc_Fat_Write(file_contents, 42) ' write data to the assigned file | 
| Notes | None. | 
Mmc_Fat_Set_File_Date
| Prototype | sub procedure Mmc_Fat_Set_File_Date(dim year as word, dim month as byte, dim day as byte, dim hours as byte, dim mins as byte, dim seconds as byte) | 
|---|---|
| Description | Sets the date/time stamp. Any subsequent file write operation will write this stamp to the currently assigned file's time/date attributes. | 
| Parameters | 
 | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. The file must be opened for writing. See Mmc_Fat_Rewrite or Mmc_Fat_Append. | 
| Example | Mmc_Fat_Set_File_Date(2005,9,30,17,41,0) | 
| Notes | None. | 
Mmc_Fat_Get_File_Date
| Prototype | sub procedure Mmc_Fat_Get_File_Date(dim byref year as word, dim byref month as byte, dim byref day as byte, dim byref hours as byte, dim byref mins as byte) | 
|---|---|
| Description | Reads time/date attributes of the currently assigned file. | 
| Parameters | 
 | 
| Returns | Nothing. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | 
dim year as word
    month, day, hours, mins as byte
...
Mmc_Fat_Get_File_Date(year, month, day, hours, mins) | 
| Notes | None. | 
Mmc_Fat_Get_File_Date_Modified
| Prototype | sub procedure Mmc_Fat_Get_File_Date_Modified(dim byref year as word, dim byref month as byte, dim byref day as byte, dim byref hours as byte, dim byref mins as byte) | 
|---|---|
| Description | Retrieves the last modification date/time for the currently selected file. Seconds are not being retrieved since they are written in 2-sec increments. | 
| Parameters | 
 | 
| Returns | Nothing. | 
| Requires | The file must be assigned, see Mmc_Fat_Assign. | 
| Example | 
dim year as word
    month, day, hours, mins as byte
...
Mmc_Fat_Get_File_Date_Modified(year, month, day, hours, mins) | 
Mmc_Fat_Get_File_Size
| Prototype | sub function Mmc_Fat_Get_File_Size() as longword | 
|---|---|
| Description | This function reads size of the currently assigned file in bytes. | 
| Parameters | None. | 
| Returns | This function returns size of active file (in bytes). | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | dim my_file_size as longword ... my_file_size = Mmc_Fat_Get_File_Size() | 
| Notes | None. | 
Mmc_Get_File_Write_Sector
| Prototype | sub function Mmc_Get_File_Write_Sector() as longword | 
|---|---|
| Description | This function returns the current file write sector. | 
| Parameters | None. | 
| Returns | This function returns the current file write sector. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | dim sector as longword ... sector = Mmc_Get_File_Write_Sector() | 
| Notes | None. | 
Mmc_Fat_Get_Swap_File
| Prototype | sub function Mmc_Fat_Get_Swap_File(dim sectors_cnt as longword, dim byref filename as string[11], dim file_attr as byte) as longword | |||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Description | This function is used to create a swap file of predefined name and size on the MMC/SD media. If a file with specified name already exists on the media, search for consecutive sectors will ignore sectors occupied by this file. Therefore, it is recommended to erase such file if it already exists before calling this function. If it is not erased and there is still enough space for a new swap file, this function will delete it after allocating new memory space for a new swap file. The purpose of the swap file is to make reading and writing to MMC/SD media as fast as possible, by using the Mmc_Read_Sector() and Mmc_Write_Sector() functions directly, without potentially damaging the FAT system. The swap file can be considered as a "window" on the media where the user can freely write/read data. It's main purpose in this library is to be used for fast data acquisition; when the time-critical acquisition has finished, the data can be re-written into a "normal" file, and formatted in the most suitable way. | |||||||||||||||||||||||||||
| Parameters | 
 
 
 | |||||||||||||||||||||||||||
| Returns | 
 
 | |||||||||||||||||||||||||||
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | |||||||||||||||||||||||||||
| Example | '-------------- Try to create a swap file with archive atribute, whose size will be at least 1000 sectors. ' If it succeeds, it sends No. of start sector over UART dim size as longword ... size = Mmc_Fat_Get_Swap_File(1000, "mikroE.txt", 0x20) if (size <> 0) then UART1_Write(0xAA) UART1_Write(Lo(size)) UART1_Write(Hi(size)) UART1_Write(Higher(size)) UART1_Write(Highest(size)) UART1_Write(0xAA) end if | |||||||||||||||||||||||||||
| Notes | Long File Names (LFN) are not supported. | 
Mmc_Fat_Tell
| Prototype | sub function Mmc_Fat_Tell() as longword | 
|---|---|
| Description | This routine is used to retrieve the cursor position within an opened file. | 
| Parameters | None. | 
| Returns | Returns the cursor position in currently assigned file. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | dim position as longword position = Mmc_Fat_Tell() | 
| Notes | None. | 
Mmc_Fat_Seek
| Prototype | sub function Mmc_Fat_Seek(dim position as longword) as longword | 
|---|---|
| Description | This routine is used to set the cursor position within an opened file and returns the cursor's new position within an opened file. | 
| Parameters | 
 | 
| Returns | Returns the cursor's new position in currently assigned file. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | dim position as longword position = Mmc_Fat_Seek(1000) | 
| Notes | If the desired cursor position exceeds file size, the cursor will be placed at the end of the file. | 
Mmc_Fat_Rename
| Prototype | sub function Mmc_Fat_Rename(dim newname as ^char) as char | 
|---|---|
| Description | This sub function renames the currently assigned file. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. The file must be previously assigned. See Mmc_Fat_Assign. | 
| Example | 
if (0 = Mmc_Fat_Rename("NEWNAME.TXT")) then 	' if rename operation was successful...
...
end if
 | 
| Notes | None. | 
Mmc_Fat_MakeDir
| Prototype | sub function Mmc_Fat_MakeDir(dim name as ^char, dim attrib as char) as char | 
|---|---|
| Description | This sub function creates a new directory. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example | 
if (0 = Mmc_Fat_MakeDir('DIR_A')) then  ' create DIR_A directory
...
end if
 | 
| Notes | None. | 
Mmc_Fat_RenameDir
| Prototype | sub function Mmc_Fat_RenameDir(dim oldname as ^char, dim newname as ^char) as char | 
|---|---|
| Description | This sub function renames a directory. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example | 
if (0 = Mmc_Fat_RenameDir("DIR_A", "DIR_B")) then ' if rename operation was successful...
...
end if
 | 
| Notes | None. | 
Mmc_Fat_RemoveDir
| Prototype | sub function Mmc_Fat_RemoveDir(dim name as ^char) as char | 
|---|---|
| Description | This function removes directory entry from current directory. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example | 
if (0 = Mmc_Fat_RemoveDir("DIR_A")) then	' if removing operation was successful...
...
end if
 | 
| Notes | Recursive removing is not supported, i.e. the directory must be empty before it can be removed. | 
Mmc_Fat_ChangeDir
| Prototype | sub function Mmc_Fat_ChangeDir(dim name as ^char) as char | 
|---|---|
| Description | This sub function changes the current directory to  | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example | 
' enter DIR_A directory
if (0 = Mmc_Fat_ChangeDir("DIR_A")) then
...
end if
' go to parent directory
if (0 = Mmc_Fat_ChangeDir("..")) then
...
end if
' go to root directory
if (0 = Mmc_Fat_ChangeDir("\")) then
...
end if
 | 
| Notes | Special directory names like " | 
Mmc_Fat_Exists
| Prototype | sub function Mmc_Fat_Exists(dim name as ^char) as char | 
|---|---|
| Description | This sub function returns information on file/directory existence. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example | 
status = Mmc_Fat_Exists("X_FILES.TXT")
' if process was successful...
if (0 = status) then
...
end if
' if an error occurred...
if (255 = status) then	
...
end if
 | 
| Notes | None. | 
Mmc_Fat_Dir
| Prototype | sub function Mmc_Fat_Dir(dim print as ^TProcedure) as byte | 
|---|---|
| Description | This routine displays contents of the current directory via user-defined medium (i.e. UART module, a file on FAT16 file system). The sub function displays character by character. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example | typedef TProcedure as sub procedure(dim ch as char) ' Displaying routine procedure PrintChar(dim ch as char) UART1_Write(ch) end sub ... Mmc_Fat_Dir(@PrintChar) | 
| Notes | None. | 
Mmc_Fat_ReadDir
| Prototype | sub function Mmc_Fat_ReadDir(dim byref d as F16_DIR) as short | 
|---|---|
| Description | This function gets next directory entry from current directory. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example | 
if (1 = Mmc_Fat_ReadDir("DIR_A")) then
...
end if
 | 
| Notes | None. | 
Mmc_Fat_Activate
| Prototype | sub function Mmc_Fat_Activate(dim fileHandle as short) as byte | 
|---|---|
| Description | This function selects active file of currently opened files. | 
| Parameters | 
 | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example |  | 
| Notes | Use Mmc_Fat_Open function to get file handles. | 
Mmc_Fat_ReadN
| Prototype | sub function Mmc_Fat_ReadN(dim fdata as ^byte, dim n as word) as word | 
|---|---|
| Description | This function reads multiple bytes. | 
| Parameters | 
 | 
| Returns | Number of read bytes. | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example |  | 
| Notes | None. | 
Mmc_Fat_Open
| Prototype | sub function Mmc_Fat_Open(dim byref name as char[12], dim mode, attrib as byte) as short | |||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Description | This function removes a directory from the current directory. | |||||||||||||||||||||||||||
| Parameters | 
 
 
 | |||||||||||||||||||||||||||
| Returns | 
 | |||||||||||||||||||||||||||
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | |||||||||||||||||||||||||||
| Example |  | |||||||||||||||||||||||||||
| Notes | None. | 
Mmc_Fat_Close
| Prototype | sub function Mmc_Fat_Close() as byte | 
|---|---|
| Description | This function closes currently opened file. | 
| Parameters | None. | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example |  | 
| Notes | None. | 
Mmc_Fat_EOF
| Prototype | sub function Mmc_Fat_EOF() as short | 
|---|---|
| Description | This function check if the end of file is reached. | 
| Parameters | None. | 
| Returns | 
 | 
| Requires | MMC/SD card and MMC library must be initialized for file operations. See Mmc_Fat_Init. | 
| Example |  | 
| Notes | None. | 
Library Example
This project consists of several blocks that demonstrate various aspects of usage of the Mmc_Fat16 library. These are :
- Creation of new file and writing down to it;
- Opening existing file and re-writing it (writing from start-of-file);
- Opening existing file and appending data to it (writing from end-of-file);
- Opening a file and reading data from it (sending it to UART terminal);
- Creating and modifying several files at once;
- Reading file contents;
- Deleting file(s);
- Creating the swap file (see Help for details);
program MMC_FAT_Test
' MMC module connections
dim MMC_chip_select as sbit at LATG9_bit ' for writing to output pin always use latch 
dim MMC_chip_select_direction as sbit at TRISG9_bit
' eof MMC module connections
const LINE_LEN = 43
dim
  FAT_TXT as string[20]
  file_contents as string[LINE_LEN]
  filename as string[14] ' File names
  character as byte
  loop_, loop2 as byte
  size as longint
  buffer as byte[512]
' UART write text and new line (carriage return + line feed)
sub procedure UART_Write_Line( dim byref uart_text as string )
  UART1_Write_Text(uart_text)
  UART1_Write(13)
  UART1_Write(10)
end sub
'-------------- Creates new file and writes some data to it
sub procedure M_Create_New_File()
  filename[7] = "A"                              ' Set filename for single-file tests
  Mmc_Fat_Set_File_Date(2011,1,12,11,9,0)       ' Set file date & time info
  Mmc_Fat_Assign(filename, 0xA0)                 ' Will not find file and then create file
  Mmc_Fat_Rewrite                                ' To clear file and start with new data
  
  for loop_ = 1 to 99                            '  We want 5 files on the MMC card
    UART1_Write(".")
    file_contents[0] = loop_ div 10 + 48
    file_contents[1] = loop_ mod 10 + 48
    Mmc_Fat_Write(file_contents, LINE_LEN-1)     ' write data to the assigned file
  next loop_
end sub
'-------------- Creates many new files and writes data to them
sub procedure M_Create_Multiple_Files()
  for loop2 = "B" to "Z"
    UART1_Write(loop2)                            ' this line can slow down the performance
    filename[7] = loop2                           ' set filename
    Mmc_Fat_Set_File_Date(2011,1,12,11,9,0)      ' Set file date & time info
    Mmc_Fat_Assign(filename, 0xA0)                ' find existing file or create a new one
    Mmc_Fat_Rewrite                               ' To clear file and start with new data
    for loop_ = 1 to 44
      file_contents[0] = byte(loop_ div 10 + 48)
      file_contents[1] = byte(loop_ mod 10 + 48)
      Mmc_Fat_Write(file_contents, 42)            ' write data to the assigned file
    next loop_
  next loop2
end sub
'-------------- Opens an existing file and rewrites it
sub procedure M_Open_File_Rewrite()
  filename[7] = "C"                               ' Set filename for single-file tests
  Mmc_Fat_Assign(filename, 0)
  Mmc_Fat_Rewrite
  for loop_ = 1 to 55
    file_contents[0] = byte(loop_ div 10 + 48)
    file_contents[1] = byte(loop_ mod 10 + 48)
    Mmc_Fat_Write(file_contents, 42)              ' write data to the assigned file
  next loop_
end sub
'-------------- Opens an existing file and appends data to it
'               (and alters the date/time stamp)
sub procedure M_Open_File_Append()
  filename[7] = "B"
  Mmc_Fat_Assign(filename, 0)
  Mmc_Fat_Set_File_Date(2009, 1, 23, 17, 22, 0)
  Mmc_Fat_Append()                                ' Prepare file for append
  file_contents = " for mikroElektronika 2009"    ' Prepare file for append
  file_contents[26] = 10                          ' LF
  Mmc_Fat_Write(file_contents, 27)                ' Write data to assigned file
end sub
'-------------- Opens an existing file, reads data from it and puts it to USART
sub procedure M_Open_File_Read()
  filename[7] = "B"
  Mmc_Fat_Assign(filename, 0)
  Mmc_Fat_Reset(size)                  ' To read file, sub procedure returns size of file
  while size > 0
    Mmc_Fat_Read(character)
    UART1_Write(character)             ' Write data to UART
    Dec(size)
  wend
end sub
'-------------- Deletes a file. If file doesn"t exist, it will first be created
'               and then deleted.
sub procedure M_Delete_File()
  filename[7] = "F"
  Mmc_Fat_Assign(filename, 0)
  Mmc_Fat_Delete
end sub
'-------------- Tests whether file exists, and if so sends its creation date
'               and file size via USART
sub procedure M_Test_File_Exist()
dim
  fsize as longint
  year as word
  month_, day, hour_, minute_ as byte
  outstr as char[12]
  filename[7] = "B"
  if Mmc_Fat_Assign(filename, 0) <> 0 then
    '--- file has been found - get its date
    Mmc_Fat_Get_File_Date(year, month_, day, hour_, minute_)
    UART1_Write_Text(" created: ")
    WordToStr(year, outstr)
    UART1_Write_Text(outstr)
    ByteToStr(month_ , outstr)
    UART1_Write_Text(outstr)
    WordToStr(day, outstr)
    UART1_Write_Text(outstr)
    WordToStr(hour_, outstr)
    UART1_Write_Text(outstr)
    WordToStr(minute_, outstr)
    UART1_Write_Text(outstr)
    '--- file has been found - get its modified date
    Mmc_Fat_Get_File_Date_Modified(year, month_, day, hour_, minute_)
    UART1_Write_Text(" modified: ")
    WordToStr(year, outstr)
    UART1_Write_Text(outstr)
    ByteToStr(month_, outstr)
    UART1_Write_Text(outstr)
    WordToStr(day, outstr)
    UART1_Write_Text(outstr)
    WordToStr(hour_, outstr)
    UART1_Write_Text(outstr)
    WordToStr(minute_, outstr)
    UART1_Write_Text(outstr)
    '--- get file size
    fsize = Mmc_Fat_Get_File_Size
    LongWordToStr(longint(fsize), outstr)
    UART_Write_Line(outstr)
  else
    '--- file was not found - signal it
    UART1_Write(0x55)
    Delay_ms(1000)
    UART1_Write(0x55)
  end if
end sub
'-------------- Tries to create a swap file, whose size will be at least 100
'               sectors (see Help for details)
sub procedure M_Create_Swap_File()
  dim  i as word
    for i=0 to 511
      Buffer[i] = i
    next i
    size = Mmc_Fat_Get_Swap_File(5000, "mikroE.txt", 0x20)   ' see help on this sub function for details
    if (size <> 0) then
      LongIntToStr(size, fat_txt)
      UART_Write_Line(fat_txt)
      for i=0 to 4999
        Mmc_Write_Sector(size, Buffer)
        size = size + 1
        UART1_Write(".")
      next i
    end if
end sub
'-------------- Main. Uncomment the function(s) to test the desired operation(s)
main:
  #DEFINE COMPLETE_EXAMPLE        ' comment this line to get smaller example
  fat_txt = "FAT16 not found"
  file_contents = "XX MMC/SD FAT16 library by Anton Rieckert#"
  file_contents[41] = 10          ' newline
  filename = "MIKRO00xTXT"
  CHECON = 0x32
  AD1PCFG = 0xFFFF                       ' initialize AN pins as digital
  ' Initialize UART1 module
  UART1_Init(56000)
  Delay_ms(10)
  UART_Write_Line("MCU-Started") ' MCU present report
  '--- set up SPI for the file read
  SPI2_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, 64, _SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE)
  Delay_ms(10)
  ' use fat16 quick format instead of init routine if a formatting is needed
  if Mmc_Fat_Init() = 0 then
    ' reinitialize spi at higher speed
    SPI2_Init_Advanced(_SPI_MASTER, _SPI_8_BIT, 8, _SPI_SS_DISABLE, _SPI_DATA_SAMPLE_MIDDLE, _SPI_CLK_IDLE_HIGH, _SPI_ACTIVE_2_IDLE)
    '--- Test start
    UART_Write_Line("Test Start.")
    '--- Test routines. Uncomment them one-by-one to test certain features
    M_Create_New_File()
    #IFDEF COMPLETE_EXAMPLE
    M_Create_New_File()
    M_Create_Multiple_Files()
    M_Open_File_Rewrite()
    M_Open_File_Append()
    M_Open_File_Read()
    M_Delete_File()
    M_Test_File_Exist()
    M_Create_Swap_File()
    #ENDIF
    UART_Write_Line("Test End.")
  else
    UART_Write_Line(fat_txt)   ' Note: Mmc_Fat_Init tries to initialize a card more than once.
                               '       If card is not present, initialization may last longer (depending on clock speed)
  end if
end.
    
    HW Connection

Pin diagram of MMC memory card
What do you think about this topic ? Send us feedback!





