summaryrefslogtreecommitdiff
path: root/sys/arch/sgi/include/rbus_machdep.h
blob: c98c66b0648d4c08c29d9ccc61c76ca536c6f9bc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/*	$OpenBSD: rbus_machdep.h,v 1.1 2009/07/21 21:25:19 miod Exp $	*/

/*
 * Copyright (c) 2009 Miodrag Vallat.
 *
 * Permission to use, copy, modify, and distribute this software for any
 * purpose with or without fee is hereby granted, provided that the above
 * copyright notice and this permission notice appear in all copies.
 *
 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 */

#ifndef	_SGI_RBUS_MACHDEP_H_
#define	_SGI_RBUS_MACHDEP_H_

/*
 * RBUS mapping routines
 */

struct rb_md_fnptr {
	int	(*rbus_md_space_map)(bus_space_tag_t, bus_addr_t, bus_size_t,
		    int, bus_space_handle_t *);
	void	(*rbus_md_space_unmap)(bus_space_tag_t, bus_space_handle_t,
		    bus_size_t, bus_addr_t *);
};

static __inline__ int
md_space_map(rbus_tag_t rbt, u_long addr, bus_size_t size, int flags,
    bus_space_handle_t *bshp)
{
	struct rb_md_fnptr *fn = (struct rb_md_fnptr *)rbt->rb_md;

	return (*fn->rbus_md_space_map)(rbt->rb_bt, (bus_addr_t)addr, size,
	    flags, bshp);
}

static __inline__ void
md_space_unmap(rbus_tag_t rbt, bus_space_handle_t h, bus_size_t size,
    bus_addr_t *addrp)
{
	struct rb_md_fnptr *fn = (struct rb_md_fnptr *)rbt->rb_md;

	(*fn->rbus_md_space_unmap)(rbt->rb_bt, h, size, addrp);
}

/*
 * PCCBB RBUS allocation routines (rbus_pccbb_parent_io, rbus_pccbb_parent_mem)
 * are implemented in pci_machdep.h.
 */

#define	pccbb_attach_hook(parent, self, paa)	\
	do { /* nothing */} while (/*CONSTCOND*/0)

#endif	/* _SGI_RBUS_MACHDEP_H_ */