hd64465var.h revision 1.4 1 1.4 martin /* $NetBSD: hd64465var.h,v 1.4 2008/04/28 20:23:22 martin Exp $ */
2 1.1 uch
3 1.1 uch /*-
4 1.1 uch * Copyright (c) 2002 The NetBSD Foundation, Inc.
5 1.1 uch * All rights reserved.
6 1.1 uch *
7 1.1 uch * This code is derived from software contributed to The NetBSD Foundation
8 1.1 uch * by UCHIYAMA Yasushi.
9 1.1 uch *
10 1.1 uch * Redistribution and use in source and binary forms, with or without
11 1.1 uch * modification, are permitted provided that the following conditions
12 1.1 uch * are met:
13 1.1 uch * 1. Redistributions of source code must retain the above copyright
14 1.1 uch * notice, this list of conditions and the following disclaimer.
15 1.1 uch * 2. Redistributions in binary form must reproduce the above copyright
16 1.1 uch * notice, this list of conditions and the following disclaimer in the
17 1.1 uch * documentation and/or other materials provided with the distribution.
18 1.1 uch *
19 1.1 uch * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.1 uch * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.1 uch * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.1 uch * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.1 uch * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.1 uch * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.1 uch * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.1 uch * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.1 uch * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.1 uch * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.1 uch * POSSIBILITY OF SUCH DAMAGE.
30 1.1 uch */
31 1.1 uch
32 1.2 uch #ifndef _HPCSH_DEV_HD64465VAR_H_
33 1.2 uch #define _HPCSH_DEV_HD64465VAR_H_
34 1.1 uch /*
35 1.1 uch * HD64465 register access macro.
36 1.1 uch */
37 1.3 uwe #define hd64465_reg_read_1(r) (*((volatile uint8_t *)(r)))
38 1.3 uwe #define hd64465_reg_write_1(r, v) (*((volatile uint8_t *)(r)) = (v))
39 1.3 uwe #define hd64465_reg_read_2(r) (*((volatile uint16_t *)(r)))
40 1.3 uwe #define hd64465_reg_write_2(r, v) (*((volatile uint16_t *)(r)) = (v))
41 1.1 uch
42 1.1 uch /*
43 1.1 uch * HD64465 modules canonical ID.
44 1.1 uch */
45 1.1 uch enum hd64465_module_id {
46 1.1 uch HD64465_MODULE_INTERFACE = 0,
47 1.1 uch HD64465_MODULE_INTC,
48 1.1 uch HD64465_MODULE_PS2IF,
49 1.1 uch HD64465_MODULE_PCMCIA,
50 1.1 uch HD64465_MODULE_AFE,
51 1.1 uch HD64465_MODULE_GPIO,
52 1.1 uch HD64465_MODULE_TIMER,
53 1.1 uch HD64465_MODULE_KBC,
54 1.1 uch HD64465_MODULE_IRDA,
55 1.1 uch HD64465_MODULE_UART,
56 1.1 uch HD64465_MODULE_PARALEL,
57 1.1 uch HD64465_MODULE_CODEC,
58 1.1 uch HD64465_MODULE_OHCI,
59 1.1 uch HD64465_MODULE_ADC
60 1.1 uch };
61 1.1 uch
62 1.1 uch struct hd64465_attach_args {
63 1.1 uch enum hd64465_module_id ha_module_id;
64 1.1 uch };
65 1.1 uch
66 1.2 uch /*
67 1.2 uch * Interrupt staff.
68 1.2 uch */
69 1.2 uch #include <hpcsh/dev/hd6446x/hd6446xintcvar.h>
70 1.2 uch void *hd64465_intr_establish(int, int, int, int (*)(void *), void *);
71 1.2 uch void hd64465_intr_disestablish(void *);
72 1.2 uch void hd64465_shutdown(void);
73 1.1 uch
74 1.2 uch #endif /* !_HPCSH_DEV_HD64465VAR_H_ */
75