878d9f0680e6d1058ffeb6905d70791979853e5d
[SCSI2SD-V6.git] / src / firmware / sd.h
1 //      Copyright (C) 2013 Michael McMaster <michael@codesrc.com>
2 //
3 //      This file is part of SCSI2SD.
4 //
5 //      SCSI2SD is free software: you can redistribute it and/or modify
6 //      it under the terms of the GNU General Public License as published by
7 //      the Free Software Foundation, either version 3 of the License, or
8 //      (at your option) any later version.
9 //
10 //      SCSI2SD is distributed in the hope that it will be useful,
11 //      but WITHOUT ANY WARRANTY; without even the implied warranty of
12 //      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 //      GNU General Public License for more details.
14 //
15 //      You should have received a copy of the GNU General Public License
16 //      along with SCSI2SD.  If not, see <http://www.gnu.org/licenses/>.
17 #ifndef S2S_SD_H
18 #define S2S_SD_H
19
20 #include <stdint.h>
21
22 #define SD_SECTOR_SIZE 512
23
24 /*
25 typedef enum
26 {
27         SD_GO_IDLE_STATE = 0,
28         SD_SEND_OP_COND = 1,
29         SD_SEND_IF_COND = 8, // SD V2
30         SD_SEND_CSD = 9,
31         SD_SEND_CID = 10,
32         SD_STOP_TRANSMISSION = 12,
33         SD_SEND_STATUS = 13,
34         SD_SET_BLOCKLEN = 16,
35         SD_READ_SINGLE_BLOCK = 17,
36         SD_READ_MULTIPLE_BLOCK = 18,
37         SD_APP_SET_WR_BLK_ERASE_COUNT = 23,
38         SD_WRITE_MULTIPLE_BLOCK = 25,
39         SD_APP_SEND_OP_COND = 41,
40         SD_APP_CMD = 55,
41         SD_READ_OCR = 58,
42         SD_CRC_ON_OFF = 59
43 } SD_CMD;
44
45 typedef enum
46 {
47         SD_R1_IDLE = 1,
48         SD_R1_ERASE_RESET = 2,
49         SD_R1_ILLEGAL = 4,
50         SD_R1_CRC = 8,
51         SD_R1_ERASE_SEQ = 0x10,
52         SD_R1_ADDRESS = 0x20,
53         SD_R1_PARAMETER = 0x40
54 } SD_R1;
55 */
56
57 typedef struct
58 {
59         int version; // SDHC = version 2.
60         int ccs; // Card Capacity Status. 1 = SDHC or SDXC
61         uint32_t capacity; // in 512 byte blocks
62
63         uint8_t csd[16]; // Unparsed CSD
64         uint8_t cid[16]; // Unparsed CID
65 } SdDevice;
66
67 extern SdDevice sdDev;
68 extern volatile uint8_t sdRxDMAComplete;
69 extern volatile uint8_t sdTxDMAComplete;
70
71 int sdInit(void);
72
73 #define sdDMABusy() (!(sdRxDMAComplete && sdTxDMAComplete))
74
75 void sdWriteMultiSectorPrep(uint32_t sdLBA, uint32_t sdSectors);
76 void sdWriteMultiSectorDMA(uint8_t* outputBuffer);
77 int sdWriteSectorDMAPoll();
78
79 void sdReadMultiSectorPrep(uint32_t sdLBA, uint32_t sdSectors);
80 void sdReadMultiSectorDMA(uint8_t* outputBuffer);
81 void sdReadSingleSectorDMA(uint32_t lba, uint8_t* outputBuffer);
82 int sdReadSectorDMAPoll();
83
84 void sdCompleteTransfer(void);
85 void sdCheckPresent();
86 void sdPoll();
87
88 #endif