NetBSD/sys/arch/acorn26/include/podulebus_machdep.h
bjh21 e9030bd381 Move over to using the standard ARM bus_space implementation on acorn26.
This is more flexible than the old acorn26 bus_space, which means that single
read/write operations are slower, but multi and region operations have the
potential to be faster, and particularly insane podules might be supportable.
In theory the acorn32 mainbus and podulebus code ought to be shareable, but
acorn26 needs the extra overhead of saving R14_svc on some operations so
I've made my own version for now.  Also the acorn32 bus_spaces are a mess.
2006-09-30 16:30:10 +00:00

123 lines
3.7 KiB
C

/* $NetBSD: podulebus_machdep.h,v 1.2 2006/09/30 16:30:10 bjh21 Exp $ */
/*
* Copyright (c) 1995 Mark Brinicombe.
* Copyright (c) 1995 Brini.
* 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 Brini.
* 4. The name of the company nor the name of the author may be used to
* endorse or promote products derived from this software without specific
* prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY BRINI ``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 BRINI 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.
*
* RiscBSD kernel project
*
* podulebus.h
*
* Podule bus header file
*
* Created : 26/04/95
*/
#include <sys/param.h>
#include <machine/bus.h>
struct podulebus_chunk {
int pc_type;
int pc_length;
int pc_offset;
int pc_useloader;
};
typedef int podulebus_intr_handle_t;
struct podulebus_attach_args {
/* bus_space references for the (many) podule spaces */
bus_space_tag_t pa_easi_t;
bus_space_handle_t pa_easi_h;
bus_space_tag_t pa_mod_t;
bus_space_handle_t pa_mod_h;
bus_space_tag_t pa_fast_t;
bus_space_handle_t pa_fast_h;
bus_space_tag_t pa_medium_t;
bus_space_handle_t pa_medium_h;
bus_space_tag_t pa_slow_t;
bus_space_handle_t pa_slow_h;
bus_space_tag_t pa_sync_t;
bus_space_handle_t pa_sync_h;
/* Same things as raw addresses (arm32 compat) */
bus_addr_t pa_easi_base;
bus_addr_t pa_mod_base;
bus_addr_t pa_fast_base;
bus_addr_t pa_medium_base;
bus_addr_t pa_slow_base;
bus_addr_t pa_sync_base;
podulebus_intr_handle_t pa_ih;
int pa_slotnum;
int pa_ecid;
int pa_flags1;
int pa_manufacturer;
int pa_product;
struct podulebus_chunk *pa_chunks;
int pa_nchunks;
char *pa_descr;
void *pa_loader;
int pa_slotflags;
#define PA_SLOT_EASI 0x01 /* EASI space available */
};
#define IS_PODULE(pa, man, prod) \
((pa)->pa_manufacturer == (man) && (pa)->pa_product == (prod))
/* Set the address-bus shift for a bus_space tag. */
#define podulebus_shift_tag(tag, shift, tagp) bus_space_shift(tag, shift, tagp)
#ifdef _KERNEL
struct evcnt;
extern void *podulebus_irq_establish(podulebus_intr_handle_t, int,
int (*)(void *), void *, struct evcnt *);
#endif
/* arm32 compatibility */
#define WriteByte(a, v) bus_space_write_1(2, (a), 0, (v))
#define WriteShort(a, v) bus_space_write_2(2, (a), 0, (v))
#define ReadByte(a) bus_space_read_1(2, (a), 0)
#define ReadShort(a) bus_space_read_2(2, (a), 0)
/* XXX The arm32 version ignores "slot" too. */
#define matchpodule(pa, man, prod, slot) IS_PODULE(pa, man, prod)
/* end arm32 compatibility */
/* End of podulebus.h */