source: soft/giet_vm/giet_drivers/sdc_driver.h @ 294

Last change on this file since 294 was 289, checked in by cfuguet, 11 years ago

Modifications on GIET-VM IOC driver:

  • Introducing new layer on the IOC driver. Every call to ioc_read, ioc_write, ioc_get_block_size or ioc_init

functions will call the specific driver of the used IOC
controller. Supported IOC controllers are (for now) :

  1. BDV (Soclib Block Device)
  2. HBA
  3. SPI (SDCARD - SPI controller)
  • All functions of IOC controllers drivers respect the same interface.
  • To specify the used IOC controller of the platform, a subtype field has been introduced on the map.xml file. This subtype field must be declared on the IOC periph instantiation. Available subtypes (for now) : BDV, HBA or SPI.
File size: 4.1 KB
Line 
1///////////////////////////////////////////////////////////////////////////////////
2// File     : sdc_driver.h
3// Date     : 31/08/2012
4// Author   : cesar fuguet
5// Copyright (c) UPMC-LIP6
6///////////////////////////////////////////////////////////////////////////////////
7#ifndef _GIET_SDC_DRIVER_H_
8#define _GIET_SDC_DRIVER_H_
9
10#include <ioc_driver.h>
11#include <spi_driver.h>
12#include <mapping_info.h>
13
14///////////////////////////////////////////////////////////////////////////////
15// SD card structure definition
16///////////////////////////////////////////////////////////////////////////////
17struct sdcard_dev
18{ 
19    // SPI controller pointer
20    struct spi_dev * spi;
21
22    // block length of the SDCARD
23    unsigned int block_length;
24
25    // access pointer representing the offset in bytes used to read or write in
26    // the SDCARD. This driver is for cards SDSD, therefore this offset must be
27    // multiple of the block length
28    unsigned int access_pointer;
29
30    // slave ID. This ID represents the number of the slave select signal used
31    // in the hardware platform (SPI channel)
32    int slave_id;
33
34    // is the card high capacity ?
35    int sdhc;
36};
37
38unsigned int _sdc_init( unsigned int channel );
39
40
41unsigned int _sdc_read( unsigned int mode,
42                        unsigned int lba,
43                        paddr_t      buffer,
44                        unsigned int count);
45
46
47unsigned int _sdc_write( unsigned int mode,
48                         unsigned int lba,
49                         paddr_t      buffer,
50                         unsigned int count);
51
52unsigned int _sdc_get_block_size();
53
54unsigned int _sdc_get_status( unsigned int channel ,
55                              unsigned int* status );
56
57
58///////////////////////////////////////////////////////////////////////////////
59// SD card constants
60///////////////////////////////////////////////////////////////////////////////
61
62// Number of retries after an unacknowledge command
63#define SDCARD_COMMAND_TIMEOUT  100
64
65// This command is a simple SD commmand
66#define SDCARD_CMD              0
67
68// This is an application specific command
69#define SDCARD_ACMD             1
70
71// The transmition is done in the negative edge of the clock
72#define SDCARD_TX_NEGEDGE       0
73
74// The transmition is done in the positive edge of the clock
75#define SDCARD_TX_POSEDGE       1
76
77// The reception is done in the negative edge of the clock
78#define SDCARD_RX_NEGEDGE       0
79
80// The reception is done in the positive edge of the clock
81#define SDCARD_RX_POSEDGE       1
82
83///////////////////////////////////////////////////////////////////////////////
84// SD card macros
85///////////////////////////////////////////////////////////////////////////////
86
87///////////////////////////////////////////////////////////////////////////////
88//   SDCARD_CHECK_R1_VALID()
89// This macro checks if the SD card response is valid
90// - x: SD card response
91// Returns 1 if valid and 0 otherwise
92///////////////////////////////////////////////////////////////////////////////
93#define SDCARD_CHECK_R1_VALID(x)    (~x & SDCARD_R1_RSP_VALID) ? 1 : 0
94
95///////////////////////////////////////////////////////////////////////////////
96//   SDCARD_CHECK_R1_ERROR()
97// This macro checks if there is an error in SD card response
98// - x: SD card response
99// Returns 1 if error and 0 otherwise
100///////////////////////////////////////////////////////////////////////////////
101#define SDCARD_CHECK_R1_ERROR(x)    ( x & 0x7E)                ? 1 : 0
102
103// SD card response 1 (R1) format constants
104#define SDCARD_R1_IN_IDLE_STATE     ( 1 << 0 ) // R1 bit 0
105#define SDCARD_R1_ERASE_RESET       ( 1 << 1 ) // R1 bit 1
106#define SDCARD_R1_ILLEGAL_CMD       ( 1 << 2 ) // R1 bit 2
107#define SDCARD_R1_COM_CRC_ERR       ( 1 << 3 ) // R1 bit 3
108#define SDCARD_R1_ERASE_SEQ_ERR     ( 1 << 4 ) // R1 bit 4
109#define SDCARD_R1_ADDRESS_ERR       ( 1 << 5 ) // R1 bit 5
110#define SDCARD_R1_PARAMETER_ERR     ( 1 << 6 ) // R1 bit 6
111#define SDCARD_R1_RSP_VALID         ( 1 << 7 ) // R1 bit 7
112
113#endif
114
115// Local Variables:
116// tab-width: 4
117// c-basic-offset: 4
118// c-file-offsets:((innamespace . 0)(inline-open . 0))
119// indent-tabs-mode: nil
120// End:
121// vim: filetype=c:expandtab:shiftwidth=4:tabstop=4:softtabstop=4
Note: See TracBrowser for help on using the repository browser.