Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 265447
b: refs/heads/master
c: d4df789
h: refs/heads/master
i:
  265445: 24dac9a
  265443: 9ad3a5a
  265439: cecdcdb
v: v3
  • Loading branch information
Vasanthakumar Thiagarajan authored and Kalle Valo committed Aug 9, 2011
1 parent a61d7ec commit 3a41b6a
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 24 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: c630d18a5ea0213f6ad8e34b62f9c78038f371d8
refs/heads/master: d4df78904d12850c1c57bfffde8eff5195f3cd4d
8 changes: 2 additions & 6 deletions trunk/drivers/net/wireless/ath/ath6kl/hif.h
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,8 @@ struct hif_scatter_req {
struct htc_endpoint *ep;
int scat_entries;

struct hif_scatter_req_priv *req_priv;
struct bus_request *busrequest;
struct scatterlist *sgentries;

/* bounce buffer for upper layers to copy to/from */
u8 *virt_dma_buf;
Expand All @@ -190,11 +191,6 @@ struct hif_dev_scat_sup_info {
int max_xfer_szper_scatreq;
};

struct hif_scatter_req_priv {
struct bus_request *busrequest;
struct scatterlist sgentries[MAX_SCATTER_ENTRIES_PER_REQ];
};

struct ath6kl_hif_ops {
int (*read_write_sync)(struct ath6kl *ar, u32 addr, u8 *buf,
u32 len, u32 request);
Expand Down
33 changes: 16 additions & 17 deletions trunk/drivers/net/wireless/ath/ath6kl/sdio.c
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,6 @@ static void ath6kl_sdio_free_bus_req(struct ath6kl_sdio *ar_sdio,
}

static void ath6kl_sdio_setup_scat_data(struct hif_scatter_req *scat_req,
struct hif_scatter_req_priv *s_req_priv,
struct mmc_data *data)
{
struct scatterlist *sg;
Expand All @@ -182,7 +181,7 @@ static void ath6kl_sdio_setup_scat_data(struct hif_scatter_req *scat_req,
MMC_DATA_READ;

/* fill SG entries */
sg = s_req_priv->sgentries;
sg = scat_req->sgentries;
sg_init_table(sg, scat_req->scat_entries);

/* assemble SG list */
Expand All @@ -206,7 +205,7 @@ static void ath6kl_sdio_setup_scat_data(struct hif_scatter_req *scat_req,
}

/* set scatter-gather table for request */
data->sg = s_req_priv->sgentries;
data->sg = scat_req->sgentries;
data->sg_len = scat_req->scat_entries;
}

Expand All @@ -226,7 +225,7 @@ static int ath6kl_sdio_scat_rw(struct ath6kl_sdio *ar_sdio,
memset(&cmd, 0, sizeof(struct mmc_command));
memset(&data, 0, sizeof(struct mmc_data));

ath6kl_sdio_setup_scat_data(scat_req, scat_req->req_priv, &data);
ath6kl_sdio_setup_scat_data(scat_req, &data);

opcode = (scat_req->req & HIF_FIXED_ADDRESS) ?
CMD53_ARG_FIXED_ADDRESS : CMD53_ARG_INCR_ADDRESS;
Expand Down Expand Up @@ -282,11 +281,10 @@ static void ath6kl_sdio_cleanup_scat_resource(struct ath6kl_sdio *ar_sdio)
list_del(&s_req->list);
spin_unlock_irqrestore(&ar_sdio->scat_lock, flag);

if (s_req->req_priv && s_req->req_priv->busrequest)
ath6kl_sdio_free_bus_req(ar_sdio,
s_req->req_priv->busrequest);
if (s_req->busrequest)
ath6kl_sdio_free_bus_req(ar_sdio, s_req->busrequest);
kfree(s_req->virt_dma_buf);
kfree(s_req->req_priv);
kfree(s_req->sgentries);
kfree(s_req);

spin_lock_irqsave(&ar_sdio->scat_lock, flag);
Expand All @@ -300,7 +298,7 @@ static int ath6kl_sdio_setup_scat_resource(struct ath6kl_sdio *ar_sdio,
{
struct hif_scatter_req *s_req;
struct bus_request *bus_req;
int i, scat_req_sz, scat_list_sz;
int i, scat_req_sz, scat_list_sz, sg_sz;

/* check if host supports scatter and it meets our requirements */
if (ar_sdio->func->card->host->max_segs < MAX_SCATTER_ENTRIES_PER_REQ) {
Expand All @@ -318,31 +316,33 @@ static int ath6kl_sdio_setup_scat_resource(struct ath6kl_sdio *ar_sdio,
sizeof(struct hif_scatter_item);
scat_req_sz = sizeof(*s_req) + scat_list_sz;

sg_sz = sizeof(struct scatterlist) * MAX_SCATTER_ENTRIES_PER_REQ;

for (i = 0; i < MAX_SCATTER_REQUESTS; i++) {
/* allocate the scatter request */
s_req = kzalloc(scat_req_sz, GFP_KERNEL);
if (!s_req)
goto fail_setup_scat;

/* allocate the private request blob */
s_req->req_priv = kzalloc(sizeof(*s_req->req_priv), GFP_KERNEL);
/* allocate sglist */
s_req->sgentries = kzalloc(sg_sz, GFP_KERNEL);

if (!s_req->req_priv) {
if (!s_req->sgentries) {
kfree(s_req);
goto fail_setup_scat;
}

/* allocate a bus request for this scatter request */
bus_req = ath6kl_sdio_alloc_busreq(ar_sdio);
if (!bus_req) {
kfree(s_req->req_priv);
kfree(s_req->sgentries);
kfree(s_req);
goto fail_setup_scat;
}

/* assign the scatter request to this bus request */
bus_req->scat_req = s_req;
s_req->req_priv->busrequest = bus_req;
s_req->busrequest = bus_req;
/* add it to the scatter pool */
hif_scatter_req_add(ar_sdio->ar, s_req);
}
Expand Down Expand Up @@ -627,7 +627,6 @@ static int ath6kl_sdio_async_rw_scatter(struct ath6kl *ar,
struct hif_scatter_req *scat_req)
{
struct ath6kl_sdio *ar_sdio = ath6kl_sdio_priv(ar);
struct hif_scatter_req_priv *req_priv = scat_req->req_priv;
u32 request = scat_req->req;
int status = 0;
unsigned long flags;
Expand All @@ -641,11 +640,11 @@ static int ath6kl_sdio_async_rw_scatter(struct ath6kl *ar,

if (request & HIF_SYNCHRONOUS) {
sdio_claim_host(ar_sdio->func);
status = ath6kl_sdio_scat_rw(ar_sdio, req_priv->busrequest);
status = ath6kl_sdio_scat_rw(ar_sdio, scat_req->busrequest);
sdio_release_host(ar_sdio->func);
} else {
spin_lock_irqsave(&ar_sdio->wr_async_lock, flags);
list_add_tail(&req_priv->busrequest->list, &ar_sdio->wr_asyncq);
list_add_tail(&scat_req->busrequest->list, &ar_sdio->wr_asyncq);
spin_unlock_irqrestore(&ar_sdio->wr_async_lock, flags);
queue_work(ar->ath6kl_wq, &ar_sdio->wr_async_work);
}
Expand Down

0 comments on commit 3a41b6a

Please sign in to comment.