NetBSD/sys/arch/alpha/include/bus.h
cgd ff0a52ccd9 define bus_io_{read,write}_multi_{1,2,4,8} functions, which read/write
multiple values from a single I/O port in to/out of an array of values.
1996-04-18 05:47:29 +00:00

203 lines
7.3 KiB
C

/* $NetBSD: bus.h,v 1.2 1996/04/18 05:47:29 cgd Exp $ */
/*
* Copyright (c) 1996 Carnegie-Mellon University.
* All rights reserved.
*
* Author: Chris G. Demetriou
*
* Permission to use, copy, modify and distribute this software and
* its documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie the
* rights to redistribute these changes.
*/
#ifndef _ALPHA_BUS_H_
#define _ALPHA_BUS_H_
/*
* I/O addresses (in bus space)
*/
typedef u_long bus_io_addr_t;
typedef u_long bus_io_size_t;
/*
* Memory addresses (in bus space)
*/
typedef u_long bus_mem_addr_t;
typedef u_long bus_mem_size_t;
/*
* Access methods for bus resources, I/O space, and memory space.
*/
typedef struct alpha_bus_chipset *bus_chipset_tag_t;
typedef u_long bus_io_handle_t;
typedef u_long bus_mem_handle_t;
struct alpha_bus_chipset {
/* I/O-space cookie */
void *bc_i_v;
/* I/O-space control functions */
int (*bc_i_map) __P((void *v, bus_io_addr_t port,
bus_io_size_t size, bus_io_handle_t *iohp));
void (*bc_i_unmap) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t size));
/* I/O-space read functions */
u_int8_t (*bc_ir1) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off));
u_int16_t (*bc_ir2) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off));
u_int32_t (*bc_ir4) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off));
u_int64_t (*bc_ir8) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off));
/* I/O-space read-multiple functions */
void (*bc_irm1) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int8_t *addr,
bus_io_size_t count));
void (*bc_irm2) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int16_t *addr,
bus_io_size_t count));
void (*bc_irm4) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int32_t *addr,
bus_io_size_t count));
void (*bc_irm8) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int64_t *addr,
bus_io_size_t count));
/* I/O-space write functions */
void (*bc_iw1) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int8_t val));
void (*bc_iw2) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int16_t val));
void (*bc_iw4) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int32_t val));
void (*bc_iw8) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, u_int64_t val));
/* I/O-space write-multiple functions */
void (*bc_iwm1) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, const u_int8_t *addr,
bus_io_size_t count));
void (*bc_iwm2) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, const u_int16_t *addr,
bus_io_size_t count));
void (*bc_iwm4) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, const u_int32_t *addr,
bus_io_size_t count));
void (*bc_iwm8) __P((void *v, bus_io_handle_t ioh,
bus_io_size_t off, const u_int64_t *addr,
bus_io_size_t count));
/* Mem-space cookie */
void *bc_m_v;
/* Mem-space control functions */
int (*bc_m_map) __P((void *v, bus_mem_addr_t buspa,
bus_mem_size_t size, int cacheable,
bus_mem_handle_t *mhp));
void (*bc_m_unmap) __P((void *v, bus_mem_handle_t mh,
bus_mem_size_t size));
/* Mem-space read functions */
u_int8_t (*bc_mr1) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off));
u_int16_t (*bc_mr2) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off));
u_int32_t (*bc_mr4) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off));
u_int64_t (*bc_mr8) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off));
/* Mem-space write functions */
void (*bc_mw1) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off, u_int8_t val));
void (*bc_mw2) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off, u_int16_t val));
void (*bc_mw4) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off, u_int32_t val));
void (*bc_mw8) __P((void *v, bus_mem_handle_t memh,
bus_mem_size_t off, u_int64_t val));
};
#define __bc_CONCAT(A,B) __CONCAT(A,B)
#define __bc_ABC(A,B,C) __bc_CONCAT(A,__bc_CONCAT(B,C))
#define __bc_ABCD(A,B,C,D) __bc_CONCAT(__bc_ABC(A,B,C),D)
#define __bc_rd(t, h, o, sz, sp) \
(*(t)->__bc_ABCD(bc_,sp,r,sz))((t)->__bc_ABC(bc_,sp,_v), h, o)
#define __bc_wr(t, h, o, v, sz, sp) \
(*(t)->__bc_ABCD(bc_,sp,w,sz))((t)->__bc_ABC(bc_,sp,_v), h, o, v)
#define bus_io_map(t, port, size, iohp) \
(*(t)->bc_i_map)((t)->bc_i_v, (port), (size), (iohp))
#define bus_io_unmap(t, ioh, size) \
(*(t)->bc_i_unmap)((t)->bc_i_v, (ioh), (size))
#define __bc_io_multi(t, h, o, a, s, dir, sz) \
(*(t)->__bc_ABCD(bc_i,dir,m,sz))((t)->bc_i_v, h, o, a, s)
#define bus_io_read_1(t, h, o) __bc_rd((t),(h),(o),1,i)
#define bus_io_read_2(t, h, o) __bc_rd((t),(h),(o),2,i)
#define bus_io_read_4(t, h, o) __bc_rd((t),(h),(o),4,i)
#define bus_io_read_8(t, h, o) __bc_rd((t),(h),(o),8,i)
#define bus_io_read_multi_1(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),r,1)
#define bus_io_read_multi_2(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),r,2)
#define bus_io_read_multi_4(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),r,4)
#define bus_io_read_multi_8(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),r,8)
#define bus_io_write_1(t, h, o, v) __bc_wr((t),(h),(o),(v),1,i)
#define bus_io_write_2(t, h, o, v) __bc_wr((t),(h),(o),(v),2,i)
#define bus_io_write_4(t, h, o, v) __bc_wr((t),(h),(o),(v),4,i)
#define bus_io_write_8(t, h, o, v) __bc_wr((t),(h),(o),(v),8,i)
#define bus_io_write_multi_1(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),w,1)
#define bus_io_write_multi_2(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),w,2)
#define bus_io_write_multi_4(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),w,4)
#define bus_io_write_multi_8(t, h, o, a, s) \
__bc_io_multi((t),(h),(o),(a),(s),w,8)
#define bus_mem_map(t, bpa, size, cacheable, mhp) \
(*(t)->bc_m_map)((t)->bc_m_v, (bpa), (size), (cacheable), (mhp))
#define bus_mem_unmap(t, memh, size) \
(*(t)->bc_m_unmap)((t)->bc_m_v, (memh), (size))
#define bus_mem_read_1(t, h, o) __bc_rd((t),(h),(o),1,m)
#define bus_mem_read_2(t, h, o) __bc_rd((t),(h),(o),2,m)
#define bus_mem_read_4(t, h, o) __bc_rd((t),(h),(o),4,m)
#define bus_mem_read_8(t, h, o) __bc_rd((t),(h),(o),8,m)
#define bus_mem_write_1(t, h, o, v) __bc_wr((t),(h),(o),(v),1,m)
#define bus_mem_write_2(t, h, o, v) __bc_wr((t),(h),(o),(v),2,m)
#define bus_mem_write_4(t, h, o, v) __bc_wr((t),(h),(o),(v),4,m)
#define bus_mem_write_8(t, h, o, v) __bc_wr((t),(h),(o),(v),8,m)
#endif /* _ALPHA_BUS_H_ */