diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 1998-11-23 03:36:54 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 1998-11-23 03:36:54 +0000 |
commit | 161a56b70ece8fb1c5a9a0a84bdbb8dff879bcde (patch) | |
tree | 997bc4cd0e079a869a64516d563f0ba68eb37edc | |
parent | 8504f12edff2b01ba1b6bfda6bddf66756e63267 (diff) |
some bus.h
-rw-r--r-- | sys/arch/hppa/include/bus.h | 347 |
1 files changed, 347 insertions, 0 deletions
diff --git a/sys/arch/hppa/include/bus.h b/sys/arch/hppa/include/bus.h new file mode 100644 index 00000000000..fd8de3afc12 --- /dev/null +++ b/sys/arch/hppa/include/bus.h @@ -0,0 +1,347 @@ +/* $OpenBSD: bus.h,v 1.1 1998/11/23 03:36:53 mickey Exp $ */ + +/* + * Copyright (c) 1998 Michael Shalayeff + * 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 Michael Shalayeff. + * 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. + */ + +#ifndef _MACHINE_BUS_H_ +#define _MACHINE_BUS_H_ + +#include <machine/cpufunc.h> + +/* addresses in bus space */ +typedef u_long bus_addr_t; +typedef u_long bus_size_t; + +/* access methods for bus space */ +typedef u_long bus_space_tag_t; +typedef u_long bus_space_handle_t; +typedef u_long bus_dma_tag_t; + +#define HPPA_BUS_TAG_SET_BYTE(tag) ((tag) & (~1)) +#define HPPA_BUS_TAG_SET_WORD(tag,off) ((tag) | (1) | ((off) << 1)) +#define HPPA_BUS_TAG_PROTO(tag) ((tag) & 1) +#define HPPA_BUS_TAG_OFFSET(tag) (((tag) >> 1) & 3) +#define HPPA_BUS_TAG_SET_BASE(tag,base) \ + ((((tag) & 0x00000fff)) | ((base) & 0xfffff000)) +#define HPPA_BUS_TAG_BASE(tag) ((tag) & 0xfffff000) + +/* bus access routines */ +#define DCIAS(pa) \ + __asm __volatile ("rsm %1, %%r0\n\tpdc %%r0(%0)\n\tssm %1, %%r0" \ + :: "r" (pa), "i" (PSW_D)); + +/* no extent handlng for now + we won't have overlaps from PDC anyway */ +static __inline int bus_space_map (bus_space_tag_t t, bus_addr_t addr, + bus_size_t size, int cacheable, + bus_space_handle_t *bshp) +{ + *bshp = addr + HPPA_BUS_TAG_BASE(t); + return 0; +} + +static __inline void bus_space_unmap (bus_space_tag_t t, + bus_space_handle_t bsh, + bus_size_t size) +{ + /* nothing to do */ +} + +int bus_space_subregion __P((bus_space_tag_t t, bus_space_handle_t bsh, + bus_size_t offset, bus_size_t size, bus_space_handle_t *nbshp)); + +int bus_space_alloc __P((bus_space_tag_t t, bus_addr_t rstart, + bus_addr_t rend, bus_size_t size, bus_size_t align, + bus_size_t boundary, int cacheable, bus_addr_t *addrp, + bus_space_handle_t *bshp)); +void bus_space_free __P((bus_space_tag_t t, bus_space_handle_t bsh, + bus_size_t size)); + +static __inline u_int8_t +bus_space_read_1(bus_space_tag_t t, bus_space_handle_t h, int o) +{ + register u_int32_t v; + + if (HPPA_BUS_TAG_PROTO(t)) + o = (o << 2) | HPPA_BUS_TAG_OFFSET(t); + + __asm __volatile ("rsm %3, %%r0\n\t" + "ldbx %2(%1), %0\n\t" + "pdc %2(%1)\n\t" + "ssm %3, %%r0" + : "=r" (v): "r" (h), "r" (o), "i" (PSW_D)); + return v & 0xff; +} + +static __inline u_int16_t +bus_space_read_2(bus_space_tag_t t, bus_space_handle_t h, int o) +{ + register u_int32_t v; + + if (HPPA_BUS_TAG_PROTO(t)) + o = (o << 2) | HPPA_BUS_TAG_OFFSET(t); + + __asm __volatile ("rsm %3, %%r0\n\t" + "ldhx %2(%1), %0\n\t" + "pdc %2(%1)\n\t" + "ssm %3, %%r0" + : "=r" (v): "r" (h), "r" (o), "i" (PSW_D)); + return v & 0xffff; +} + +static __inline u_int32_t +bus_space_read_4(bus_space_tag_t t, bus_space_handle_t h, int o) +{ + register u_int32_t v; + + if (HPPA_BUS_TAG_PROTO(t)) + o = (o << 2) | HPPA_BUS_TAG_OFFSET(t); + + __asm __volatile ("rsm %3, %%r0\n\t" + "ldwx %2(%1), %0\n\t" + "pdc %2(%1)\n\t" + "ssm %3, %%r0" + : "=r" (v): "r" (h), "r" (o), "i" (PSW_D)); + return v; +} + +#if 0 +#define bus_space_read_8(t, h, o) +#endif + +static __inline void +bus_space_read_multi_1(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int8_t *a, size_t c) +{ + register u_int32_t v; + + if (HPPA_BUS_TAG_PROTO(t)) + o = (o << 2) | HPPA_BUS_TAG_OFFSET(t); + + for (; c--; *(a++) = v & 0xff) + __asm __volatile ("rsm %3, %%r0\n\t" + "ldbx %2(%1), %0\n\t" + "pdc %2(%1)\n\t" + "ssm %3, %%r0" + : "=r" (v): "r" (h), "r" (o), "i" (PSW_D)); +} + +static __inline void +bus_space_read_multi_2(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int16_t *a, size_t c) +{ + register u_int32_t v; + + if (HPPA_BUS_TAG_PROTO(t)) + o = (o << 2) | HPPA_BUS_TAG_OFFSET(t); + + for (; c--; *(a++) = v & 0xffff) + __asm __volatile ("rsm %3, %%r0\n\t" + "ldhx %2(%1), %0\n\t" + "pdc %2(%1)\n\t" + "ssm %3, %%r0" + : "=r" (v): "r" (h), "r" (o), "i" (PSW_D)); +} + +static __inline void +bus_space_read_multi_4(bus_space_tag_t t, bus_space_handle_t h, + bus_size_t o, u_int32_t *a, size_t c) +{ + register u_int32_t v; + + if (HPPA_BUS_TAG_PROTO(t)) + o = (o << 2) | HPPA_BUS_TAG_OFFSET(t); + + for (; c--; *(a++) = v) + __asm __volatile ("rsm %3, %%r0\n\t" + "ldwx %2(%1), %0\n\t" + "pdc %2(%1)\n\t" + "ssm %3, %%r0" + : "=r" (v): "r" (h), "r" (o), "i" (PSW_D)); +} + +#if 0 +#define bus_space_read_multi_8 +#endif + +#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) + +#if 0 +#define bus_space_read_raw_multi_8 +#endif + +#if 0 +#define bus_space_read_region_1(t, h, o, a, c) do { \ +} while (0) + +#define bus_space_read_region_2(t, h, o, a, c) do { \ + +} while (0) + +#define bus_space_read_region_4(t, h, o, a, c) do { \ +} while (0) + +#define bus_space_read_region_8 +#endif + +#if 0 +#define bus_space_read_raw_region_2(t, h, o, a, c) \ + bus_space_read_region_2((t), (h), (o), (u_int16_t *)(a), (c) >> 1) +#define bus_space_read_raw_region_4(t, h, o, a, c) \ + bus_space_read_region_4((t), (h), (o), (u_int32_t *)(a), (c) >> 2) + +#define bus_space_read_raw_region_8 +#endif + +#define bus_space_write_1(t, h, o, v) do { \ + __asm __volatile ( \ + "rsm %0, %%r0\n\t" \ + "stbs %1, 0(%2)\n\t" \ + "fdc %%r0(%2)\n\t" \ + "ssm %0, %%r0" \ + :: "i" (PSW_D), "r" (v), \ + "r" (h + ((HPPA_BUS_TAG_PROTO(t))? \ + ((o) << 2) | HPPA_BUS_TAG_OFFSET(t):(o))));\ +} while (0) + +#define bus_space_write_2(t, h, o, v) do { \ + __asm __volatile ( \ + "rsm %0, %%r0\n\t" \ + "sths %1, 0(%2)\n\t" \ + "fdc %%r0(%2)\n\t" \ + "ssm %0, %%r0" \ + :: "i" (PSW_D), "r" (v), \ + "r" (h + ((HPPA_BUS_TAG_PROTO(t))? \ + ((o) << 2) | HPPA_BUS_TAG_OFFSET(t):(o))));\ +} while (0) + +#define bus_space_write_4(t, h, o, v) do { \ + __asm __volatile ( \ + "rsm %0, %%r0\n\t" \ + "stws %1, 0(%2)\n\t" \ + "fdc %%r0(%2)\n\t" \ + "ssm %0, %%r0" \ + :: "i" (PSW_D), "r" (v), \ + "r" (h + ((HPPA_BUS_TAG_PROTO(t))? \ + ((o) << 2) | HPPA_BUS_TAG_OFFSET(t):(o))));\ +} while (0) + +#if 0 +#define bus_space_write_8 +#endif + +#define bus_space_write_multi_1(t, h, o, a, c) do { \ +} while (0) + +#define bus_space_write_multi_2(t, h, o, a, c) do { \ +} while (0) + +#define bus_space_write_multi_4(t, h, o, a, c) do { \ +} while (0) + +#if 0 +#define bus_space_write_multi_8(t, h, o, a, c) +#endif + +#define bus_space_write_raw_multi_2(t, h, o, a, c) \ + bus_space_write_multi_2((t), (h), (o), (const u_int16_t *)(a), (c) >> 1) +#define bus_space_write_raw_multi_4(t, h, o, a, c) \ + bus_space_write_multi_4((t), (h), (o), (const u_int32_t *)(a), (c) >> 2) + +#if 0 +#define bus_space_write_raw_multi_8 +#endif + +#if 0 +#define bus_space_write_region_1(t, h, o, a, c) do { \ +} while (0) + +#define bus_space_write_region_2(t, h, o, a, c) do { \ +} while (0) + +#define bus_space_write_region_4(t, h, o, a, c) do { \ +} while (0) + +#define bus_space_write_region_8 +#endif + +#define bus_space_write_raw_region_2(t, h, o, a, c) \ + bus_space_write_region_2((t), (h), (o), (const u_int16_t *)(a), (c) >> 1) +#define bus_space_write_raw_region_4(t, h, o, a, c) \ + bus_space_write_region_4((t), (h), (o), (const u_int32_t *)(a), (c) >> 2) + +#if 0 +#define bus_space_write_raw_region_8 +#endif + +#if 0 +#define bus_space_set_multi_1(t, h, o, v, c) do { \ +} while (0) + +#define bus_space_set_multi_2(t, h, o, v, c) do { \ +} while (0) + +#define bus_space_set_multi_4(t, h, o, v, c) do { \ +} while (0) + +#define bus_space_set_multi_8 +#endif + +#if 0 +#define bus_space_set_region_1(t, h, o, v, c) do { \ +} while (0) + +#define bus_space_set_region_2(t, h, o, v, c) do { \ +} while (0) + +#define bus_space_set_region_4(t, h, o, v, c) do { \ +} while (0) + +#define bus_space_set_region_8 +#endif + +#if 0 +#define bus_space_copy_1(t, h1, o1, h2, o2, c) do { \ +} while (0) + +#define bus_space_copy_2(t, h1, o1, h2, o2, c) do { \ +} while (0) + +#define bus_space_copy_4(t, h1, o1, h2, o2, c) do { \ +} while (0) + +#define bus_space_copy_8 +#endif + +#endif /* _MACHINE_BUS_H_ */ + |