at91var.h revision 238403
1/*- 2 * Copyright (c) 2005 Olivier Houchard. All rights reserved. 3 * 4 * Redistribution and use in source and binary forms, with or without 5 * modification, are permitted provided that the following conditions 6 * are met: 7 * 1. Redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer. 9 * 2. Redistributions in binary form must reproduce the above copyright 10 * notice, this list of conditions and the following disclaimer in the 11 * documentation and/or other materials provided with the distribution. 12 * 13 * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND 14 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16 * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE 17 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23 * SUCH DAMAGE. 24 */ 25 26/* $FreeBSD: head/sys/arm/at91/at91var.h 238403 2012-07-12 19:11:37Z imp $ */ 27 28#ifndef _AT91VAR_H_ 29#define _AT91VAR_H_ 30 31#include <sys/bus.h> 32#include <sys/rman.h> 33 34#include <arm/at91/at91reg.h> 35 36struct at91_softc { 37 device_t dev; 38 bus_space_tag_t sc_st; 39 bus_space_handle_t sc_sh; 40 bus_space_handle_t sc_aic_sh; 41 struct rman sc_irq_rman; 42 struct rman sc_mem_rman; 43}; 44 45struct at91_ivar { 46 struct resource_list resources; 47}; 48 49struct cpu_devs 50{ 51 const char *name; 52 int unit; 53 bus_addr_t mem_base; 54 bus_size_t mem_len; 55 int irq0; 56 int irq1; 57 int irq2; 58 const char *parent_clk; 59}; 60 61enum at91_soc_type { 62 AT91_T_NONE = 0, 63 AT91_T_CAP9, 64 AT91_T_RM9200, 65 AT91_T_SAM9260, 66 AT91_T_SAM9261, 67 AT91_T_SAM9263, 68 AT91_T_SAM9G10, 69 AT91_T_SAM9G20, 70 AT91_T_SAM9G45, 71 AT91_T_SAM9N12, 72 AT91_T_SAM9RL, 73 AT91_T_SAM9X5, 74}; 75 76enum at91_soc_subtype { 77 AT91_ST_ANY = -1, /* Match any type */ 78 AT91_ST_NONE = 0, 79 /* AT91RM9200 */ 80 AT91_ST_RM9200_BGA, 81 AT91_ST_RM9200_PQFP, 82 /* AT91SAM9260 */ 83 AT91_ST_SAM9XE, 84 /* AT91SAM9G45 */ 85 AT91_ST_SAM9G45, 86 AT91_ST_SAM9M10, 87 AT91_ST_SAM9G46, 88 AT91_ST_SAM9M11, 89 /* AT91SAM9X5 */ 90 AT91_ST_SAM9G15, 91 AT91_ST_SAM9G25, 92 AT91_ST_SAM9G35, 93 AT91_ST_SAM9X25, 94 AT91_ST_SAM9X35, 95}; 96 97enum at91_soc_family { 98 AT91_FAMILY_SAM9 = 0x19, 99 AT91_FAMILY_SAM9XE = 0x29, 100 AT91_FAMILY_RM92 = 0x92, 101}; 102 103#define AT91_SOC_NAME_MAX 50 104 105typedef void (*DELAY_t)(int); 106typedef void (*cpu_reset_t)(void); 107typedef void (*clk_init_t)(void); 108 109struct at91_soc_data { 110 DELAY_t soc_delay; 111 cpu_reset_t soc_reset; 112 clk_init_t soc_clock_init; 113 const int *soc_irq_prio; 114 const struct cpu_devs *soc_children; 115}; 116 117struct at91_soc_info { 118 enum at91_soc_type type; 119 enum at91_soc_subtype subtype; 120 enum at91_soc_family family; 121 uint32_t cidr; 122 uint32_t exid; 123 char name[AT91_SOC_NAME_MAX]; 124 uint32_t dbgu_base; 125 struct at91_soc_data *soc_data; 126}; 127 128extern struct at91_soc_info soc_info; 129 130static inline int at91_is_rm92(void); 131static inline int at91_is_sam9(void); 132static inline int at91_is_sam9xe(void); 133static inline int at91_cpu_is(u_int cpu); 134 135static inline int 136at91_is_rm92(void) 137{ 138 139 return (soc_info.type == AT91_T_RM9200); 140} 141 142static inline int 143at91_is_sam9(void) 144{ 145 146 return (soc_info.family == AT91_FAMILY_SAM9); 147} 148 149static inline int 150at91_is_sam9xe(void) 151{ 152 153 return (soc_info.family == AT91_FAMILY_SAM9XE); 154} 155 156static inline int 157at91_cpu_is(u_int cpu) 158{ 159 160 return (soc_info.type == cpu); 161} 162 163void at91_add_child(device_t dev, int prio, const char *name, int unit, 164 bus_addr_t addr, bus_size_t size, int irq0, int irq1, int irq2); 165 166extern uint32_t at91_irq_system; 167extern uint32_t at91_master_clock; 168void at91_pmc_init_clock(void); 169 170#endif /* _AT91VAR_H_ */ 171