summaryrefslogtreecommitdiff
path: root/sys/arch/amiga/isa/ggbus.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/amiga/isa/ggbus.c')
-rw-r--r--sys/arch/amiga/isa/ggbus.c57
1 files changed, 48 insertions, 9 deletions
diff --git a/sys/arch/amiga/isa/ggbus.c b/sys/arch/amiga/isa/ggbus.c
index 970ba20301f..7864220395a 100644
--- a/sys/arch/amiga/isa/ggbus.c
+++ b/sys/arch/amiga/isa/ggbus.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ggbus.c,v 1.4 1996/06/04 13:40:14 niklas Exp $ */
+/* $OpenBSD: ggbus.c,v 1.5 1996/08/04 01:30:49 niklas Exp $ */
/*
* Copyright (c) 1994, 1995, 1996 Niklas Hallqvist
@@ -87,6 +87,11 @@ __inline u_int16_t ggbus_read_2 __P((bus_io_handle_t, bus_io_size_t));
__inline void ggbus_write_1 __P((bus_io_handle_t, bus_io_size_t, u_int8_t));
__inline void ggbus_write_2 __P((bus_io_handle_t, bus_io_size_t, u_int16_t));
+void ggbus_io_read_raw_multi_2 __P((bus_io_handle_t, bus_io_size_t,
+ u_int8_t *, bus_io_size_t));
+void ggbus_io_write_raw_multi_2 __P((bus_io_handle_t, bus_io_size_t,
+ const u_int8_t *, bus_io_size_t));
+
/*
* In order to share the access function implementations for I/O and memory
* access we cast the functions for the memory access case. These typedefs
@@ -130,9 +135,11 @@ struct amiga_bus_chipset ggbus1_chipset = {
0 /* bc_mem_write_1 */, 0 /* bc_mem_write_2 */,
0 /* bc_mem_write_4 */, 0 /* bc_mem_write_8 */,
- /* These are extensions to the general NetBSD bus interface. */
- swap, 0 /* bc_to_host_4 */, 0 /* bc_to_host_8 */,
- swap, 0 /* bc_from_host_4 */, 0 /* bc_from_host_8 */,
+ 0 /* bc_io_read_raw_multi_2 */,
+ 0 /* bc_io_read_raw_multi_4 */, 0 /* bc_io_read_raw_multi_8 */,
+
+ 0 /* bc_io_write_raw_multi_2 */,
+ 0 /* bc_io_write_raw_multi_4 */, 0 /* bc_io_write_raw_multi_8 */,
};
/* Golden Gate II. */
@@ -155,9 +162,11 @@ struct amiga_bus_chipset ggbus2_chipset = {
(bus_mem_write_1_t)ggbus_write_1, (bus_mem_write_2_t)ggbus_write_2,
0 /* bc_mem_write_4 */, 0 /* bc_mem_write_8 */,
- /* These are extensions to the general NetBSD bus interface. */
- swap, 0 /* bc_to_host_4 */, 0 /* bc_to_host_8 */,
- swap, 0 /* bc_from_host_4 */, 0 /* bc_from_host_8 */,
+ ggbus_io_read_raw_multi_2,
+ 0 /* bc_io_read_raw_multi_4 */, 0 /* bc_io_read_raw_multi_8 */,
+
+ ggbus_io_write_raw_multi_2,
+ 0 /* bc_io_write_raw_multi_4 */, 0 /* bc_io_write_raw_multi_8 */,
};
struct cfattach ggbus_ca = {
@@ -287,7 +296,7 @@ ggbus_read_2(handle, addr)
bus_io_handle_t handle;
bus_io_size_t addr;
{
- return swap(*(volatile u_int16_t *)(handle + 2 * addr));
+ return *(volatile u_int16_t *)(handle + 2 * addr);
}
void
@@ -312,6 +321,21 @@ ggbus_io_read_multi_2(handle, addr, buf, cnt)
*buf++ = ggbus_read_2(handle, addr);
}
+void
+ggbus_io_read_raw_multi_2(handle, addr, buf, cnt)
+ bus_io_handle_t handle;
+ bus_io_size_t addr;
+ u_int8_t *buf;
+ bus_io_size_t cnt;
+{
+ u_int16_t *buf16 = (u_int16_t *)buf;
+
+ while (cnt) {
+ cnt -= 2;
+ *buf16++ = swap(ggbus_read_2(handle, addr));
+ }
+}
+
__inline void
ggbus_write_1(handle, addr, val)
bus_io_handle_t handle;
@@ -330,7 +354,7 @@ ggbus_write_2(handle, addr, val)
bus_io_size_t addr;
u_int16_t val;
{
- *(volatile u_int16_t *)(handle + 2 * addr) = swap(val);
+ *(volatile u_int16_t *)(handle + 2 * addr) = val;
}
void
@@ -355,6 +379,21 @@ ggbus_io_write_multi_2(handle, addr, buf, cnt)
ggbus_write_2(handle, addr, *buf++);
}
+void
+ggbus_io_write_raw_multi_2(handle, addr, buf, cnt)
+ bus_io_handle_t handle;
+ bus_io_size_t addr;
+ const u_int8_t *buf;
+ bus_io_size_t cnt;
+{
+ const u_int16_t *buf16 = (const u_int16_t *)buf;
+
+ while (cnt) {
+ cnt -= 2;
+ ggbus_write_2(handle, addr, swap(*buf16++));
+ }
+}
+
static ggbus_int_map[] = {
0, 0, 0, 0, GG2_IRQ3, GG2_IRQ4, GG2_IRQ5, GG2_IRQ6, GG2_IRQ7, 0,
GG2_IRQ9, GG2_IRQ10, GG2_IRQ11, GG2_IRQ12, 0, GG2_IRQ14, GG2_IRQ15