1
0
mirror of https://github.com/marqs85/ossc.git synced 2024-06-29 22:29:35 +00:00
ossc/software/sys_controller/ulibSD/sd_io.h
2016-10-21 01:19:53 +03:00

190 lines
6.5 KiB
C

/*
* File: sd_io.h
* Author: Nelson Lombardo
* Year: 2015
* e-mail: nelson.lombardo@gmail.com
* License at the end of file.
*/
#ifndef _SD_IO_H_
#define _SD_IO_H_
/*****************************************************************************/
/* Configurations */
/*****************************************************************************/
//#define _M_IX86 // For use with x86 architecture
#define SD_IO_WRITE
//#define SD_IO_WRITE_WAIT_BLOCKER
#define SD_IO_WRITE_TIMEOUT_WAIT 250
//#define SD_IO_DBG_COUNT
/*****************************************************************************/
#if defined(_M_IX86)
#include <stdio.h>
#include "integer.h"
/* Results of SD functions */
typedef enum {
SD_OK = 0, /* 0: Function succeeded */
SD_NOINIT /* 1: SD not initialized */
SD_ERROR, /* 2: Disk error */
SD_PARERR, /* 3: Invalid parameter */
SD_BUSY, /* 4: Programming busy */
SD_REJECT /* 5: Reject data */
} SDRESULTS;
#ifdef SD_IO_DBG_COUNT
typedef struct _DBG_COUNT {
WORD read;
WORD write;
} DBG_COUNT;
#endif
/* SD device object */
typedef struct _SD_DEV {
BOOL mount;
BYTE cardtype;
char fn[20]; /* dd if=/dev/zero of=sim_sd.raw bs=1k count=0 seek=8192 */
FILE *fp;
DWORD last_sector;
#ifdef SD_IO_DBG_COUNT
DBG_COUNT debug;
#endif
} SD_DEV;
#else // For use with uControllers
#include "sysconfig.h"
#include "stddef.h"
#include "spi_io.h" /* Provide the low-level functions */
/* Definitions of SD commands */
#define CMD0 (0x40+0) /* GO_IDLE_STATE */
#define CMD1 (0x40+1) /* SEND_OP_COND (MMC) */
#define ACMD41 (0xC0+41) /* SEND_OP_COND (SDC) */
#define CMD8 (0x40+8) /* SEND_IF_COND */
#define CMD9 (0x40+9) /* SEND_CSD */
#define CMD16 (0x40+16) /* SET_BLOCKLEN */
#define CMD17 (0x40+17) /* READ_SINGLE_BLOCK */
#define CMD24 (0x40+24) /* WRITE_SINGLE_BLOCK */
#define CMD42 (0x40+42) /* LOCK_UNLOCK */
#define CMD55 (0x40+55) /* APP_CMD */
#define CMD58 (0x40+58) /* READ_OCR */
#define CMD59 (0x40+59) /* CRC_ON_OFF */
#define SD_INIT_TRYS 0x03
/* CardType) */
#define SDCT_MMC 0x01 /* MMC version 3 */
#define SDCT_SD1 0x02 /* SD version 1 */
#define SDCT_SD2 0x04 /* SD version 2 */
#define SDCT_SDC (SDCT_SD1|SDCT_SD2) /* SD */
#define SDCT_BLOCK 0x08 /* Block addressing */
#define SD_BLK_SIZE 512
/* Results of SD functions */
typedef enum {
SD_OK = 0, /* 0: Function succeeded */
SD_NOINIT, /* 1: SD not initialized */
SD_ERROR, /* 2: Disk error */
SD_PARERR, /* 3: Invalid parameter */
SD_BUSY, /* 4: Programming busy */
SD_REJECT, /* 5: Reject data */
SD_NORESPONSE /* 6: No response */
} SDRESULTS;
#ifdef SD_IO_DBG_COUNT
typedef struct _DBG_COUNT {
WORD read;
WORD write;
} DBG_COUNT;
#endif
/* SD device object */
typedef struct _SD_DEV {
BOOL mount;
BYTE cardtype;
DWORD last_sector;
#ifdef SD_IO_DBG_COUNT
DBG_COUNT debug;
#endif
} SD_DEV;
#endif
/*******************************************************************************
* Public Methods - Direct work with SD card *
******************************************************************************/
/**
\brief Initialization the SD card.
\return If all goes well returns SD_OK.
*/
SDRESULTS SD_Init (SD_DEV *dev);
/**
\brief Read a single block.
\param dest Pointer to the destination object to put data
\param sector Start sector number (internally is converted to byte address).
\param ofs Byte offset in the sector (0..511).
\param cnt Byte count (1..512).
\return If all goes well returns SD_OK.
*/
SDRESULTS SD_Read (SD_DEV *dev, void *dat, DWORD sector, WORD ofs, WORD cnt);
/**
\brief Write a single block.
\param dat Data to write.
\param sector Sector number to write (internally is converted to byte address).
\return If all goes well returns SD_OK.
*/
SDRESULTS SD_Write (SD_DEV *dev, void *dat, DWORD sector);
/**
\brief Allows know status of SD card.
\return If all goes well returns SD_OK.
*/
SDRESULTS SD_Status (SD_DEV *dev);
#endif
// «sd_io.h» is part of:
/*----------------------------------------------------------------------------/
/ ulibSD - Library for SD cards semantics (C)Nelson Lombardo, 2015
/-----------------------------------------------------------------------------/
/ ulibSD library is a free software that opened under license policy of
/ following conditions.
/
/ Copyright (C) 2015, ChaN, all right reserved.
/
/ 1. Redistributions of source code must retain the above copyright notice,
/ this condition and the following disclaimer.
/
/ This software is provided by the copyright holder and contributors "AS IS"
/ and any warranties related to this software are DISCLAIMED.
/ The copyright owner or contributors be NOT LIABLE for any damages caused
/ by use of this software.
/----------------------------------------------------------------------------*/
// Derived from Mister Chan works on FatFs code (http://elm-chan.org/fsw/ff/00index_e.html):
/*----------------------------------------------------------------------------/
/ FatFs - FAT file system module R0.11 (C)ChaN, 2015
/-----------------------------------------------------------------------------/
/ FatFs module is a free software that opened under license policy of
/ following conditions.
/
/ Copyright (C) 2015, ChaN, all right reserved.
/
/ 1. Redistributions of source code must retain the above copyright notice,
/ this condition and the following disclaimer.
/
/ This software is provided by the copyright holder and contributors "AS IS"
/ and any warranties related to this software are DISCLAIMED.
/ The copyright owner or contributors be NOT LIABLE for any damages caused
/ by use of this software.
/----------------------------------------------------------------------------*/