summaryrefslogtreecommitdiff
path: root/sys/dev/sdmmc
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/sdmmc')
-rw-r--r--sys/dev/sdmmc/sdmmc.c92
-rw-r--r--sys/dev/sdmmc/sdmmc_mem.c100
-rw-r--r--sys/dev/sdmmc/sdmmcvar.h7
3 files changed, 101 insertions, 98 deletions
diff --git a/sys/dev/sdmmc/sdmmc.c b/sys/dev/sdmmc/sdmmc.c
index 11f6c889ac0..0a143f8f76d 100644
--- a/sys/dev/sdmmc/sdmmc.c
+++ b/sys/dev/sdmmc/sdmmc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sdmmc.c,v 1.8 2006/11/29 00:46:52 uwe Exp $ */
+/* $OpenBSD: sdmmc.c,v 1.9 2006/11/29 14:16:43 uwe Exp $ */
/*
* Copyright (c) 2006 Uwe Stuehler <uwe@openbsd.org>
@@ -647,96 +647,6 @@ sdmmc_select_card(struct sdmmc_softc *sc, struct sdmmc_function *sf)
return error;
}
-int
-sdmmc_decode_csd(struct sdmmc_softc *sc, sdmmc_response resp,
- struct sdmmc_function *sf)
-{
- struct sdmmc_csd *csd = &sf->csd;
-
- if (ISSET(sc->sc_flags, SMF_SD_MODE)) {
- /*
- * CSD version 1.0 corresponds to SD system
- * specification version 1.0 - 1.10. (SanDisk, 3.5.3)
- */
- csd->csdver = SD_CSD_CSDVER(resp);
- if (csd->csdver != SD_CSD_CSDVER_1_0) {
- printf("%s: unknown SD CSD structure version 0x%x\n",
- DEVNAME(sc), csd->csdver);
- return 1;
- }
-
- csd->capacity = SD_CSD_CAPACITY(resp);
- csd->read_bl_len = SD_CSD_READ_BL_LEN(resp);
- } else {
- csd->csdver = MMC_CSD_CSDVER(resp);
- if (csd->csdver != MMC_CSD_CSDVER_1_0 &&
- csd->csdver != MMC_CSD_CSDVER_2_0) {
- printf("%s: unknown MMC CSD structure version 0x%x\n",
- DEVNAME(sc), csd->csdver);
- return 1;
- }
-
- csd->mmcver = MMC_CSD_MMCVER(resp);
- csd->capacity = MMC_CSD_CAPACITY(resp);
- csd->read_bl_len = MMC_CSD_READ_BL_LEN(resp);
- }
- csd->sector_size = MIN(1 << csd->read_bl_len,
- sdmmc_chip_host_maxblklen(sc->sct, sc->sch));
- if (csd->sector_size < (1<<csd->read_bl_len))
- csd->capacity *= (1<<csd->read_bl_len) /
- csd->sector_size;
-
- return 0;
-}
-
-int
-sdmmc_decode_cid(struct sdmmc_softc *sc, sdmmc_response resp,
- struct sdmmc_function *sf)
-{
- struct sdmmc_cid *cid = &sf->cid;
-
- if (ISSET(sc->sc_flags, SMF_SD_MODE)) {
- cid->mid = SD_CID_MID(resp);
- cid->oid = SD_CID_OID(resp);
- SD_CID_PNM_CPY(resp, cid->pnm);
- cid->rev = SD_CID_REV(resp);
- cid->psn = SD_CID_PSN(resp);
- cid->mdt = SD_CID_MDT(resp);
- } else {
- switch(sf->csd.mmcver) {
- case MMC_CSD_MMCVER_1_0:
- case MMC_CSD_MMCVER_1_4:
- cid->mid = MMC_CID_MID_V1(resp);
- MMC_CID_PNM_V1_CPY(resp, cid->pnm);
- cid->rev = MMC_CID_REV_V1(resp);
- cid->psn = MMC_CID_PSN_V1(resp);
- cid->mdt = MMC_CID_MDT_V1(resp);
- break;
- case MMC_CSD_MMCVER_2_0:
- case MMC_CSD_MMCVER_3_1:
- case MMC_CSD_MMCVER_4_0:
- cid->mid = MMC_CID_MID_V2(resp);
- cid->oid = MMC_CID_OID_V2(resp);
- MMC_CID_PNM_V2_CPY(resp, cid->pnm);
- cid->psn = MMC_CID_PSN_V2(resp);
- break;
- default:
- printf("%s: unknown MMC version %d\n",
- DEVNAME(sc), sf->csd.mmcver);
- return 1;
- }
- }
- return 0;
-}
-
-void
-sdmmc_print_cid(struct sdmmc_cid *cid)
-{
- printf("mid=0x%02x oid=0x%04x pnm=\"%s\" rev=0x%02x psn=0x%08x"
- " mdt=%03x\n", cid->mid, cid->oid, cid->pnm, cid->rev, cid->psn,
- cid->mdt);
-}
-
#ifdef SDMMC_IOCTL
int
sdmmc_ioctl(struct device *self, u_long request, caddr_t addr)
diff --git a/sys/dev/sdmmc/sdmmc_mem.c b/sys/dev/sdmmc/sdmmc_mem.c
index a3daba6411d..3ec17a1a5c3 100644
--- a/sys/dev/sdmmc/sdmmc_mem.c
+++ b/sys/dev/sdmmc/sdmmc_mem.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: sdmmc_mem.c,v 1.5 2006/07/18 04:10:35 uwe Exp $ */
+/* $OpenBSD: sdmmc_mem.c,v 1.6 2006/11/29 14:16:43 uwe Exp $ */
/*
* Copyright (c) 2006 Uwe Stuehler <uwe@openbsd.org>
@@ -27,6 +27,12 @@
#include <dev/sdmmc/sdmmcreg.h>
#include <dev/sdmmc/sdmmcvar.h>
+int sdmmc_decode_csd(struct sdmmc_softc *, sdmmc_response,
+ struct sdmmc_function *);
+int sdmmc_decode_cid(struct sdmmc_softc *, sdmmc_response,
+ struct sdmmc_function *);
+void sdmmc_print_cid(struct sdmmc_cid *);
+
int sdmmc_mem_send_op_cond(struct sdmmc_softc *, u_int32_t, u_int32_t *);
int sdmmc_mem_set_blocklen(struct sdmmc_softc *, struct sdmmc_function *);
@@ -206,6 +212,98 @@ sdmmc_mem_scan(struct sdmmc_softc *sc)
}
}
+int
+sdmmc_decode_csd(struct sdmmc_softc *sc, sdmmc_response resp,
+ struct sdmmc_function *sf)
+{
+ struct sdmmc_csd *csd = &sf->csd;
+
+ if (ISSET(sc->sc_flags, SMF_SD_MODE)) {
+ /*
+ * CSD version 1.0 corresponds to SD system
+ * specification version 1.0 - 1.10. (SanDisk, 3.5.3)
+ */
+ csd->csdver = SD_CSD_CSDVER(resp);
+ if (csd->csdver != SD_CSD_CSDVER_1_0) {
+ printf("%s: unknown SD CSD structure version 0x%x\n",
+ SDMMCDEVNAME(sc), csd->csdver);
+ return 1;
+ }
+
+ csd->capacity = SD_CSD_CAPACITY(resp);
+ csd->read_bl_len = SD_CSD_READ_BL_LEN(resp);
+ } else {
+ csd->csdver = MMC_CSD_CSDVER(resp);
+ if (csd->csdver != MMC_CSD_CSDVER_1_0 &&
+ csd->csdver != MMC_CSD_CSDVER_2_0) {
+ printf("%s: unknown MMC CSD structure version 0x%x\n",
+ SDMMCDEVNAME(sc), csd->csdver);
+ return 1;
+ }
+
+ csd->mmcver = MMC_CSD_MMCVER(resp);
+ csd->capacity = MMC_CSD_CAPACITY(resp);
+ csd->read_bl_len = MMC_CSD_READ_BL_LEN(resp);
+ }
+ csd->sector_size = MIN(1 << csd->read_bl_len,
+ sdmmc_chip_host_maxblklen(sc->sct, sc->sch));
+ if (csd->sector_size < (1<<csd->read_bl_len))
+ csd->capacity *= (1<<csd->read_bl_len) /
+ csd->sector_size;
+
+ return 0;
+}
+
+int
+sdmmc_decode_cid(struct sdmmc_softc *sc, sdmmc_response resp,
+ struct sdmmc_function *sf)
+{
+ struct sdmmc_cid *cid = &sf->cid;
+
+ if (ISSET(sc->sc_flags, SMF_SD_MODE)) {
+ cid->mid = SD_CID_MID(resp);
+ cid->oid = SD_CID_OID(resp);
+ SD_CID_PNM_CPY(resp, cid->pnm);
+ cid->rev = SD_CID_REV(resp);
+ cid->psn = SD_CID_PSN(resp);
+ cid->mdt = SD_CID_MDT(resp);
+ } else {
+ switch(sf->csd.mmcver) {
+ case MMC_CSD_MMCVER_1_0:
+ case MMC_CSD_MMCVER_1_4:
+ cid->mid = MMC_CID_MID_V1(resp);
+ MMC_CID_PNM_V1_CPY(resp, cid->pnm);
+ cid->rev = MMC_CID_REV_V1(resp);
+ cid->psn = MMC_CID_PSN_V1(resp);
+ cid->mdt = MMC_CID_MDT_V1(resp);
+ break;
+ case MMC_CSD_MMCVER_2_0:
+ case MMC_CSD_MMCVER_3_1:
+ case MMC_CSD_MMCVER_4_0:
+ cid->mid = MMC_CID_MID_V2(resp);
+ cid->oid = MMC_CID_OID_V2(resp);
+ MMC_CID_PNM_V2_CPY(resp, cid->pnm);
+ cid->psn = MMC_CID_PSN_V2(resp);
+ break;
+ default:
+ printf("%s: unknown MMC version %d\n",
+ SDMMCDEVNAME(sc), sf->csd.mmcver);
+ return 1;
+ }
+ }
+ return 0;
+}
+
+#ifdef SDMMC_DEBUG
+void
+sdmmc_print_cid(struct sdmmc_cid *cid)
+{
+ printf("mid=0x%02x oid=0x%04x pnm=\"%s\" rev=0x%02x psn=0x%08x"
+ " mdt=%03x\n", cid->mid, cid->oid, cid->pnm, cid->rev, cid->psn,
+ cid->mdt);
+}
+#endif
+
/*
* Initialize a SD/MMC memory card.
*/
diff --git a/sys/dev/sdmmc/sdmmcvar.h b/sys/dev/sdmmc/sdmmcvar.h
index bca300a15b2..2c2bdd27e14 100644
--- a/sys/dev/sdmmc/sdmmcvar.h
+++ b/sys/dev/sdmmc/sdmmcvar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: sdmmcvar.h,v 1.4 2006/11/29 00:46:52 uwe Exp $ */
+/* $OpenBSD: sdmmcvar.h,v 1.5 2006/11/29 14:16:43 uwe Exp $ */
/*
* Copyright (c) 2006 Uwe Stuehler <uwe@openbsd.org>
@@ -191,11 +191,6 @@ void sdmmc_go_idle_state(struct sdmmc_softc *);
int sdmmc_select_card(struct sdmmc_softc *, struct sdmmc_function *);
int sdmmc_set_relative_addr(struct sdmmc_softc *,
struct sdmmc_function *);
-int sdmmc_decode_csd(struct sdmmc_softc *, sdmmc_response,
- struct sdmmc_function *);
-int sdmmc_decode_cid(struct sdmmc_softc *, sdmmc_response,
- struct sdmmc_function *);
-void sdmmc_print_cid(struct sdmmc_cid *);
int sdmmc_io_enable(struct sdmmc_softc *);
void sdmmc_io_scan(struct sdmmc_softc *);