Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Simplify sdhc(4) locking
details: https://anonhg.NetBSD.org/src/rev/0d9b01bdba2d
branches: trunk
changeset: 809770:0d9b01bdba2d
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Fri Jul 31 15:00:07 2015 +0000
description:
Simplify sdhc(4) locking
diffstat:
sys/arch/arm/broadcom/bcm2835_emmc.c | 19 ++---
sys/arch/arm/omap/omap3_sdhc.c | 18 ++--
sys/dev/sdmmc/sdhc.c | 116 +++++++++++++++-------------------
sys/dev/sdmmc/sdhcvar.h | 3 +-
4 files changed, 72 insertions(+), 84 deletions(-)
diffs (truncated from 660 to 300 lines):
diff -r 56e93f992170 -r 0d9b01bdba2d sys/arch/arm/broadcom/bcm2835_emmc.c
--- a/sys/arch/arm/broadcom/bcm2835_emmc.c Fri Jul 31 12:51:32 2015 +0000
+++ b/sys/arch/arm/broadcom/bcm2835_emmc.c Fri Jul 31 15:00:07 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: bcm2835_emmc.c,v 1.23 2015/07/29 14:22:49 skrll Exp $ */
+/* $NetBSD: bcm2835_emmc.c,v 1.24 2015/07/31 15:00:07 jmcneill Exp $ */
/*-
* Copyright (c) 2012 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: bcm2835_emmc.c,v 1.23 2015/07/29 14:22:49 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: bcm2835_emmc.c,v 1.24 2015/07/31 15:00:07 jmcneill Exp $");
#include "bcmdmac.h"
@@ -64,7 +64,6 @@
struct sdhc_host *sc_hosts[1];
void *sc_ih;
- kmutex_t sc_lock;
kcondvar_t sc_cv;
enum bcmemmc_dma_state sc_state;
@@ -165,7 +164,6 @@
sc->sc.sc_vendor_transfer_data_dma = bcmemmc_xfer_data_dma;
sc->sc_state = EMMC_DMA_STATE_IDLE;
- mutex_init(&sc->sc_lock, MUTEX_DEFAULT, IPL_SDMMC);
cv_init(&sc->sc_cv, "bcmemmcdma");
int rseg;
@@ -242,9 +240,12 @@
bcmemmc_xfer_data_dma(struct sdhc_softc *sdhc_sc, struct sdmmc_command *cmd)
{
struct bcmemmc_softc * const sc = device_private(sdhc_sc->sc_dev);
+ kmutex_t *plock = sdhc_host_lock(sc->sc_hosts[0]);
size_t seg;
int error;
+ KASSERT(mutex_owned(plock));
+
for (seg = 0; seg < cmd->c_dmamap->dm_nsegs; seg++) {
sc->sc_cblk[seg].cb_ti =
__SHIFTIN(11, DMAC_TI_PERMAP); /* e.MMC */
@@ -303,14 +304,13 @@
error = 0;
- mutex_enter(&sc->sc_lock);
KASSERT(sc->sc_state == EMMC_DMA_STATE_IDLE);
sc->sc_state = EMMC_DMA_STATE_BUSY;
bcm_dmac_set_conblk_addr(sc->sc_dmac,
sc->sc_dmamap->dm_segs[0].ds_addr);
bcm_dmac_transfer(sc->sc_dmac);
while (sc->sc_state == EMMC_DMA_STATE_BUSY) {
- error = cv_timedwait(&sc->sc_cv, &sc->sc_lock, hz * 10);
+ error = cv_timedwait(&sc->sc_cv, plock, hz * 10);
if (error == EWOULDBLOCK) {
device_printf(sc->sc.sc_dev, "transfer timeout!\n");
bcm_dmac_halt(sc->sc_dmac);
@@ -319,7 +319,6 @@
break;
}
}
- mutex_exit(&sc->sc_lock);
bus_dmamap_sync(sc->sc.sc_dmat, sc->sc_dmamap, 0,
sc->sc_dmamap->dm_mapsize, BUS_DMASYNC_POSTWRITE);
@@ -331,12 +330,12 @@
bcmemmc_dma_done(void *arg)
{
struct bcmemmc_softc * const sc = arg;
+ kmutex_t *plock = sdhc_host_lock(sc->sc_hosts[0]);
- mutex_enter(&sc->sc_lock);
+ mutex_enter(plock);
KASSERT(sc->sc_state == EMMC_DMA_STATE_BUSY);
sc->sc_state = EMMC_DMA_STATE_IDLE;
cv_broadcast(&sc->sc_cv);
- mutex_exit(&sc->sc_lock);
-
+ mutex_exit(plock);
}
#endif
diff -r 56e93f992170 -r 0d9b01bdba2d sys/arch/arm/omap/omap3_sdhc.c
--- a/sys/arch/arm/omap/omap3_sdhc.c Fri Jul 31 12:51:32 2015 +0000
+++ b/sys/arch/arm/omap/omap3_sdhc.c Fri Jul 31 15:00:07 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: omap3_sdhc.c,v 1.16 2015/04/14 18:45:25 bouyer Exp $ */
+/* $NetBSD: omap3_sdhc.c,v 1.17 2015/07/31 15:00:07 jmcneill Exp $ */
/*-
* Copyright (c) 2011 The NetBSD Foundation, Inc.
* All rights reserved.
@@ -29,7 +29,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: omap3_sdhc.c,v 1.16 2015/04/14 18:45:25 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: omap3_sdhc.c,v 1.17 2015/07/31 15:00:07 jmcneill Exp $");
#include "opt_omap.h"
#include "edma.h"
@@ -102,7 +102,6 @@
struct edma_channel *sc_edma_rx;
uint16_t sc_edma_param_tx[EDMA_MAX_PARAMS];
uint16_t sc_edma_param_rx[EDMA_MAX_PARAMS];
- kmutex_t sc_edma_lock;
kcondvar_t sc_edma_cv;
bus_addr_t sc_edma_fifo;
bool sc_edma_pending;
@@ -230,7 +229,6 @@
#if NEDMA > 0
if (oa->obio_edmabase != -1) {
- mutex_init(&sc->sc_edma_lock, MUTEX_DEFAULT, IPL_SCHED);
cv_init(&sc->sc_edma_cv, "sdhcedma");
sc->sc_edma_fifo = oa->obio_addr +
OMAP3_SDMMC_SDHC_OFFSET + SDHC_DATA;
@@ -468,6 +466,7 @@
obiosdhc_edma_xfer_data(struct sdhc_softc *sdhc_sc, struct sdmmc_command *cmd)
{
struct obiosdhc_softc *sc = device_private(sdhc_sc->sc_dev);
+ kmutex_t *plock = sdhc_host_lock(sc->sc_hosts[0]);
struct edma_channel *edma;
uint16_t *edma_param;
struct edma_param ep;
@@ -475,6 +474,8 @@
int error;
int blksize = MIN(cmd->c_datalen, cmd->c_blklen);
+ KASSERT(mutex_owned(plock));
+
edma = ISSET(cmd->c_flags, SCF_CMD_READ) ?
sc->sc_edma_rx : sc->sc_edma_tx;
edma_param = ISSET(cmd->c_flags, SCF_CMD_READ) ?
@@ -540,12 +541,11 @@
#endif
}
- mutex_enter(&sc->sc_edma_lock);
error = 0;
sc->sc_edma_pending = true;
edma_transfer_enable(edma, edma_param[0]);
while (sc->sc_edma_pending) {
- error = cv_timedwait(&sc->sc_edma_cv, &sc->sc_edma_lock, hz*10);
+ error = cv_timedwait(&sc->sc_edma_cv, plock, hz*10);
if (error == EWOULDBLOCK) {
device_printf(sc->sc.sc_dev, "transfer timeout!\n");
edma_dump(edma);
@@ -557,7 +557,6 @@
}
}
edma_halt(edma);
- mutex_exit(&sc->sc_edma_lock);
return error;
}
@@ -566,11 +565,12 @@
obiosdhc_edma_done(void *priv)
{
struct obiosdhc_softc *sc = priv;
+ kmutex_t *plock = sdhc_host_lock(sc->sc_hosts[0]);
- mutex_enter(&sc->sc_edma_lock);
+ mutex_enter(plock);
KASSERT(sc->sc_edma_pending == true);
sc->sc_edma_pending = false;
cv_broadcast(&sc->sc_edma_cv);
- mutex_exit(&sc->sc_edma_lock);
+ mutex_exit(plock);
}
#endif
diff -r 56e93f992170 -r 0d9b01bdba2d sys/dev/sdmmc/sdhc.c
--- a/sys/dev/sdmmc/sdhc.c Fri Jul 31 12:51:32 2015 +0000
+++ b/sys/dev/sdmmc/sdhc.c Fri Jul 31 15:00:07 2015 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sdhc.c,v 1.64 2015/07/30 15:03:14 jmcneill Exp $ */
+/* $NetBSD: sdhc.c,v 1.65 2015/07/31 15:00:08 jmcneill Exp $ */
/* $OpenBSD: sdhc.c,v 1.25 2009/01/13 19:44:20 grange Exp $ */
/*
@@ -23,7 +23,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sdhc.c,v 1.64 2015/07/30 15:03:14 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sdhc.c,v 1.65 2015/07/31 15:00:08 jmcneill Exp $");
#ifdef _KERNEL_OPT
#include "opt_sdmmc.h"
@@ -66,8 +66,6 @@
device_t sdmmc; /* generic SD/MMC device */
- struct kmutex host_mtx;
-
u_int clkbase; /* base clock frequency in KHz */
int maxblklen; /* maximum block length */
uint32_t ocr; /* OCR value from capabilities */
@@ -76,8 +74,8 @@
uint16_t intr_status; /* soft interrupt status */
uint16_t intr_error_status; /* soft error status */
- struct kmutex intr_mtx;
- struct kcondvar intr_cv;
+ kmutex_t intr_lock;
+ kcondvar_t intr_cv;
int specver; /* spec. version */
@@ -271,8 +269,7 @@
hp->ios = iosize;
hp->dmat = sc->sc_dmat;
- mutex_init(&hp->host_mtx, MUTEX_DEFAULT, IPL_SDMMC);
- mutex_init(&hp->intr_mtx, MUTEX_DEFAULT, IPL_SDMMC);
+ mutex_init(&hp->intr_lock, MUTEX_DEFAULT, IPL_SDMMC);
cv_init(&hp->intr_cv, "sdhcintr");
if (ISSET(hp->sc->sc_flags, SDHC_FLAG_ENHANCED)) {
@@ -315,9 +312,7 @@
if (ISSET(sc->sc_flags, SDHC_FLAG_HOSTCAPS)) {
caps = sc->sc_caps;
} else {
- mutex_enter(&hp->host_mtx);
caps = HREAD4(hp, SDHC_CAPABILITIES);
- mutex_exit(&hp->host_mtx);
}
/*
@@ -528,8 +523,7 @@
err:
cv_destroy(&hp->intr_cv);
- mutex_destroy(&hp->intr_mtx);
- mutex_destroy(&hp->host_mtx);
+ mutex_destroy(&hp->intr_lock);
free(hp, M_DEVBUF);
sc->sc_host[--sc->sc_nhosts] = NULL;
err1:
@@ -562,8 +556,7 @@
sdhc_soft_reset(hp, SDHC_RESET_ALL);
}
cv_destroy(&hp->intr_cv);
- mutex_destroy(&hp->intr_mtx);
- mutex_destroy(&hp->host_mtx);
+ mutex_destroy(&hp->intr_lock);
if (hp->ios > 0) {
bus_space_unmap(hp->iot, hp->ioh, hp->ios);
hp->ios = 0;
@@ -672,7 +665,7 @@
uint32_t sdhcimask;
int error;
- /* Don't lock. */
+ KASSERT(mutex_owned(&hp->intr_lock));
/* Disable all interrupts. */
if (ISSET(hp->sc->sc_flags, SDHC_FLAG_32BIT_ACCESS)) {
@@ -697,7 +690,6 @@
#endif
/* Enable interrupts. */
- mutex_enter(&hp->intr_mtx);
sdhcimask = SDHC_CARD_REMOVAL | SDHC_CARD_INSERTION |
SDHC_BUFFER_READ_READY | SDHC_BUFFER_WRITE_READY |
SDHC_DMA_INTERRUPT | SDHC_BLOCK_GAP_EVENT |
@@ -716,7 +708,6 @@
HWRITE2(hp, SDHC_NINTR_SIGNAL_EN, sdhcimask);
HWRITE2(hp, SDHC_EINTR_SIGNAL_EN, SDHC_EINTR_SIGNAL_MASK);
}
- mutex_exit(&hp->intr_mtx);
out:
return error;
@@ -728,9 +719,9 @@
struct sdhc_host *hp = (struct sdhc_host *)sch;
int error;
- mutex_enter(&hp->host_mtx);
+ mutex_enter(&hp->intr_lock);
error = sdhc_host_reset1(sch);
- mutex_exit(&hp->host_mtx);
+ mutex_exit(&hp->intr_lock);
return error;
}
@@ -763,9 +754,7 @@
if (hp->sc->sc_vendor_card_detect)
return (*hp->sc->sc_vendor_card_detect)(hp->sc);
- mutex_enter(&hp->host_mtx);
r = ISSET(HREAD4(hp, SDHC_PRESENT_STATE), SDHC_CARD_INSERTED);
- mutex_exit(&hp->host_mtx);
return r ? 1 : 0;
}
Home |
Main Index |
Thread Index |
Old Index