Add missing define.
[bertos.git] / bertos / cpu / cortex-m3 / drv / hsmci_sam3.h
index 4f27843d6fea18d23174a95c86fd2fd4fb7342de..f5cebdc776a8610e8329f6fe975431aa84ed3672 100644 (file)
 #ifndef DRV_HSMCI_SAM3_H
 #define DRV_HSMCI_SAM3_H
 
-#include <io/cm3.h>
 #include <cfg/macros.h>
+#include <cfg/debug.h>
+
+#include <io/cm3.h>
 
 #define CMD8_V_RANGE_CHECK_PAT    0xAA
 #define CMD8_V_RANGE_27V_36V      (0x100 | CMD8_V_RANGE_CHECK_PAT)
                                    SD_OCR_VDD_31_32 | \
                                    SD_OCR_VDD_32_33)
 
+#define HSMCI_CHECK_BUSY() \
+       do { \
+               cpu_relax(); \
+       } while (!(HSMCI_SR & BV(HSMCI_SR_NOTBUSY)))
+
+
+
 typedef struct Hsmci
 {
 } Hsmci;
 
+INLINE void hsmci_enableIrq(void)
+{
+       HSMCI_IER = BV(HSMCI_IER_RTOE);
+}
+
+INLINE void hsmci_disableIrq(void)
+{
+       HSMCI_IDR = BV(HSMCI_IER_RTOE);
+}
+
+INLINE void hsmci_setBusWidth(size_t len)
+{
+       ASSERT((len == 8) || (len == 4) || (len == 1));
+       HSMCI_SDCR = (len << HSMCI_SDCR_SDCBUS_SHIFT) & HSMCI_SDCR_SDCBUS_MASK;
+}
+
 void hsmci_readResp(void *resp, size_t len);
 bool hsmci_sendCmd(uint8_t index, uint32_t argument, uint32_t reply_type);
 
+void hsmci_setBlkSize(size_t blk_size);
+bool hsmci_read(uint32_t *buf, size_t word_num);
+
+
+
 void hsmci_init(Hsmci *hsmci);
 
 #endif /* DRV_HSMCI_SAM3_H */