diff options
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/amd64/include/bus.h | 6 | ||||
-rw-r--r-- | sys/arch/i386/conf/files.i386 | 3 | ||||
-rw-r--r-- | sys/arch/i386/i386/bus_space.c | 554 | ||||
-rw-r--r-- | sys/arch/i386/include/bus.h | 423 |
4 files changed, 619 insertions, 367 deletions
diff --git a/sys/arch/amd64/include/bus.h b/sys/arch/amd64/include/bus.h index d566a285691..88e13b20fd9 100644 --- a/sys/arch/amd64/include/bus.h +++ b/sys/arch/amd64/include/bus.h @@ -1,4 +1,4 @@ -/* $OpenBSD: bus.h,v 1.11 2008/11/21 23:16:16 oga Exp $ */ +/* $OpenBSD: bus.h,v 1.12 2008/11/22 17:45:20 oga Exp $ */ /* $NetBSD: bus.h,v 1.6 1996/11/10 03:19:25 thorpej Exp $ */ /*- @@ -201,7 +201,6 @@ void bus_space_read_multi_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, void bus_space_read_region_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, u_int8_t *, bus_size_t); - void bus_space_read_region_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, u_int16_t *, bus_size_t); void bus_space_read_region_4(bus_space_tag_t, bus_space_handle_t, @@ -245,10 +244,8 @@ void bus_space_read_region_4(bus_space_tag_t, bus_space_handle_t, void bus_space_write_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, u_int8_t); - void bus_space_write_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, u_int16_t); - void bus_space_write_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, u_int32_t); @@ -314,7 +311,6 @@ void bus_space_write_region_2(bus_space_tag_t, bus_space_handle_t, void bus_space_write_region_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, const u_int32_t *, bus_size_t); - #if 0 /* Cause a link error for bus_space_write_region_8 */ #define bus_space_write_region_8 \ !!! bus_space_write_region_8 unimplemented !!! diff --git a/sys/arch/i386/conf/files.i386 b/sys/arch/i386/conf/files.i386 index 651dfa007c7..ae0c24c5c17 100644 --- a/sys/arch/i386/conf/files.i386 +++ b/sys/arch/i386/conf/files.i386 @@ -1,4 +1,4 @@ -# $OpenBSD: files.i386,v 1.184 2008/11/09 15:11:19 oga Exp $ +# $OpenBSD: files.i386,v 1.185 2008/11/22 17:45:20 oga Exp $ # # new style config file for i386 architecture # @@ -11,6 +11,7 @@ maxusers 2 16 100 major {ccd = 16} file arch/i386/i386/autoconf.c +file arch/i386/i386/bus_space.c file arch/i386/i386/conf.c file arch/i386/i386/db_disasm.c ddb file arch/i386/i386/db_interface.c ddb diff --git a/sys/arch/i386/i386/bus_space.c b/sys/arch/i386/i386/bus_space.c new file mode 100644 index 00000000000..000de7d0f99 --- /dev/null +++ b/sys/arch/i386/i386/bus_space.c @@ -0,0 +1,554 @@ +/* $OpenBSD: bus_space.c,v 1.1 2008/11/22 17:45:20 oga Exp $ */ +/*- + * Copyright (c) 1996, 1997 The NetBSD Foundation, Inc. + * All rights reserved. + * + * This code is derived from software contributed to The NetBSD Foundation + * by Jason R. Thorpe of the Numerical Aerospace Simulation Facility, + * NASA Ames Research Center. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS + * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED + * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS + * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR + * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + * POSSIBILITY OF SUCH DAMAGE. + */ + +/* + * Copyright (c) 1996 Charles M. Hannum. All rights reserved. + * Copyright (c) 1996 Jason R. Thorpe. All rights reserved. + * Copyright (c) 1996 Christopher G. Demetriou. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes software developed by Christopher G. Demetriou + * for the NetBSD Project. + * 4. The name of the author may not be used to endorse or promote products + * derived from this software without specific prior written permission + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include <sys/param.h> +#include<sys/systm.h> +#include <sys/malloc.h> +#include <sys/extent.h> + +#define _I386_BUS_DMA_PRIVATE +#include <machine/bus.h> + +u_int8_t +bus_space_read_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o) +{ + return ((t) == I386_BUS_SPACE_IO ? (inb((h) + (o))) : + (*(volatile u_int8_t *)((h) + (o)))); +} + +u_int16_t +bus_space_read_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o) +{ + return ((t) == I386_BUS_SPACE_IO ? (inw((h) + (o))) : + (*(volatile u_int16_t *)((h) + (o)))); +} + +u_int32_t +bus_space_read_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o) +{ + return ((t) == I386_BUS_SPACE_IO ? (inl((h) + (o))) : + (*(volatile u_int32_t *)((h) + (o)))); +} + + +void +bus_space_read_multi_1(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, + u_int8_t *a, bus_size_t cnt) +{ + if (t == I386_BUS_SPACE_IO) { + insb(h + o, a, cnt); + } else { + void *_addr=a; + int _cnt=cnt; + __asm __volatile("cld ;" + "1: movb (%2),%%al ;" + " stosb ;" + " loop 1b" : + "+D" (_addr), "+c" (_cnt) : "r" (h + o) : + "%eax", "memory", "cc"); + } +} + +void +bus_space_read_multi_2(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, + u_int16_t *a, bus_size_t cnt) +{ + if (t == I386_BUS_SPACE_IO) { + insw(h + o, a, cnt); + } else { + void *_addr=a; + int _cnt=cnt; + __asm __volatile("cld ;" + "1: movw (%2),%%ax ;" + " stosw ;" + " loop 1b" : + "+D" (_addr), "+c" (_cnt) : "r" ((h) + (o)) : + "%eax", "memory", "cc"); + } +} +void +bus_space_read_multi_4(bus_space_tag_t t, bus_space_handle_t h, bus_size_t o, + u_int32_t *a, bus_size_t cnt) +{ + if (t == I386_BUS_SPACE_IO) { + insl(h + o, a, cnt); + } else { + void *_addr=a; + int _cnt=cnt; + __asm __volatile("cld ;" + "1: movl (%2),%%eax ;" + " stosl ;" + " loop 1b" : + "+D" (_addr), "+c" (_cnt) : "r" (h + o) : + "%eax", "memory", "cc"); + } +} + +void +bus_space_read_region_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int8_t *a, bus_size_t cnt) +{ + int _cnt = cnt; + void *_addr = a; + int _port = h + o; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: inb %w2,%%al ;" + " stosb ;" + " incl %2 ;" + " loop 1b" : + "+D" (_addr), "+c" (_cnt), "+d" (_port) :: + "%eax", "memory", "cc"); + } else + i386_space_copy(_port, _addr, 1, _cnt); +} + +void +bus_space_read_region_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int16_t *a, bus_size_t cnt) +{ + int _cnt = cnt; + void *_addr = a; + int _port = h + o; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: inw %w2,%%ax ;" + " stosw ;" + " addl $2,%2 ;" + " loop 1b" : + "+D" (_addr), "+c" (_cnt), "+d" (_port) :: + "%eax", "memory", "cc"); + } else + i386_space_copy(_port, _addr, 2, _cnt); +} + +void +bus_space_read_region_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int32_t *a, bus_size_t cnt) +{ + int _cnt = cnt; + void *_addr = a; + int _port = h + o; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: inl %w2,%%eax ;" + " stosl ;" + " addl $4,%2 ;" + " loop 1b" : + "+D" (_addr), "+c" (_cnt), "+d" (_port) :: + "%eax", "memory", "cc"); + } else + i386_space_copy(_port, _addr, 4, _cnt); +} + +void +bus_space_write_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int8_t v) +{ + if (t == I386_BUS_SPACE_IO) + outb(h + o, v); + else + ((void)(*(volatile u_int8_t *)(h + o) = v)); +} + +void +bus_space_write_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int16_t v) +{ + if ((t) == I386_BUS_SPACE_IO) + outw(h + o, v); + else + ((void)(*(volatile u_int16_t *)(h + o) = v)); +} + +void +bus_space_write_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int32_t v) +{ + if ((t) == I386_BUS_SPACE_IO) + outl(h + o, v); + else + ((void)(*(volatile u_int32_t *)(h + o) = v)); +} + +void +bus_space_write_multi_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, const u_int8_t *a, bus_size_t cnt) +{ + if (t == I386_BUS_SPACE_IO) { + outsb(h + o, a, cnt); + } else { + const void *_addr=a; + int _cnt=cnt; + + __asm __volatile("cld ;" + "1: lodsb ;" + " movb %%al,(%2) ;" + " loop 1b" : + "+S" (_addr), "+c" (_cnt) : "r" (h + o) : + "%eax", "memory", "cc"); + } +} + +void +bus_space_write_multi_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, const u_int16_t *a, bus_size_t cnt) +{ + if (t == I386_BUS_SPACE_IO) { + outsw(h + o, a, cnt); + } else { + const void *_addr = a; + int _cnt = cnt; + + __asm __volatile("cld ;" + "1: lodsw ;" + " movw %%ax,(%2) ;" + " loop 1b" : + "+S" (_addr), "+c" (_cnt) : "r" (h + o) : + "%eax", "memory", "cc"); + } +} +void +bus_space_write_multi_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, const u_int32_t *a, bus_size_t cnt) +{ + if (t == I386_BUS_SPACE_IO) { + outsl(h + o, a, cnt); + } else { + const void *_addr=a; + int _cnt=cnt; + + __asm __volatile("cld ;" + "1: lodsl ;" + " movl %%eax,(%2) ;" + " loop 1b" : + "+S" (_addr), "+c" (_cnt) : "r" (h + o) : + "%eax", "memory", "cc"); + } +} + +void +bus_space_write_region_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, const u_int8_t *a, bus_size_t cnt) +{ + int _port = h + o; + const void *_addr = a; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: lodsb ;" + " outb %%al,%w0 ;" + " incl %0 ;" + " loop 1b" : + "+d" (_port), "+S" (_addr), "+c" (_cnt) :: + "%eax", "memory", "cc"); + } else + i386_space_copy(_addr, _port, 1, _cnt); +} + +void +bus_space_write_region_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, const u_int16_t *a, bus_size_t cnt) +{ + int _port = h + o; + const void *_addr = a; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: lodsw ;" + " outw %%ax,%w0 ;" + " addl $2,%0 ;" + " loop 1b" : + "+d" (_port), "+S" (_addr), "+c" (_cnt) :: + "%eax", "memory", "cc"); + } else + i386_space_copy(_addr, _port, 2, _cnt); +} + +void +bus_space_write_region_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, const u_int32_t *a, bus_size_t cnt) +{ + int _port = h + o; + const void *_addr = a; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: lodsl ;" + " outl %%eax,%w0 ;" + " addl $4,%0 ;" + " loop 1b" : + "+d" (_port), "+S" (_addr), "+c" (_cnt) :: + "%eax", "memory", "cc"); + } else + i386_space_copy(_addr, _port, 4, _cnt); +} + +void +bus_space_set_multi_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int8_t v, size_t cnt) +{ + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: outb %b2, %w1 ;" + " loop 1b" : + "+c" (_cnt) : "d" (h + o), "a" (v) : + "cc"); + } else { + __asm __volatile("cld ;" + "1: movb %b2, (%1) ;" + " loop 1b" : + "+c" (_cnt) : "D" (h + o), "a" (v) : + "cc", "memory"); + } +} + +void +bus_space_set_multi_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int16_t v, size_t cnt) +{ + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: outw %w2, %w1 ;" + " loop 1b" : + "+c" (_cnt) : "d" (h + o), "a" (v) : + "cc"); + } else { + __asm __volatile("cld ;" + "1: movw %w2, (%1) ;" + " loop 1b" : + "+c" (_cnt) : "D" (h + o), "a" (v) : + "cc", "memory"); + } +} + +void +bus_space_set_multi_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int32_t v, size_t cnt) +{ + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile("cld ;" + "1: outl %2,%w1 ;" + " loop 1b" : + "+c" (_cnt) : "d" (h + o), "a" (v) : + "cc"); + } else { + __asm __volatile("cld ;" + "1: movl %2,(%1) ;" + " loop 1b" : + "+c" (_cnt) : "D" (h + o), "a" (v) : + "cc", "memory"); + } +} + +void +bus_space_set_region_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int8_t v, size_t cnt) +{ + int _port = h + o; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile( + "1: outb %%al,%w0 ;" + " incl %0 ;" + " loop 1b" : + "+d" (_port), "+c" (_cnt) : "a" (v) : + "cc"); + } else { + __asm __volatile("cld ;" + " repne ;" + " stosb" : + "+D" (_port), "+c" (_cnt) : "a" (v) : + "memory", "cc"); + } +} + +void +bus_space_set_region_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int16_t v, size_t cnt) +{ + int _port = h + o; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile( + "1: outw %%ax,%w0 ;" + " addl $2, %0 ;" + " loop 1b" : + "+d" (_port), "+c" (_cnt) : "a" (v) : + "cc"); + } else { + __asm __volatile("cld ;" + " repne ;" + " stosw" : + "+D" (_port), "+c" (_cnt) : "a" (v) : + "memory", "cc"); + } +} + +void +bus_space_set_region_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int32_t v, size_t cnt) +{ + int _port = h + o; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile( + "1: outl %%eax,%w0 ;" + " addl $4, %0 ;" + " loop 1b" : + "+d" (_port), "+c" (_cnt) : "a" (v) : + "cc"); + } else { + __asm __volatile("cld ;" + " repne ;" + " stosl" : + "+D" (_port), "+c" (_cnt) : "a" (v) : + "memory", "cc"); + } +} + +void +bus_space_copy_1(bus_space_tag_t t, bus_space_handle_t h1, bus_size_t o1, + bus_space_handle_t h2, bus_size_t o2, bus_size_t cnt) +{ + int _port1 = h1 + o1; + int _port2 = h2 + o2; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile( + "1: movl %k1,%%edx ;" + " inb %%dx,%%al ;" + " movl %k0,%%edx ;" + " outb %%al,%%dx ;" + " incl %0 ;" + " incl %1 ;" + " loop 1b" : + "+D" (_port2), "+S" (_port1), "+c" (_cnt) :: + "%edx", "%eax", "cc"); + } else + i386_space_copy(_port1, _port2, 1, _cnt); +} + +void +bus_space_copy_2(bus_space_tag_t t, bus_space_handle_t h1, bus_size_t o1, + bus_space_handle_t h2, bus_size_t o2, bus_size_t cnt) +{ + int _port1 = h1 + o1; + int _port2 = h2 + o2; + int _cnt=cnt; + if (t == I386_BUS_SPACE_IO) { + __asm __volatile( + "1: movl %k1,%%edx ;" + " inw %%dx,%%ax ;" + " movl %k0,%%edx ;" + " outw %%ax,%%dx ;" + " addl $2, %0 ;" + " addl $2, %1 ;" + " loop 1b" : + "+D" (_port2), "+ES" (_port1), "+c" (_cnt) :: + "%edx", "%eax", "cc"); + } else + i386_space_copy(_port1, _port2, 2, _cnt); +} + +void +bus_space_copy_4(bus_space_tag_t t, bus_space_handle_t h1, bus_size_t o1, + bus_space_handle_t h2, bus_size_t o2, bus_size_t cnt) +{ + int _port1 = h1 + o1; + int _port2 = h2 + o2; + int _cnt = cnt; + + if (t == I386_BUS_SPACE_IO) { + __asm __volatile( + "1: movl %k1,%%edx ;" + " inl %%dx,%%eax ;" + " movl %k0,%%edx ;" + " outl %%eax,%%dx ;" + " addl $4, %0 ;" + " addl $4, %1 ;" + " loop 1b" : + "+D" (_port2), "+ES" (_port1), "+c" (_cnt) :: + "%edx", "%eax", "cc"); + } else + i386_space_copy(_port1, _port2, 4, _cnt); +} diff --git a/sys/arch/i386/include/bus.h b/sys/arch/i386/include/bus.h index a2d329950b2..bb58a12fe8c 100644 --- a/sys/arch/i386/include/bus.h +++ b/sys/arch/i386/include/bus.h @@ -1,4 +1,4 @@ -/* $OpenBSD: bus.h,v 1.43 2008/06/26 05:42:10 ray Exp $ */ +/* $OpenBSD: bus.h,v 1.44 2008/11/22 17:45:20 oga Exp $ */ /* $NetBSD: bus.h,v 1.6 1996/11/10 03:19:25 thorpej Exp $ */ /*- @@ -113,18 +113,18 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * Read a 1, 2, 4, or 8 byte quantity from bus space * described by tag/handle/offset. */ +u_int8_t bus_space_read_1(bus_space_tag_t, bus_space_handle_t, + bus_size_t); -#define bus_space_read_1(t, h, o) \ - ((t) == I386_BUS_SPACE_IO ? (inb((h) + (o))) : \ - (*(volatile u_int8_t *)((h) + (o)))) +u_int16_t bus_space_read_2(bus_space_tag_t, bus_space_handle_t, + bus_size_t); -#define bus_space_read_2(t, h, o) \ - ((t) == I386_BUS_SPACE_IO ? (inw((h) + (o))) : \ - (*(volatile u_int16_t *)((h) + (o)))) +u_int32_t bus_space_read_4(bus_space_tag_t, bus_space_handle_t, + bus_size_t); -#define bus_space_read_4(t, h, o) \ - ((t) == I386_BUS_SPACE_IO ? (inl((h) + (o))) : \ - (*(volatile u_int32_t *)((h) + (o)))) +#if 0 /* Cause a link error for bus_space_read_8 */ +#define bus_space_read_8(t, h, o) !!! bus_space_read_8 unimplemented !!! +#endif #if 0 /* Cause a link error for bus_space_read_8 */ #define bus_space_read_8(t, h, o) !!! bus_space_read_8 unimplemented !!! @@ -139,47 +139,17 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * described by tag/handle/offset and copy into buffer provided. */ -#define bus_space_read_multi_1(t, h, o, a, cnt) do { \ - if ((t) == I386_BUS_SPACE_IO) { \ - insb((h) + (o), (a), (cnt)); \ - } else {void *_addr=(a); int _cnt=(cnt); \ - __asm __volatile(" \ - cld ; \ - 1: movb (%2),%%al ; \ - stosb ; \ - loop 1b" : \ - "+D" (_addr), "+c" (_cnt) : "r" ((h) + (o)) : \ - "%eax", "memory", "cc"); \ - } \ -} while (0) - -#define bus_space_read_multi_2(t, h, o, a, cnt) do { \ - if ((t) == I386_BUS_SPACE_IO) { \ - insw((h) + (o), (a), (cnt)); \ - } else {void *_addr=(a); int _cnt=(cnt); \ - __asm __volatile(" \ - cld ; \ - 1: movw (%2),%%ax ; \ - stosw ; \ - loop 1b" : \ - "+D" (_addr), "+c" (_cnt) : "r" ((h) + (o)) : \ - "%eax", "memory", "cc"); \ - } \ -} while (0) +#define bus_space_read_raw_multi_2(t, h, o, a, c) \ + bus_space_read_multi_2((t), (h), (o), (u_int16_t *)(a), (c) >> 1) +#define bus_space_read_raw_multi_4(t, h, o, a, c) \ + bus_space_read_multi_4((t), (h), (o), (u_int32_t *)(a), (c) >> 2) -#define bus_space_read_multi_4(t, h, o, a, cnt) do { \ - if ((t) == I386_BUS_SPACE_IO) { \ - insl((h) + (o), (a), (cnt)); \ - } else {void *_addr=(a); int _cnt=(cnt); \ - __asm __volatile(" \ - cld ; \ - 1: movl (%2),%%eax ; \ - stosl ; \ - loop 1b" : \ - "+D" (_addr), "+c" (_cnt) : "r" ((h) + (o)) : \ - "%eax", "memory", "cc"); \ - } \ -} while (0) +void bus_space_read_multi_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, + u_int8_t *, bus_size_t); +void bus_space_read_multi_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, + u_int16_t *, bus_size_t); +void bus_space_read_multi_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, + u_int32_t *, bus_size_t); #if 0 /* Cause a link error for bus_space_read_multi_8 */ #define bus_space_read_multi_8 !!! bus_space_read_multi_8 unimplemented !!! @@ -216,50 +186,12 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * buffer provided. */ -#define bus_space_read_region_1(t, h, o, a, cnt) do { \ - int _cnt = (cnt); void *_addr = (a); int _port = (h)+(o); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: inb %w2,%%al ; \ - stosb ; \ - incl %2 ; \ - loop 1b" : \ - "+D" (_addr), "+c" (_cnt), "+d" (_port) :: \ - "%eax", "memory", "cc"); \ - } else \ - i386_space_copy(_port, _addr, 1, _cnt); \ -} while (0) - -#define bus_space_read_region_2(t, h, o, a, cnt) do { \ - int _cnt = (cnt); void *_addr = (a); int _port = (h)+(o); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: inw %w2,%%ax ; \ - stosw ; \ - addl $2,%2 ; \ - loop 1b" : \ - "+D" (_addr), "+c" (_cnt), "+d" (_port) :: \ - "%eax", "memory", "cc"); \ - } else \ - i386_space_copy(_port, _addr, 2, _cnt); \ -} while (0) - -#define bus_space_read_region_4(t, h, o, a, cnt) do { \ - int _cnt = (cnt); void *_addr = (a); int _port = (h)+(o); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: inl %w2,%%eax ; \ - stosl ; \ - addl $4,%2 ; \ - loop 1b" : \ - "+D" (_addr), "+c" (_cnt), "+d" (_port) :: \ - "%eax", "memory", "cc"); \ - } else \ - i386_space_copy(_port, _addr, 4, _cnt); \ -} while (0) +void bus_space_read_region_1(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int8_t *, bus_size_t); +void bus_space_read_region_2(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int16_t *, bus_size_t); +void bus_space_read_region_4(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int32_t *, bus_size_t); #if 0 /* Cause a link error for bus_space_read_region_8 */ #define bus_space_read_region_8 !!! bus_space_read_region_8 unimplemented !!! @@ -296,26 +228,12 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * described by tag/handle/offset. */ -#define bus_space_write_1(t, h, o, v) do { \ - if ((t) == I386_BUS_SPACE_IO) \ - outb((h) + (o), (v)); \ - else \ - ((void)(*(volatile u_int8_t *)((h) + (o)) = (v))); \ -} while (0) - -#define bus_space_write_2(t, h, o, v) do { \ - if ((t) == I386_BUS_SPACE_IO) \ - outw((h) + (o), (v)); \ - else \ - ((void)(*(volatile u_int16_t *)((h) + (o)) = (v))); \ -} while (0) - -#define bus_space_write_4(t, h, o, v) do { \ - if ((t) == I386_BUS_SPACE_IO) \ - outl((h) + (o), (v)); \ - else \ - ((void)(*(volatile u_int32_t *)((h) + (o)) = (v))); \ -} while (0) +void bus_space_write_1(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int8_t); +void bus_space_write_2(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int16_t); +void bus_space_write_4(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int32_t); #if 0 /* Cause a link error for bus_space_write_8 */ #define bus_space_write_8 !!! bus_space_write_8 not implemented !!! @@ -330,47 +248,12 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * provided to bus space described by tag/handle/offset. */ -#define bus_space_write_multi_1(t, h, o, a, cnt) do { \ - if ((t) == I386_BUS_SPACE_IO) { \ - outsb((h) + (o), (a), (cnt)); \ - } else {const void *_addr=(a); int _cnt=(cnt); \ - __asm __volatile(" \ - cld ; \ - 1: lodsb ; \ - movb %%al,(%2) ; \ - loop 1b" : \ - "+S" (_addr), "+c" (_cnt) : "r" ((h) + (o)) : \ - "%eax", "memory", "cc"); \ - } \ -} while (0) - -#define bus_space_write_multi_2(t, h, o, a, cnt) do { \ - if ((t) == I386_BUS_SPACE_IO) { \ - outsw((h) + (o), (a), (cnt)); \ - } else {const void *_addr=(a); int _cnt=(cnt); \ - __asm __volatile(" \ - cld ; \ - 1: lodsw ; \ - movw %%ax,(%2) ; \ - loop 1b" : \ - "+S" (_addr), "+c" (_cnt) : "r" ((h) + (o)) : \ - "%eax", "memory", "cc"); \ - } \ -} while (0) - -#define bus_space_write_multi_4(t, h, o, a, cnt) do { \ - if ((t) == I386_BUS_SPACE_IO) { \ - outsl((h) + (o), (a), (cnt)); \ - } else {const void *_addr=(a); int _cnt=(cnt); \ - __asm __volatile(" \ - cld ; \ - 1: lodsl ; \ - movl %%eax,(%2) ; \ - loop 1b" : \ - "+S" (_addr), "+c" (_cnt) : "r" ((h) + (o)) : \ - "%eax", "memory", "cc"); \ - } \ -} while (0) +void bus_space_write_multi_1(bus_space_tag_t, bus_space_handle_t, + bus_size_t, const u_int8_t *, bus_size_t); +void bus_space_write_multi_2(bus_space_tag_t, bus_space_handle_t, + bus_size_t, const u_int16_t *, bus_size_t); +void bus_space_write_multi_4(bus_space_tag_t, bus_space_handle_t, + bus_size_t, const u_int32_t *, bus_size_t); #if 0 /* Cause a link error for bus_space_write_multi_8 */ #define bus_space_write_multi_8(t, h, o, a, c) \ @@ -407,50 +290,12 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * to bus space described by tag/handle starting at `offset'. */ -#define bus_space_write_region_1(t, h, o, a, cnt) do { \ - int _port = (h)+(o); const void *_addr=(a); int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: lodsb ; \ - outb %%al,%w0 ; \ - incl %0 ; \ - loop 1b" : \ - "+d" (_port), "+S" (_addr), "+c" (_cnt) :: \ - "%eax", "memory", "cc"); \ - } else \ - i386_space_copy(_addr, _port, 1, _cnt); \ -} while (0) - -#define bus_space_write_region_2(t, h, o, a, cnt) do { \ - int _port = (h)+(o); const void *_addr=(a); int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: lodsw ; \ - outw %%ax,%w0 ; \ - addl $2,%0 ; \ - loop 1b" : \ - "+d" (_port), "+S" (_addr), "+c" (_cnt) :: \ - "%eax", "memory", "cc"); \ - } else \ - i386_space_copy(_addr, _port, 2, _cnt); \ -} while (0) - -#define bus_space_write_region_4(t, h, o, a, cnt) do { \ - int _port = (h)+(o); const void *_addr=(a); int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: lodsl ; \ - outl %%eax,%w0 ; \ - addl $4,%0 ; \ - loop 1b" : \ - "+d" (_port), "+S" (_addr), "+c" (_cnt) :: \ - "%eax", "memory", "cc"); \ - } else \ - i386_space_copy(_addr, _port, 4, _cnt); \ -} while (0) +void bus_space_write_region_1(bus_space_tag_t, bus_space_handle_t, + bus_size_t, const u_int8_t *, bus_size_t); +void bus_space_write_region_2(bus_space_tag_t, bus_space_handle_t, + bus_size_t, const u_int16_t *, bus_size_t); +void bus_space_write_region_4(bus_space_tag_t, bus_space_handle_t, + bus_size_t, const u_int32_t *, bus_size_t); #if 0 /* Cause a link error for bus_space_write_region_8 */ #define bus_space_write_region_8 \ @@ -488,62 +333,12 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * by tag/handle/offset `count' times. */ -#define bus_space_set_multi_1(t, h, o, v, cnt) do { \ - int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: outb %b2, %w1 ; \ - loop 1b" : \ - "+c" (_cnt) : "d" ((h) + (o)), "a" ((v)) : \ - "cc"); \ - } else { \ - __asm __volatile(" \ - cld ; \ - 1: movb %b2, (%1) ; \ - loop 1b" : \ - "+c" (_cnt) : "D" ((h) + (o)), "a" ((v)) : \ - "cc", "memory"); \ - } \ -} while (0) - -#define bus_space_set_multi_2(t, h, o, v, cnt) do { \ - int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: outw %w2, %w1 ; \ - loop 1b" : \ - "+c" (_cnt) : "d" ((h) + (o)), "a" ((v)) : \ - "cc"); \ - } else { \ - __asm __volatile(" \ - cld ; \ - 1: movw %w2, (%1) ; \ - loop 1b" : \ - "+c" (_cnt) : "D" ((h) + (o)), "a" ((v)) : \ - "cc", "memory"); \ - } \ -} while (0) - -#define bus_space_set_multi_4(t, h, o, v, cnt) do { \ - int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - cld ; \ - 1: outl %2,%w1 ; \ - loop 1b" : \ - "+c" (_cnt) : "d" ((h) + (o)), "a" ((v)) : \ - "cc"); \ - } else { \ - __asm __volatile(" \ - cld ; \ - 1: movl %2,(%1) ; \ - loop 1b" : \ - "+c" (_cnt) : "D" ((h) + (o)), "a" ((v)) : \ - "cc", "memory"); \ - } \ -} while (0) +void bus_space_set_multi_1(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int8_t, size_t); +void bus_space_set_multi_2(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int16_t, size_t); +void bus_space_set_multi_4(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int32_t, size_t); #if 0 /* Cause a link error for bus_space_set_multi_8 */ #define bus_space_set_multi_8 \ @@ -558,63 +353,13 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * Write `count' 1, 2, 4, or 8 byte value `val' to bus space described * by tag/handle starting at `offset'. */ +void bus_space_set_region_1(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int8_t, size_t); +void bus_space_set_region_2(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int16_t, size_t); +void bus_space_set_region_4(bus_space_tag_t, bus_space_handle_t, + bus_size_t, u_int32_t, size_t); -#define bus_space_set_region_1(t, h, o, v, cnt) do { \ - int _port = (h)+(o); int _cnt = (cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - 1: outb %%al,%w0 ; \ - incl %0 ; \ - loop 1b" : \ - "+d" (_port), "+c" (_cnt) : "a" ((v)) : \ - "cc"); \ - } else { \ - __asm __volatile(" \ - cld ; \ - repne ; \ - stosb" : \ - "+D" (_port), "+c" (_cnt) : "a" ((v)) : \ - "memory", "cc"); \ - } \ -} while (0) - -#define bus_space_set_region_2(t, h, o, v, cnt) do { \ - int _port = (h)+(o); int _cnt = (cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - 1: outw %%ax,%w0 ; \ - addl $2, %0 ; \ - loop 1b" : \ - "+d" (_port), "+c" (_cnt) : "a" ((v)) : \ - "cc"); \ - } else { \ - __asm __volatile(" \ - cld ; \ - repne ; \ - stosw" : \ - "+D" (_port), "+c" (_cnt) : "a" ((v)) : \ - "memory", "cc"); \ - } \ -} while (0) - -#define bus_space_set_region_4(t, h, o, v, cnt) do { \ - int _port = (h)+(o); int _cnt = (cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - 1: outl %%eax,%w0 ; \ - addl $4, %0 ; \ - loop 1b" : \ - "+d" (_port), "+c" (_cnt) : "a" ((v)) : \ - "cc"); \ - } else { \ - __asm __volatile(" \ - cld ; \ - repne ; \ - stosl" : \ - "+D" (_port), "+c" (_cnt) : "a" ((v)) : \ - "memory", "cc"); \ - } \ -} while (0) #if 0 /* Cause a link error for bus_space_set_region_8 */ #define bus_space_set_region_8 \ @@ -631,56 +376,12 @@ void bus_space_free(bus_space_tag_t t, bus_space_handle_t bsh, * at tag/bsh1/off1 to bus space starting at tag/bsh2/off2. */ -#define bus_space_copy_1(t, h1, o1, h2, o2, cnt) do { \ - int _port1 = (h1)+(o1); int _port2 = (h2)+(o2); int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - 1: movl %k1,%%edx ; \ - inb %%dx,%%al ; \ - movl %k0,%%edx ; \ - outb %%al,%%dx ; \ - incl %0 ; \ - incl %1 ; \ - loop 1b" : \ - "+D" (_port2), "+S" (_port1), "+c" ((_cnt)) :: \ - "%edx", "%eax", "cc"); \ - } else \ - i386_space_copy(_port1, _port2, 1, _cnt); \ -} while (0) - -#define bus_space_copy_2(t, h1, o1, h2, o2, cnt) do { \ - int _port1 = (h1)+(o1); int _port2 = (h2)+(o2); int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - 1: movl %k1,%%edx ; \ - inw %%dx,%%ax ; \ - movl %k0,%%edx ; \ - outw %%ax,%%dx ; \ - addl $2, %0 ; \ - addl $2, %1 ; \ - loop 1b" : \ - "+D" (_port2), "+ES" (_port1), "+c" ((_cnt)) :: \ - "%edx", "%eax", "cc"); \ - } else \ - i386_space_copy(_port1, _port2, 2, _cnt); \ -} while (0) - -#define bus_space_copy_4(t, h1, o1, h2, o2, cnt) do { \ - int _port1 = (h1)+(o1); int _port2 = (h2)+(o2); int _cnt=(cnt); \ - if ((t) == I386_BUS_SPACE_IO) { \ - __asm __volatile(" \ - 1: movl %k1,%%edx ; \ - inl %%dx,%%eax ; \ - movl %k0,%%edx ; \ - outl %%eax,%%dx ; \ - addl $4, %0 ; \ - addl $4, %1 ; \ - loop 1b" : \ - "+D" (_port2), "+ES" (_port1), "+c" ((_cnt)) :: \ - "%edx", "%eax", "cc"); \ - } else \ - i386_space_copy(_port1, _port2, 4, _cnt); \ -} while (0) +void bus_space_copy_1(bus_space_tag_t, bus_space_handle_t, bus_size_t, + bus_space_handle_t, bus_size_t, bus_size_t); +void bus_space_copy_2(bus_space_tag_t, bus_space_handle_t, bus_size_t, + bus_space_handle_t, bus_size_t, bus_size_t); +void bus_space_copy_4(bus_space_tag_t, bus_space_handle_t, bus_size_t, + bus_space_handle_t, bus_size_t, bus_size_t); #if 0 /* Cause a link error for bus_space_copy_8 */ #define bus_space_copy_8 \ |