mirror of
https://github.com/fail0verflow/mini.git
synced 2024-11-16 16:39:25 +01:00
simplify sdhc code by removing voltage checking code and some other disabled code
This commit is contained in:
parent
c53d5f58c7
commit
5122d749ee
72
sdhc.c
72
sdhc.c
@ -244,14 +244,6 @@ sdhc_host_found(struct sdhc_softc *sc, bus_space_tag_t iot,
|
|||||||
* capabilities. (2.2.15)
|
* capabilities. (2.2.15)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
|
||||||
* Determine SD bus voltage levels supported by the controller.
|
|
||||||
*/
|
|
||||||
if (ISSET(caps, SDHC_VOLTAGE_SUPP_1_8V))
|
|
||||||
SET(hp->ocr, MMC_OCR_1_7V_1_8V | MMC_OCR_1_8V_1_9V);
|
|
||||||
if (ISSET(caps, SDHC_VOLTAGE_SUPP_3_0V))
|
|
||||||
SET(hp->ocr, MMC_OCR_2_9V_3_0V | MMC_OCR_3_0V_3_1V);
|
|
||||||
if (ISSET(caps, SDHC_VOLTAGE_SUPP_3_3V))
|
|
||||||
SET(hp->ocr, MMC_OCR_3_2V_3_3V | MMC_OCR_3_3V_3_4V);
|
SET(hp->ocr, MMC_OCR_3_2V_3_3V | MMC_OCR_3_3V_3_4V);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -283,58 +275,14 @@ sdhc_host_found(struct sdhc_softc *sc, bus_space_tag_t iot,
|
|||||||
saa.sch = hp;
|
saa.sch = hp;
|
||||||
|
|
||||||
hp->sdmmc = sdmmc_attach(&sdhc_functions, hp, "sdhc", ioh);
|
hp->sdmmc = sdmmc_attach(&sdhc_functions, hp, "sdhc", ioh);
|
||||||
/* hp->sdmmc = config_found(&sc->sc_dev, &saa, NULL);
|
|
||||||
if (hp->sdmmc == NULL) {
|
|
||||||
error = 0;
|
|
||||||
goto err;
|
|
||||||
}*/
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err:
|
err:
|
||||||
// free(hp, M_DEVBUF);
|
|
||||||
sc->sc_nhosts--;
|
sc->sc_nhosts--;
|
||||||
return (error);
|
return (error);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if 0
|
|
||||||
/*
|
|
||||||
* Power hook established by or called from attachment driver.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
sdhc_power(int why, void *arg)
|
|
||||||
{
|
|
||||||
struct sdhc_softc *sc = arg;
|
|
||||||
struct sdhc_host *hp;
|
|
||||||
int n, i;
|
|
||||||
|
|
||||||
switch(why) {
|
|
||||||
case PWR_STANDBY:
|
|
||||||
case PWR_SUSPEND:
|
|
||||||
/* XXX poll for command completion or suspend command
|
|
||||||
* in progress */
|
|
||||||
|
|
||||||
/* Save the host controller state. */
|
|
||||||
for (n = 0; n < sc->sc_nhosts; n++) {
|
|
||||||
hp = sc->sc_host[n];
|
|
||||||
for (i = 0; i < sizeof hp->regs; i++)
|
|
||||||
hp->regs[i] = HREAD1(hp, i);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case PWR_RESUME:
|
|
||||||
/* Restore the host controller state. */
|
|
||||||
for (n = 0; n < sc->sc_nhosts; n++) {
|
|
||||||
hp = sc->sc_host[n];
|
|
||||||
(void)sdhc_host_reset(hp);
|
|
||||||
for (i = 0; i < sizeof hp->regs; i++)
|
|
||||||
HWRITE1(hp, i, hp->regs[i]);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef LOADER
|
#ifndef LOADER
|
||||||
/*
|
/*
|
||||||
* Shutdown hook established by or called from attachment driver.
|
* Shutdown hook established by or called from attachment driver.
|
||||||
@ -429,8 +377,8 @@ int
|
|||||||
sdhc_bus_power(sdmmc_chipset_handle_t sch, u_int32_t ocr)
|
sdhc_bus_power(sdmmc_chipset_handle_t sch, u_int32_t ocr)
|
||||||
{
|
{
|
||||||
struct sdhc_host *hp = sch;
|
struct sdhc_host *hp = sch;
|
||||||
u_int8_t vdd;
|
|
||||||
|
|
||||||
|
gecko_printf("sdhc_bus_power(%u)\n", ocr);
|
||||||
/* Disable bus power before voltage change. */
|
/* Disable bus power before voltage change. */
|
||||||
HWRITE1(hp, SDHC_POWER_CTL, 0);
|
HWRITE1(hp, SDHC_POWER_CTL, 0);
|
||||||
|
|
||||||
@ -440,26 +388,11 @@ sdhc_bus_power(sdmmc_chipset_handle_t sch, u_int32_t ocr)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Select the maximum voltage according to capabilities.
|
|
||||||
*/
|
|
||||||
ocr &= hp->ocr;
|
|
||||||
if (ISSET(ocr, MMC_OCR_3_2V_3_3V|MMC_OCR_3_3V_3_4V))
|
|
||||||
vdd = SDHC_VOLTAGE_3_3V;
|
|
||||||
else if (ISSET(ocr, MMC_OCR_2_9V_3_0V|MMC_OCR_3_0V_3_1V))
|
|
||||||
vdd = SDHC_VOLTAGE_3_0V;
|
|
||||||
else if (ISSET(ocr, MMC_OCR_1_7V_1_8V|MMC_OCR_1_8V_1_9V))
|
|
||||||
vdd = SDHC_VOLTAGE_1_8V;
|
|
||||||
else {
|
|
||||||
/* Unsupported voltage level requested. */
|
|
||||||
return EINVAL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Enable bus power. Wait at least 1 ms (or 74 clocks) plus
|
* Enable bus power. Wait at least 1 ms (or 74 clocks) plus
|
||||||
* voltage ramp until power rises.
|
* voltage ramp until power rises.
|
||||||
*/
|
*/
|
||||||
HWRITE1(hp, SDHC_POWER_CTL, (vdd << SDHC_VOLTAGE_SHIFT) |
|
HWRITE1(hp, SDHC_POWER_CTL, (SDHC_VOLTAGE_3_3V << SDHC_VOLTAGE_SHIFT) |
|
||||||
SDHC_BUS_POWER);
|
SDHC_BUS_POWER);
|
||||||
sdmmc_delay(10000);
|
sdmmc_delay(10000);
|
||||||
|
|
||||||
@ -469,6 +402,7 @@ sdhc_bus_power(sdmmc_chipset_handle_t sch, u_int32_t ocr)
|
|||||||
* bus power bit.
|
* bus power bit.
|
||||||
*/
|
*/
|
||||||
if (!ISSET(HREAD1(hp, SDHC_POWER_CTL), SDHC_BUS_POWER)) {
|
if (!ISSET(HREAD1(hp, SDHC_POWER_CTL), SDHC_BUS_POWER)) {
|
||||||
|
gecko_printf("Host controller failed to enable bus power\n");
|
||||||
return ENXIO;
|
return ENXIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user