blob: 8eeaa81de0668cbb898bca660d344ffd148e0f28 [file] [log] [blame]
Pierre Ossman795312e2005-09-03 15:56:54 -07001/*
Dave Jones835c34a2007-10-12 21:10:53 -04002 * 8237A DMA controller suspend functions.
Pierre Ossman795312e2005-09-03 15:56:54 -07003 *
4 * Written by Pierre Ossman, 2005.
Pierre Ossman643f7202006-09-30 23:27:52 -07005 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or (at
9 * your option) any later version.
Pierre Ossman795312e2005-09-03 15:56:54 -070010 */
11
12#include <linux/init.h>
Rafael J. Wysockif3c6ea12011-03-23 22:15:54 +010013#include <linux/syscore_ops.h>
Pierre Ossman795312e2005-09-03 15:56:54 -070014
15#include <asm/dma.h>
16
17/*
18 * This module just handles suspend/resume issues with the
19 * 8237A DMA controller (used for ISA and LPC).
20 * Allocation is handled in kernel/dma.c and normal usage is
21 * in asm/dma.h.
22 */
23
Rafael J. Wysockif3c6ea12011-03-23 22:15:54 +010024static void i8237A_resume(void)
Pierre Ossman795312e2005-09-03 15:56:54 -070025{
26 unsigned long flags;
27 int i;
28
29 flags = claim_dma_lock();
30
Clemens Ladischb52af402009-02-10 09:21:07 +010031 dma_outb(0, DMA1_RESET_REG);
32 dma_outb(0, DMA2_RESET_REG);
Pierre Ossman795312e2005-09-03 15:56:54 -070033
Clemens Ladischb52af402009-02-10 09:21:07 +010034 for (i = 0; i < 8; i++) {
Pierre Ossman795312e2005-09-03 15:56:54 -070035 set_dma_addr(i, 0x000000);
36 /* DMA count is a bit weird so this is not 0 */
37 set_dma_count(i, 1);
38 }
39
40 /* Enable cascade DMA or channel 0-3 won't work */
41 enable_dma(4);
42
43 release_dma_lock(flags);
Pierre Ossman795312e2005-09-03 15:56:54 -070044}
45
Rafael J. Wysockif3c6ea12011-03-23 22:15:54 +010046static struct syscore_ops i8237_syscore_ops = {
Clemens Ladischb52af402009-02-10 09:21:07 +010047 .resume = i8237A_resume,
Pierre Ossman795312e2005-09-03 15:56:54 -070048};
49
Rafael J. Wysockif3c6ea12011-03-23 22:15:54 +010050static int __init i8237A_init_ops(void)
Pierre Ossman795312e2005-09-03 15:56:54 -070051{
Rafael J. Wysockif3c6ea12011-03-23 22:15:54 +010052 register_syscore_ops(&i8237_syscore_ops);
53 return 0;
Pierre Ossman795312e2005-09-03 15:56:54 -070054}
Rafael J. Wysockif3c6ea12011-03-23 22:15:54 +010055device_initcall(i8237A_init_ops);