2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
6 * Copyright (C) 2012 MIPS Technologies, Inc. All rights reserved.
8 #include <linux/delay.h>
9 #include <linux/kernel.h>
10 #include <linux/spinlock.h>
11 #include <linux/init.h>
13 #include <linux/errno.h>
15 #define PIC32_NULL 0x00
17 #define PIC32_SYSRD 0x02
19 #define PIC32_SYSWR 0x20
20 #define PIC32_IRQ_CLR 0x40
21 #define PIC32_STATUS 0x80
23 #define DELAY() udelay(100) /* FIXME: needed? */
25 /* spinlock to ensure atomic access to PIC32 */
26 static DEFINE_SPINLOCK(pic32_bus_lock
);
28 /* FIXME: io_remap these */
29 static void __iomem
*bus_xfer
= (void __iomem
*)0xbf000600;
30 static void __iomem
*bus_status
= (void __iomem
*)0xbf000060;
32 static inline unsigned int ioready(void)
34 return readl(bus_status
) & 1;
37 static inline void wait_ioready(void)
39 do { } while (!ioready());
42 static inline void wait_ioclear(void)
44 do { } while (ioready());
47 static inline void check_ioclear(void)
50 pr_debug("ioclear: initially busy\n");
52 (void) readl(bus_xfer
);
55 pr_debug("ioclear: cleared busy\n");
59 u32
pic32_bus_readl(u32 reg
)
64 spin_lock_irqsave(&pic32_bus_lock
, flags
);
68 writel((PIC32_RD
<< 24) | (reg
& 0x00ffffff), bus_xfer
);
71 status
= readl(bus_xfer
);
73 val
= readl(bus_xfer
);
76 pr_debug("pic32_bus_readl: *%x -> %x (status=%x)\n", reg
, val
, status
);
78 spin_unlock_irqrestore(&pic32_bus_lock
, flags
);
83 void pic32_bus_writel(u32 val
, u32 reg
)
88 spin_lock_irqsave(&pic32_bus_lock
, flags
);
92 writel((PIC32_WR
<< 24) | (reg
& 0x00ffffff), bus_xfer
);
94 writel(val
, bus_xfer
);
97 status
= readl(bus_xfer
);
100 pr_debug("pic32_bus_writel: *%x <- %x (status=%x)\n", reg
, val
, status
);
102 spin_unlock_irqrestore(&pic32_bus_lock
, flags
);