1*3747b72bSbsh /* $NetBSD: imx31reg.h,v 1.5 2010/11/15 18:19:19 bsh Exp $ */ 2825088edSmatt /*- 3825088edSmatt * Copyright (c) 2007 The NetBSD Foundation, Inc. 4825088edSmatt * All rights reserved. 5825088edSmatt * 6825088edSmatt * This code is derived from software contributed to The NetBSD Foundation 7825088edSmatt * by Matt Thomas. 8825088edSmatt * 9825088edSmatt * Redistribution and use in source and binary forms, with or without 10825088edSmatt * modification, are permitted provided that the following conditions 11825088edSmatt * are met: 12825088edSmatt * 1. Redistributions of source code must retain the above copyright 13825088edSmatt * notice, this list of conditions and the following disclaimer. 14825088edSmatt * 2. Redistributions in binary form must reproduce the above copyright 15825088edSmatt * notice, this list of conditions and the following disclaimer in the 16825088edSmatt * documentation and/or other materials provided with the distribution. 17825088edSmatt * 18825088edSmatt * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 19825088edSmatt * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 20825088edSmatt * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 21825088edSmatt * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 22825088edSmatt * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 23825088edSmatt * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 24825088edSmatt * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 25825088edSmatt * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 26825088edSmatt * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 27825088edSmatt * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 28825088edSmatt * POSSIBILITY OF SUCH DAMAGE. 29825088edSmatt */ 30825088edSmatt 31825088edSmatt #ifndef _ARM_IMX_IMX31REG_H_ 32825088edSmatt #define _ARM_IMX_IMX31REG_H_ 33825088edSmatt 34825088edSmatt #define I2C1_BASE 0x43f80000 35825088edSmatt #define I2C2_BASE 0x43f90000 36825088edSmatt #define I2C3_BASE 0x43f84000 37825088edSmatt 38825088edSmatt #define I2C_IADR 0x0000 /* I2C Address */ 39825088edSmatt #define I2C_IFDR 0x0004 /* I2C Frequency Divider */ 40825088edSmatt #define I2C_I2CR 0x0008 /* I2C Control */ 41825088edSmatt #define I2C_I2SR 0x000c /* I2C Status */ 42825088edSmatt #define I2C_I2DR 0x0010 /* I2C Data I/O */ 43825088edSmatt 44825088edSmatt #define ATA_BASE 0x43f8c000 45825088edSmatt #define ATA_DMA_BASE 0x50020000 46825088edSmatt 47825088edSmatt #define UART1_BASE 0x43f90000 48825088edSmatt #define UART2_BASE 0x43f94000 49825088edSmatt #define UART3_BASE 0x5000c000 50825088edSmatt #define UART4_BASE 0x43fb0000 51825088edSmatt #define UART5_BASE 0x43fb4000 52825088edSmatt 53825088edSmatt #define CSPI1_BASE 0x43fa4000 54825088edSmatt #define CSPI2_BASE 0x50010000 55825088edSmatt 56825088edSmatt #define GPIO1_BASE 0x53fcc000 57825088edSmatt #define GPIO2_BASE 0x53fd0000 58825088edSmatt #define GPIO3_BASE 0x53fa4000 5939e4a976Sbsh /* register definitions in imxgpiore.h */ 60825088edSmatt 61*3747b72bSbsh #define GPIO_NPINS 32 62*3747b72bSbsh #define GPIO_NGROUPS 3 63*3747b72bSbsh 64*3747b72bSbsh #define GPIO_NO_SCLK0 GPIO_NO(3, 2) 65*3747b72bSbsh 66*3747b72bSbsh 67*3747b72bSbsh /* EPIT */ 68*3747b72bSbsh 69*3747b72bSbsh #define EPIT1_BASE 0x53f94000 70*3747b72bSbsh #define EPIT2_BASE 0x53f98000 71*3747b72bSbsh 72*3747b72bSbsh 73825088edSmatt #define INTC_BASE 0x68000000 74825088edSmatt #define INTC_SIZE 0x0400 75825088edSmatt #define IMX31_INTCNTL 0x0000 /* Interrupt Control (RW) */ 76825088edSmatt #define IMX31_NIMASK 0x0004 /* Normal Interrupt Mask (RW) */ 77825088edSmatt #define IMX31_INTENNUM 0x0008 /* Interrupt Enable Number (RW) */ 78825088edSmatt #define IMX31_INTDISNUM 0x000c /* Interrupt Disable Number (RW) */ 79825088edSmatt #define IMX31_INTENABLEH 0x0010 /* Interrupt Enable High (RW) */ 80825088edSmatt #define IMX31_INTENABLEL 0x0014 /* Interrupt Enable Low (RW) */ 81825088edSmatt #define IMX31_INTTYPEH 0x0018 /* Interrupt Type High (RW) */ 82825088edSmatt #define IMX31_INTTYPEL 0x001c /* Interrupt Type Low (RW) */ 83825088edSmatt #define IMX31_NIPRIORITY7 0x0020 /* Normal Intr Priority Level 7 (RW) */ 84825088edSmatt #define IMX31_NIPRIORITY6 0x0024 /* Normal Intr Priority Level 6 (RW) */ 85825088edSmatt #define IMX31_NIPRIORITY5 0x0028 /* Normal Intr Priority Level 5 (RW) */ 86825088edSmatt #define IMX31_NIPRIORITY4 0x002c /* Normal Intr Priority Level 4 (RW) */ 87825088edSmatt #define IMX31_NIPRIORITY3 0x0030 /* Normal Intr Priority Level 3 (RW) */ 88825088edSmatt #define IMX31_NIPRIORITY2 0x0034 /* Normal Intr Priority Level 2 (RW) */ 89825088edSmatt #define IMX31_NIPRIORITY1 0x0038 /* Normal Intr Priority Level 1 (RW) */ 90825088edSmatt #define IMX31_NIPRIORITY0 0x003c /* Normal Intr Priority Level 0 (RW) */ 91825088edSmatt #define IMX31_NIVECSR 0x0040 /* Normal Interrupt Vector Status (R) */ 92825088edSmatt #define IMX31_FIVECSR 0x0044 /* Fast Interrupt Vector Status (R) */ 93825088edSmatt #define IMX31_INTSRCH 0x0048 /* Interrupt Source High (R) */ 94825088edSmatt #define IMX31_INTSRCL 0x004c /* Interrupt Source Low (R) */ 95825088edSmatt #define IMX31_INTFRCH 0x0050 /* Interrupt Force High (RW) */ 96825088edSmatt #define IMX31_INTFRCL 0x0054 /* Interrupt Force Low (RW) */ 97825088edSmatt #define IMX31_NIPNDH 0x0058 /* Normal Intr Pending High (R) */ 98825088edSmatt #define IMX31_NIPNDL 0x005c /* Normal Intr Pending Low (R) */ 99825088edSmatt #define IMX31_FIPNDH 0x0060 /* Fast Intr Pending High (R) */ 100825088edSmatt #define IMX31_FIPNDL 0x0064 /* Fast Intr Pending Low (R) */ 101825088edSmatt 102825088edSmatt #define IMX31_VECTOR(n) (0x0100 + (n) * 4) /* Vector [N] */ 103825088edSmatt 104825088edSmatt #define INTCNTL_ABFLAG (1 << 25) /* Core Arb. Priorty Risen (W1C) */ 105825088edSmatt #define INTCNTL_ABFEN (1 << 24) /* ABFLAG Sticky Enable */ 106825088edSmatt #define INTCNTL_NIDIS (1 << 22) /* Normal Intr. Disable */ 107825088edSmatt #define INTCNTL_FIDIS (1 << 21) /* Fast Intr. Disable */ 108825088edSmatt #define INTCNTL_NIAD (1 << 20) /* Normal Intr. Arbiter Rise ARM Lvl */ 109825088edSmatt #define INTCNTL_FIAD (1 << 19) /* Fast Intr. Arbiter Rise ARM Level */ 110825088edSmatt #define INTCNTL_NM (1 << 18) /* Normal Intr. Mode Control (1=AVIC) */ 111825088edSmatt 112825088edSmatt #define NIMASK_DIS_NONE -1 113825088edSmatt 114825088edSmatt /* 115825088edSmatt * INTTYPE (0 = IRQ, 1 = FIQ) 116825088edSmatt */ 117825088edSmatt 118825088edSmatt #endif /* _ARM_IMX_IMX31REG_H_ */ 119