Commit 5ed34f50 authored by William Lee Irwin III's avatar William Lee Irwin III Committed by Linus Torvalds

[IRDA]: Remove usage of isa_virt_to_bus()

Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarDavid S. Miller <davem@redhat.com>
parent eac49263
...@@ -33,6 +33,7 @@ ...@@ -33,6 +33,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/rtnetlink.h> #include <linux/rtnetlink.h>
#include <linux/serial_reg.h> #include <linux/serial_reg.h>
#include <linux/dma-mapping.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/dma.h> #include <asm/dma.h>
...@@ -304,16 +305,18 @@ static int ali_ircc_open(int i, chipio_t *info) ...@@ -304,16 +305,18 @@ static int ali_ircc_open(int i, chipio_t *info)
self->tx_buff.truesize = 14384; self->tx_buff.truesize = 14384;
/* Allocate memory if needed */ /* Allocate memory if needed */
self->rx_buff.head = (__u8 *) kmalloc(self->rx_buff.truesize, self->rx_buff.head =
GFP_KERNEL |GFP_DMA); dma_alloc_coherent(NULL, self->rx_buff.truesize,
&self->rx_buff_dma, GFP_KERNEL);
if (self->rx_buff.head == NULL) { if (self->rx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto err_out2; goto err_out2;
} }
memset(self->rx_buff.head, 0, self->rx_buff.truesize); memset(self->rx_buff.head, 0, self->rx_buff.truesize);
self->tx_buff.head = (__u8 *) kmalloc(self->tx_buff.truesize, self->tx_buff.head =
GFP_KERNEL|GFP_DMA); dma_alloc_coherent(NULL, self->tx_buff.truesize,
&self->tx_buff_dma, GFP_KERNEL);
if (self->tx_buff.head == NULL) { if (self->tx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto err_out3; goto err_out3;
...@@ -362,9 +365,11 @@ static int ali_ircc_open(int i, chipio_t *info) ...@@ -362,9 +365,11 @@ static int ali_ircc_open(int i, chipio_t *info)
return 0; return 0;
err_out4: err_out4:
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
err_out3: err_out3:
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
err_out2: err_out2:
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
err_out1: err_out1:
...@@ -398,10 +403,12 @@ static int __exit ali_ircc_close(struct ali_ircc_cb *self) ...@@ -398,10 +403,12 @@ static int __exit ali_ircc_close(struct ali_ircc_cb *self)
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
if (self->tx_buff.head) if (self->tx_buff.head)
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
if (self->rx_buff.head) if (self->rx_buff.head)
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
dev_self[self->index] = NULL; dev_self[self->index] = NULL;
free_netdev(self->netdev); free_netdev(self->netdev);
...@@ -1572,7 +1579,8 @@ static void ali_ircc_dma_xmit(struct ali_ircc_cb *self) ...@@ -1572,7 +1579,8 @@ static void ali_ircc_dma_xmit(struct ali_ircc_cb *self)
self->io.direction = IO_XMIT; self->io.direction = IO_XMIT;
irda_setup_dma(self->io.dma, irda_setup_dma(self->io.dma,
self->tx_fifo.queue[self->tx_fifo.ptr].start, ((u8 *)self->tx_fifo.queue[self->tx_fifo.ptr].start -
self->tx_buff.head) + self->tx_buff_dma,
self->tx_fifo.queue[self->tx_fifo.ptr].len, self->tx_fifo.queue[self->tx_fifo.ptr].len,
DMA_TX_MODE); DMA_TX_MODE);
...@@ -1724,8 +1732,8 @@ static int ali_ircc_dma_receive(struct ali_ircc_cb *self) ...@@ -1724,8 +1732,8 @@ static int ali_ircc_dma_receive(struct ali_ircc_cb *self)
self->st_fifo.len = self->st_fifo.pending_bytes = 0; self->st_fifo.len = self->st_fifo.pending_bytes = 0;
self->st_fifo.tail = self->st_fifo.head = 0; self->st_fifo.tail = self->st_fifo.head = 0;
irda_setup_dma(self->io.dma, self->rx_buff.data, irda_setup_dma(self->io.dma, self->rx_buff_dma, self->rx_buff.truesize,
self->rx_buff.truesize, DMA_RX_MODE); DMA_RX_MODE);
/* Set Receive Mode,Brick Wall */ /* Set Receive Mode,Brick Wall */
//switch_bank(iobase, BANK0); //switch_bank(iobase, BANK0);
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/pm.h> #include <linux/pm.h>
#include <linux/types.h>
#include <asm/io.h> #include <asm/io.h>
/* SIR Register */ /* SIR Register */
...@@ -198,6 +199,8 @@ struct ali_ircc_cb { ...@@ -198,6 +199,8 @@ struct ali_ircc_cb {
chipio_t io; /* IrDA controller information */ chipio_t io; /* IrDA controller information */
iobuff_t tx_buff; /* Transmit buffer */ iobuff_t tx_buff; /* Transmit buffer */
iobuff_t rx_buff; /* Receive buffer */ iobuff_t rx_buff; /* Receive buffer */
dma_addr_t tx_buff_dma;
dma_addr_t rx_buff_dma;
__u8 ier; /* Interrupt enable register */ __u8 ier; /* Interrupt enable register */
......
...@@ -52,6 +52,7 @@ ...@@ -52,6 +52,7 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/rtnetlink.h> #include <linux/rtnetlink.h>
#include <linux/dma-mapping.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/dma.h> #include <asm/dma.h>
...@@ -307,8 +308,9 @@ static int __init nsc_ircc_open(int i, chipio_t *info) ...@@ -307,8 +308,9 @@ static int __init nsc_ircc_open(int i, chipio_t *info)
self->tx_buff.truesize = 14384; self->tx_buff.truesize = 14384;
/* Allocate memory if needed */ /* Allocate memory if needed */
self->rx_buff.head = (__u8 *) kmalloc(self->rx_buff.truesize, self->rx_buff.head =
GFP_KERNEL|GFP_DMA); dma_alloc_coherent(NULL, self->rx_buff.truesize,
&self->rx_buff_dma, GFP_KERNEL);
if (self->rx_buff.head == NULL) { if (self->rx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto out2; goto out2;
...@@ -316,8 +318,9 @@ static int __init nsc_ircc_open(int i, chipio_t *info) ...@@ -316,8 +318,9 @@ static int __init nsc_ircc_open(int i, chipio_t *info)
} }
memset(self->rx_buff.head, 0, self->rx_buff.truesize); memset(self->rx_buff.head, 0, self->rx_buff.truesize);
self->tx_buff.head = (__u8 *) kmalloc(self->tx_buff.truesize, self->tx_buff.head =
GFP_KERNEL|GFP_DMA); dma_alloc_coherent(NULL, self->tx_buff.truesize,
&self->tx_buff_dma, GFP_KERNEL);
if (self->tx_buff.head == NULL) { if (self->tx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto out3; goto out3;
...@@ -368,9 +371,11 @@ static int __init nsc_ircc_open(int i, chipio_t *info) ...@@ -368,9 +371,11 @@ static int __init nsc_ircc_open(int i, chipio_t *info)
return 0; return 0;
out4: out4:
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
out3: out3:
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
out2: out2:
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
out1: out1:
...@@ -404,10 +409,12 @@ static int __exit nsc_ircc_close(struct nsc_ircc_cb *self) ...@@ -404,10 +409,12 @@ static int __exit nsc_ircc_close(struct nsc_ircc_cb *self)
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
if (self->tx_buff.head) if (self->tx_buff.head)
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
if (self->rx_buff.head) if (self->rx_buff.head)
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
dev_self[self->index] = NULL; dev_self[self->index] = NULL;
free_netdev(self->netdev); free_netdev(self->netdev);
...@@ -1409,7 +1416,8 @@ static void nsc_ircc_dma_xmit(struct nsc_ircc_cb *self, int iobase) ...@@ -1409,7 +1416,8 @@ static void nsc_ircc_dma_xmit(struct nsc_ircc_cb *self, int iobase)
outb(ECR1_DMASWP|ECR1_DMANF|ECR1_EXT_SL, iobase+ECR1); outb(ECR1_DMASWP|ECR1_DMANF|ECR1_EXT_SL, iobase+ECR1);
irda_setup_dma(self->io.dma, irda_setup_dma(self->io.dma,
self->tx_fifo.queue[self->tx_fifo.ptr].start, ((u8 *)self->tx_fifo.queue[self->tx_fifo.ptr].start -
self->tx_buff.head) + self->tx_buff_dma,
self->tx_fifo.queue[self->tx_fifo.ptr].len, self->tx_fifo.queue[self->tx_fifo.ptr].len,
DMA_TX_MODE); DMA_TX_MODE);
...@@ -1566,8 +1574,8 @@ static int nsc_ircc_dma_receive(struct nsc_ircc_cb *self) ...@@ -1566,8 +1574,8 @@ static int nsc_ircc_dma_receive(struct nsc_ircc_cb *self)
self->st_fifo.len = self->st_fifo.pending_bytes = 0; self->st_fifo.len = self->st_fifo.pending_bytes = 0;
self->st_fifo.tail = self->st_fifo.head = 0; self->st_fifo.tail = self->st_fifo.head = 0;
irda_setup_dma(self->io.dma, self->rx_buff.data, irda_setup_dma(self->io.dma, self->rx_buff_dma, self->rx_buff.truesize,
self->rx_buff.truesize, DMA_RX_MODE); DMA_RX_MODE);
/* Enable DMA */ /* Enable DMA */
switch_bank(iobase, BANK0); switch_bank(iobase, BANK0);
......
...@@ -32,6 +32,7 @@ ...@@ -32,6 +32,7 @@
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/pm.h> #include <linux/pm.h>
#include <linux/types.h>
#include <asm/io.h> #include <asm/io.h>
/* DMA modes needed */ /* DMA modes needed */
...@@ -255,6 +256,8 @@ struct nsc_ircc_cb { ...@@ -255,6 +256,8 @@ struct nsc_ircc_cb {
chipio_t io; /* IrDA controller information */ chipio_t io; /* IrDA controller information */
iobuff_t tx_buff; /* Transmit buffer */ iobuff_t tx_buff; /* Transmit buffer */
iobuff_t rx_buff; /* Receive buffer */ iobuff_t rx_buff; /* Receive buffer */
dma_addr_t tx_buff_dma;
dma_addr_t rx_buff_dma;
__u8 ier; /* Interrupt enable register */ __u8 ier; /* Interrupt enable register */
......
...@@ -52,6 +52,7 @@ ...@@ -52,6 +52,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/rtnetlink.h> #include <linux/rtnetlink.h>
#include <linux/serial_reg.h> #include <linux/serial_reg.h>
#include <linux/dma-mapping.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/dma.h> #include <asm/dma.h>
...@@ -112,6 +113,8 @@ struct smsc_ircc_cb { ...@@ -112,6 +113,8 @@ struct smsc_ircc_cb {
chipio_t io; /* IrDA controller information */ chipio_t io; /* IrDA controller information */
iobuff_t tx_buff; /* Transmit buffer */ iobuff_t tx_buff; /* Transmit buffer */
iobuff_t rx_buff; /* Receive buffer */ iobuff_t rx_buff; /* Receive buffer */
dma_addr_t tx_buff_dma;
dma_addr_t rx_buff_dma;
struct qos_info qos; /* QoS capabilities for this device */ struct qos_info qos; /* QoS capabilities for this device */
...@@ -413,16 +416,18 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u ...@@ -413,16 +416,18 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
self->rx_buff.truesize = SMSC_IRCC2_RX_BUFF_TRUESIZE; self->rx_buff.truesize = SMSC_IRCC2_RX_BUFF_TRUESIZE;
self->tx_buff.truesize = SMSC_IRCC2_TX_BUFF_TRUESIZE; self->tx_buff.truesize = SMSC_IRCC2_TX_BUFF_TRUESIZE;
self->rx_buff.head = (u8 *) kmalloc(self->rx_buff.truesize, self->rx_buff.head =
GFP_KERNEL|GFP_DMA); dma_alloc_coherent(NULL, self->rx_buff.truesize,
&self->rx_buff_dma, GFP_KERNEL);
if (self->rx_buff.head == NULL) { if (self->rx_buff.head == NULL) {
ERROR("%s, Can't allocate memory for receive buffer!\n", ERROR("%s, Can't allocate memory for receive buffer!\n",
driver_name); driver_name);
goto err_out2; goto err_out2;
} }
self->tx_buff.head = (u8 *) kmalloc(self->tx_buff.truesize, self->tx_buff.head =
GFP_KERNEL|GFP_DMA); dma_alloc_coherent(NULL, self->tx_buff.truesize,
&self->tx_buff_dma, GFP_KERNEL);
if (self->tx_buff.head == NULL) { if (self->tx_buff.head == NULL) {
ERROR("%s, Can't allocate memory for transmit buffer!\n", ERROR("%s, Can't allocate memory for transmit buffer!\n",
driver_name); driver_name);
...@@ -464,9 +469,11 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u ...@@ -464,9 +469,11 @@ static int __init smsc_ircc_open(unsigned int fir_base, unsigned int sir_base, u
return 0; return 0;
err_out4: err_out4:
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
err_out3: err_out3:
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
err_out2: err_out2:
free_netdev(self->netdev); free_netdev(self->netdev);
dev_self[--dev_count] = NULL; dev_self[--dev_count] = NULL;
...@@ -1159,7 +1166,7 @@ static void smsc_ircc_dma_xmit(struct smsc_ircc_cb *self, int iobase, int bofs) ...@@ -1159,7 +1166,7 @@ static void smsc_ircc_dma_xmit(struct smsc_ircc_cb *self, int iobase, int bofs)
IRCC_CFGB_DMA_BURST, iobase+IRCC_SCE_CFGB); IRCC_CFGB_DMA_BURST, iobase+IRCC_SCE_CFGB);
/* Setup DMA controller (must be done after enabling chip DMA) */ /* Setup DMA controller (must be done after enabling chip DMA) */
irda_setup_dma(self->io.dma, self->tx_buff.data, self->tx_buff.len, irda_setup_dma(self->io.dma, self->tx_buff_dma, self->tx_buff.len,
DMA_TX_MODE); DMA_TX_MODE);
/* Enable interrupt */ /* Enable interrupt */
...@@ -1249,8 +1256,8 @@ static int smsc_ircc_dma_receive(struct smsc_ircc_cb *self, int iobase) ...@@ -1249,8 +1256,8 @@ static int smsc_ircc_dma_receive(struct smsc_ircc_cb *self, int iobase)
outb(2050 & 0xff, iobase+IRCC_RX_SIZE_LO); outb(2050 & 0xff, iobase+IRCC_RX_SIZE_LO);
/* Setup DMA controller */ /* Setup DMA controller */
irda_setup_dma(self->io.dma, self->rx_buff.data, irda_setup_dma(self->io.dma, self->rx_buff_dma, self->rx_buff.truesize,
self->rx_buff.truesize, DMA_RX_MODE); DMA_RX_MODE);
/* Enable burst mode chip Rx DMA */ /* Enable burst mode chip Rx DMA */
register_bank(iobase, 1); register_bank(iobase, 1);
...@@ -1717,10 +1724,12 @@ static int __exit smsc_ircc_close(struct smsc_ircc_cb *self) ...@@ -1717,10 +1724,12 @@ static int __exit smsc_ircc_close(struct smsc_ircc_cb *self)
release_region(self->io.sir_base, self->io.sir_ext); release_region(self->io.sir_base, self->io.sir_ext);
if (self->tx_buff.head) if (self->tx_buff.head)
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
if (self->rx_buff.head) if (self->rx_buff.head)
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
free_netdev(self->netdev); free_netdev(self->netdev);
......
...@@ -39,6 +39,7 @@ F02 Oct/28/02: Add SB device ID for 3147 and 3177. ...@@ -39,6 +39,7 @@ F02 Oct/28/02: Add SB device ID for 3147 and 3177.
#include <linux/init.h> #include <linux/init.h>
#include <linux/rtnetlink.h> #include <linux/rtnetlink.h>
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/dma-mapping.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/dma.h> #include <asm/dma.h>
...@@ -383,7 +384,8 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id) ...@@ -383,7 +384,8 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
/* Allocate memory if needed */ /* Allocate memory if needed */
self->rx_buff.head = self->rx_buff.head =
(__u8 *) kmalloc(self->rx_buff.truesize, GFP_KERNEL | GFP_DMA); dma_alloc_coherent(NULL, self->rx_buff.truesize,
&self->rx_buff_dma, GFP_KERNEL);
if (self->rx_buff.head == NULL) { if (self->rx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto err_out2; goto err_out2;
...@@ -391,7 +393,8 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id) ...@@ -391,7 +393,8 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
memset(self->rx_buff.head, 0, self->rx_buff.truesize); memset(self->rx_buff.head, 0, self->rx_buff.truesize);
self->tx_buff.head = self->tx_buff.head =
(__u8 *) kmalloc(self->tx_buff.truesize, GFP_KERNEL | GFP_DMA); dma_alloc_coherent(NULL, self->tx_buff.truesize,
&self->tx_buff_dma, GFP_KERNEL);
if (self->tx_buff.head == NULL) { if (self->tx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto err_out3; goto err_out3;
...@@ -432,9 +435,11 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id) ...@@ -432,9 +435,11 @@ static __devinit int via_ircc_open(int i, chipio_t * info, unsigned int id)
return 0; return 0;
err_out4: err_out4:
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
err_out3: err_out3:
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
err_out2: err_out2:
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
err_out1: err_out1:
...@@ -468,9 +473,11 @@ static int __exit via_ircc_close(struct via_ircc_cb *self) ...@@ -468,9 +473,11 @@ static int __exit via_ircc_close(struct via_ircc_cb *self)
__FUNCTION__, self->io.fir_base); __FUNCTION__, self->io.fir_base);
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
if (self->tx_buff.head) if (self->tx_buff.head)
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
if (self->rx_buff.head) if (self->rx_buff.head)
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
dev_self[self->index] = NULL; dev_self[self->index] = NULL;
free_netdev(self->netdev); free_netdev(self->netdev);
...@@ -816,7 +823,7 @@ static int via_ircc_hard_xmit_sir(struct sk_buff *skb, ...@@ -816,7 +823,7 @@ static int via_ircc_hard_xmit_sir(struct sk_buff *skb,
EnTXDMA(iobase, ON); EnTXDMA(iobase, ON);
EnRXDMA(iobase, OFF); EnRXDMA(iobase, OFF);
irda_setup_dma(self->io.dma, self->tx_buff.data, self->tx_buff.len, irda_setup_dma(self->io.dma, self->tx_buff_dma, self->tx_buff.len,
DMA_TX_MODE); DMA_TX_MODE);
SetSendByte(iobase, self->tx_buff.len); SetSendByte(iobase, self->tx_buff.len);
...@@ -897,7 +904,8 @@ static int via_ircc_dma_xmit(struct via_ircc_cb *self, u16 iobase) ...@@ -897,7 +904,8 @@ static int via_ircc_dma_xmit(struct via_ircc_cb *self, u16 iobase)
EnTXDMA(iobase, ON); EnTXDMA(iobase, ON);
EnRXDMA(iobase, OFF); EnRXDMA(iobase, OFF);
irda_setup_dma(self->io.dma, irda_setup_dma(self->io.dma,
self->tx_fifo.queue[self->tx_fifo.ptr].start, ((u8 *)self->tx_fifo.queue[self->tx_fifo.ptr].start -
self->tx_buff.head) + self->tx_buff_dma,
self->tx_fifo.queue[self->tx_fifo.ptr].len, DMA_TX_MODE); self->tx_fifo.queue[self->tx_fifo.ptr].len, DMA_TX_MODE);
#ifdef DBGMSG #ifdef DBGMSG
DBG(printk DBG(printk
...@@ -1022,7 +1030,7 @@ static int via_ircc_dma_receive(struct via_ircc_cb *self) ...@@ -1022,7 +1030,7 @@ static int via_ircc_dma_receive(struct via_ircc_cb *self)
EnAllInt(iobase, ON); EnAllInt(iobase, ON);
EnTXDMA(iobase, OFF); EnTXDMA(iobase, OFF);
EnRXDMA(iobase, ON); EnRXDMA(iobase, ON);
irda_setup_dma(self->io.dma2, self->rx_buff.data, irda_setup_dma(self->io.dma2, self->rx_buff_dma,
self->rx_buff.truesize, DMA_RX_MODE); self->rx_buff.truesize, DMA_RX_MODE);
TXStart(iobase, OFF); TXStart(iobase, OFF);
RXStart(iobase, ON); RXStart(iobase, ON);
......
...@@ -33,6 +33,7 @@ this program; if not, write to the Free Software Foundation, Inc., ...@@ -33,6 +33,7 @@ this program; if not, write to the Free Software Foundation, Inc.,
#include <linux/time.h> #include <linux/time.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/pm.h> #include <linux/pm.h>
#include <linux/types.h>
#include <asm/io.h> #include <asm/io.h>
#define MAX_TX_WINDOW 7 #define MAX_TX_WINDOW 7
...@@ -102,6 +103,8 @@ struct via_ircc_cb { ...@@ -102,6 +103,8 @@ struct via_ircc_cb {
chipio_t io; /* IrDA controller information */ chipio_t io; /* IrDA controller information */
iobuff_t tx_buff; /* Transmit buffer */ iobuff_t tx_buff; /* Transmit buffer */
iobuff_t rx_buff; /* Receive buffer */ iobuff_t rx_buff; /* Receive buffer */
dma_addr_t tx_buff_dma;
dma_addr_t rx_buff_dma;
__u8 ier; /* Interrupt enable register */ __u8 ier; /* Interrupt enable register */
......
...@@ -50,6 +50,7 @@ ...@@ -50,6 +50,7 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/init.h> #include <linux/init.h>
#include <linux/rtnetlink.h> #include <linux/rtnetlink.h>
#include <linux/dma-mapping.h>
#include <asm/io.h> #include <asm/io.h>
#include <asm/dma.h> #include <asm/dma.h>
...@@ -207,8 +208,9 @@ int w83977af_open(int i, unsigned int iobase, unsigned int irq, ...@@ -207,8 +208,9 @@ int w83977af_open(int i, unsigned int iobase, unsigned int irq,
self->tx_buff.truesize = 4000; self->tx_buff.truesize = 4000;
/* Allocate memory if needed */ /* Allocate memory if needed */
self->rx_buff.head = (__u8 *) kmalloc(self->rx_buff.truesize, self->rx_buff.head =
GFP_KERNEL|GFP_DMA); dma_alloc_coherent(NULL, self->rx_buff.truesize,
&self->rx_buff_dma, GFP_KERNEL);
if (self->rx_buff.head == NULL) { if (self->rx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto err_out1; goto err_out1;
...@@ -216,8 +218,9 @@ int w83977af_open(int i, unsigned int iobase, unsigned int irq, ...@@ -216,8 +218,9 @@ int w83977af_open(int i, unsigned int iobase, unsigned int irq,
memset(self->rx_buff.head, 0, self->rx_buff.truesize); memset(self->rx_buff.head, 0, self->rx_buff.truesize);
self->tx_buff.head = (__u8 *) kmalloc(self->tx_buff.truesize, self->tx_buff.head =
GFP_KERNEL|GFP_DMA); dma_alloc_coherent(NULL, self->tx_buff.truesize,
&self->tx_buff_dma, GFP_KERNEL);
if (self->tx_buff.head == NULL) { if (self->tx_buff.head == NULL) {
err = -ENOMEM; err = -ENOMEM;
goto err_out2; goto err_out2;
...@@ -252,9 +255,11 @@ int w83977af_open(int i, unsigned int iobase, unsigned int irq, ...@@ -252,9 +255,11 @@ int w83977af_open(int i, unsigned int iobase, unsigned int irq,
return 0; return 0;
err_out3: err_out3:
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
err_out2: err_out2:
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
err_out1: err_out1:
free_netdev(dev); free_netdev(dev);
err_out: err_out:
...@@ -297,10 +302,12 @@ static int w83977af_close(struct w83977af_ir *self) ...@@ -297,10 +302,12 @@ static int w83977af_close(struct w83977af_ir *self)
release_region(self->io.fir_base, self->io.fir_ext); release_region(self->io.fir_base, self->io.fir_ext);
if (self->tx_buff.head) if (self->tx_buff.head)
kfree(self->tx_buff.head); dma_free_coherent(NULL, self->tx_buff.truesize,
self->tx_buff.head, self->tx_buff_dma);
if (self->rx_buff.head) if (self->rx_buff.head)
kfree(self->rx_buff.head); dma_free_coherent(NULL, self->rx_buff.truesize,
self->rx_buff.head, self->rx_buff_dma);
free_netdev(self->netdev); free_netdev(self->netdev);
...@@ -606,10 +613,10 @@ static void w83977af_dma_write(struct w83977af_ir *self, int iobase) ...@@ -606,10 +613,10 @@ static void w83977af_dma_write(struct w83977af_ir *self, int iobase)
disable_dma(self->io.dma); disable_dma(self->io.dma);
clear_dma_ff(self->io.dma); clear_dma_ff(self->io.dma);
set_dma_mode(self->io.dma, DMA_MODE_READ); set_dma_mode(self->io.dma, DMA_MODE_READ);
set_dma_addr(self->io.dma, isa_virt_to_bus(self->tx_buff.data)); set_dma_addr(self->io.dma, self->tx_buff_dma);
set_dma_count(self->io.dma, self->tx_buff.len); set_dma_count(self->io.dma, self->tx_buff.len);
#else #else
irda_setup_dma(self->io.dma, self->tx_buff.data, self->tx_buff.len, irda_setup_dma(self->io.dma, self->tx_buff_dma, self->tx_buff.len,
DMA_MODE_WRITE); DMA_MODE_WRITE);
#endif #endif
self->io.direction = IO_XMIT; self->io.direction = IO_XMIT;
...@@ -763,10 +770,10 @@ int w83977af_dma_receive(struct w83977af_ir *self) ...@@ -763,10 +770,10 @@ int w83977af_dma_receive(struct w83977af_ir *self)
disable_dma(self->io.dma); disable_dma(self->io.dma);
clear_dma_ff(self->io.dma); clear_dma_ff(self->io.dma);
set_dma_mode(self->io.dma, DMA_MODE_READ); set_dma_mode(self->io.dma, DMA_MODE_READ);
set_dma_addr(self->io.dma, isa_virt_to_bus(self->rx_buff.data)); set_dma_addr(self->io.dma, self->rx_buff_dma);
set_dma_count(self->io.dma, self->rx_buff.truesize); set_dma_count(self->io.dma, self->rx_buff.truesize);
#else #else
irda_setup_dma(self->io.dma, self->rx_buff.data, self->rx_buff.truesize, irda_setup_dma(self->io.dma, self->rx_buff_dma, self->rx_buff.truesize,
DMA_MODE_READ); DMA_MODE_READ);
#endif #endif
/* /*
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#define W83977AF_IR_H #define W83977AF_IR_H
#include <asm/io.h> #include <asm/io.h>
#include <linux/types.h>
/* Flags for configuration register CRF0 */ /* Flags for configuration register CRF0 */
#define ENBNKSEL 0x01 #define ENBNKSEL 0x01
...@@ -179,6 +180,8 @@ struct w83977af_ir { ...@@ -179,6 +180,8 @@ struct w83977af_ir {
chipio_t io; /* IrDA controller information */ chipio_t io; /* IrDA controller information */
iobuff_t tx_buff; /* Transmit buffer */ iobuff_t tx_buff; /* Transmit buffer */
iobuff_t rx_buff; /* Receive buffer */ iobuff_t rx_buff; /* Receive buffer */
dma_addr_t tx_buff_dma;
dma_addr_t rx_buff_dma;
/* Note : currently locking is *very* incomplete, but this /* Note : currently locking is *very* incomplete, but this
* will get you started. Check in nsc-ircc.c for a proper * will get you started. Check in nsc-ircc.c for a proper
......
...@@ -39,11 +39,13 @@ ...@@ -39,11 +39,13 @@
#ifndef IRDA_DEVICE_H #ifndef IRDA_DEVICE_H
#define IRDA_DEVICE_H #define IRDA_DEVICE_H
#include <linux/config.h>
#include <linux/tty.h> #include <linux/tty.h>
#include <linux/netdevice.h> #include <linux/netdevice.h>
#include <linux/spinlock.h> #include <linux/spinlock.h>
#include <linux/skbuff.h> /* struct sk_buff */ #include <linux/skbuff.h> /* struct sk_buff */
#include <linux/irda.h> #include <linux/irda.h>
#include <linux/types.h>
#include <net/pkt_sched.h> #include <net/pkt_sched.h>
#include <net/irda/irda.h> #include <net/irda/irda.h>
...@@ -236,7 +238,7 @@ dongle_t *irda_device_dongle_init(struct net_device *dev, int type); ...@@ -236,7 +238,7 @@ dongle_t *irda_device_dongle_init(struct net_device *dev, int type);
int irda_device_dongle_cleanup(dongle_t *dongle); int irda_device_dongle_cleanup(dongle_t *dongle);
#ifdef CONFIG_ISA #ifdef CONFIG_ISA
void irda_setup_dma(int channel, char *buffer, int count, int mode); void irda_setup_dma(int channel, dma_addr_t buffer, int count, int mode);
#endif #endif
void irda_task_delete(struct irda_task *task); void irda_task_delete(struct irda_task *task);
......
...@@ -536,7 +536,7 @@ int irda_device_set_mode(struct net_device* dev, int mode) ...@@ -536,7 +536,7 @@ int irda_device_set_mode(struct net_device* dev, int mode)
* Setup the DMA channel. Commonly used by ISA FIR drivers * Setup the DMA channel. Commonly used by ISA FIR drivers
* *
*/ */
void irda_setup_dma(int channel, char *buffer, int count, int mode) void irda_setup_dma(int channel, dma_addr_t buffer, int count, int mode)
{ {
unsigned long flags; unsigned long flags;
...@@ -545,7 +545,7 @@ void irda_setup_dma(int channel, char *buffer, int count, int mode) ...@@ -545,7 +545,7 @@ void irda_setup_dma(int channel, char *buffer, int count, int mode)
disable_dma(channel); disable_dma(channel);
clear_dma_ff(channel); clear_dma_ff(channel);
set_dma_mode(channel, mode); set_dma_mode(channel, mode);
set_dma_addr(channel, isa_virt_to_bus(buffer)); set_dma_addr(channel, buffer);
set_dma_count(channel, count); set_dma_count(channel, count);
enable_dma(channel); enable_dma(channel);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment