Lines Matching refs:dmanr
213 static __inline__ void enable_dma(unsigned int dmanr) in enable_dma() argument
215 if (dmanr<=3) in enable_dma()
216 dma_outb(dmanr, DMA1_MASK_REG); in enable_dma()
218 dma_outb(dmanr & 3, DMA2_MASK_REG); in enable_dma()
221 static __inline__ void disable_dma(unsigned int dmanr) in disable_dma() argument
223 if (dmanr<=3) in disable_dma()
224 dma_outb(dmanr | 4, DMA1_MASK_REG); in disable_dma()
226 dma_outb((dmanr & 3) | 4, DMA2_MASK_REG); in disable_dma()
236 static __inline__ void clear_dma_ff(unsigned int dmanr) in clear_dma_ff() argument
238 if (dmanr<=3) in clear_dma_ff()
245 static __inline__ void set_dma_mode(unsigned int dmanr, char mode) in set_dma_mode() argument
247 if (dmanr<=3) in set_dma_mode()
248 dma_outb(mode | dmanr, DMA1_MODE_REG); in set_dma_mode()
250 dma_outb(mode | (dmanr&3), DMA2_MODE_REG); in set_dma_mode()
254 static __inline__ void set_dma_ext_mode(unsigned int dmanr, char ext_mode) in set_dma_ext_mode() argument
256 if (dmanr<=3) in set_dma_ext_mode()
257 dma_outb(ext_mode | dmanr, DMA1_EXT_MODE_REG); in set_dma_ext_mode()
259 dma_outb(ext_mode | (dmanr&3), DMA2_EXT_MODE_REG); in set_dma_ext_mode()
266 static __inline__ void set_dma_page(unsigned int dmanr, unsigned int pagenr) in set_dma_page() argument
268 switch(dmanr) { in set_dma_page()
304 static __inline__ void set_dma_addr(unsigned int dmanr, unsigned int a) in set_dma_addr() argument
306 if (dmanr <= 3) { in set_dma_addr()
307 dma_outb( a & 0xff, ((dmanr&3)<<1) + IO_DMA1_BASE ); in set_dma_addr()
308 dma_outb( (a>>8) & 0xff, ((dmanr&3)<<1) + IO_DMA1_BASE ); in set_dma_addr()
310 dma_outb( (a>>1) & 0xff, ((dmanr&3)<<2) + IO_DMA2_BASE ); in set_dma_addr()
311 dma_outb( (a>>9) & 0xff, ((dmanr&3)<<2) + IO_DMA2_BASE ); in set_dma_addr()
313 set_dma_page(dmanr, a>>16); /* set hipage last to enable 32-bit mode */ in set_dma_addr()
325 static __inline__ void set_dma_count(unsigned int dmanr, unsigned int count) in set_dma_count() argument
328 if (dmanr <= 3) { in set_dma_count()
329 dma_outb( count & 0xff, ((dmanr&3)<<1) + 1 + IO_DMA1_BASE ); in set_dma_count()
330 dma_outb( (count>>8) & 0xff, ((dmanr&3)<<1) + 1 + IO_DMA1_BASE ); in set_dma_count()
332 dma_outb( (count>>1) & 0xff, ((dmanr&3)<<2) + 2 + IO_DMA2_BASE ); in set_dma_count()
333 dma_outb( (count>>9) & 0xff, ((dmanr&3)<<2) + 2 + IO_DMA2_BASE ); in set_dma_count()
346 static __inline__ int get_dma_residue(unsigned int dmanr) in get_dma_residue() argument
348 unsigned int io_port = (dmanr<=3)? ((dmanr&3)<<1) + 1 + IO_DMA1_BASE in get_dma_residue()
349 : ((dmanr&3)<<2) + 2 + IO_DMA2_BASE; in get_dma_residue()
357 return (dmanr<=3)? count : (count<<1); in get_dma_residue()
362 extern int request_dma(unsigned int dmanr, const char * device_id); /* reserve a DMA channel */
363 extern void free_dma(unsigned int dmanr); /* release it again */
365 extern int check_dma(unsigned int dmanr);