avionic design with actual uboot and tooling
submodule of avionic design uboot bootloader and with included tools to get you started , read readme.md and readme-tk1-loader.md
This commit is contained in:
112
u-boot/arch/arm/include/asm/arch-pxa/bitfield.h
Normal file
112
u-boot/arch/arm/include/asm/arch-pxa/bitfield.h
Normal file
@@ -0,0 +1,112 @@
|
||||
/*
|
||||
* FILE bitfield.h
|
||||
*
|
||||
* Version 1.1
|
||||
* Author Copyright (c) Marc A. Viredaz, 1998
|
||||
* DEC Western Research Laboratory, Palo Alto, CA
|
||||
* Date April 1998 (April 1997)
|
||||
* System Advanced RISC Machine (ARM)
|
||||
* Language C or ARM Assembly
|
||||
* Purpose Definition of macros to operate on bit fields.
|
||||
*/
|
||||
|
||||
|
||||
#ifndef __BITFIELD_H
|
||||
#define __BITFIELD_H
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
#define UData(Data) ((unsigned long) (Data))
|
||||
#else
|
||||
#define UData(Data) (Data)
|
||||
#endif
|
||||
|
||||
|
||||
/*
|
||||
* MACRO: Fld
|
||||
*
|
||||
* Purpose
|
||||
* The macro "Fld" encodes a bit field, given its size and its shift value
|
||||
* with respect to bit 0.
|
||||
*
|
||||
* Note
|
||||
* A more intuitive way to encode bit fields would have been to use their
|
||||
* mask. However, extracting size and shift value information from a bit
|
||||
* field's mask is cumbersome and might break the assembler (255-character
|
||||
* line-size limit).
|
||||
*
|
||||
* Input
|
||||
* Size Size of the bit field, in number of bits.
|
||||
* Shft Shift value of the bit field with respect to bit 0.
|
||||
*
|
||||
* Output
|
||||
* Fld Encoded bit field.
|
||||
*/
|
||||
|
||||
#define Fld(Size, Shft) (((Size) << 16) + (Shft))
|
||||
|
||||
|
||||
/*
|
||||
* MACROS: FSize, FShft, FMsk, FAlnMsk, F1stBit
|
||||
*
|
||||
* Purpose
|
||||
* The macros "FSize", "FShft", "FMsk", "FAlnMsk", and "F1stBit" return
|
||||
* the size, shift value, mask, aligned mask, and first bit of a
|
||||
* bit field.
|
||||
*
|
||||
* Input
|
||||
* Field Encoded bit field (using the macro "Fld").
|
||||
*
|
||||
* Output
|
||||
* FSize Size of the bit field, in number of bits.
|
||||
* FShft Shift value of the bit field with respect to bit 0.
|
||||
* FMsk Mask for the bit field.
|
||||
* FAlnMsk Mask for the bit field, aligned on bit 0.
|
||||
* F1stBit First bit of the bit field.
|
||||
*/
|
||||
|
||||
#define FSize(Field) ((Field) >> 16)
|
||||
#define FShft(Field) ((Field) & 0x0000FFFF)
|
||||
#define FMsk(Field) (((UData (1) << FSize (Field)) - 1) << FShft (Field))
|
||||
#define FAlnMsk(Field) ((UData (1) << FSize (Field)) - 1)
|
||||
#define F1stBit(Field) (UData (1) << FShft (Field))
|
||||
|
||||
|
||||
/*
|
||||
* MACRO: FInsrt
|
||||
*
|
||||
* Purpose
|
||||
* The macro "FInsrt" inserts a value into a bit field by shifting the
|
||||
* former appropriately.
|
||||
*
|
||||
* Input
|
||||
* Value Bit-field value.
|
||||
* Field Encoded bit field (using the macro "Fld").
|
||||
*
|
||||
* Output
|
||||
* FInsrt Bit-field value positioned appropriately.
|
||||
*/
|
||||
|
||||
#define FInsrt(Value, Field) \
|
||||
(UData (Value) << FShft (Field))
|
||||
|
||||
|
||||
/*
|
||||
* MACRO: FExtr
|
||||
*
|
||||
* Purpose
|
||||
* The macro "FExtr" extracts the value of a bit field by masking and
|
||||
* shifting it appropriately.
|
||||
*
|
||||
* Input
|
||||
* Data Data containing the bit-field to be extracted.
|
||||
* Field Encoded bit field (using the macro "Fld").
|
||||
*
|
||||
* Output
|
||||
* FExtr Bit-field value.
|
||||
*/
|
||||
|
||||
#define FExtr(Data, Field) \
|
||||
((UData (Data) >> FShft (Field)) & FAlnMsk (Field))
|
||||
|
||||
|
||||
#endif /* __BITFIELD_H */
|
||||
25
u-boot/arch/arm/include/asm/arch-pxa/config.h
Normal file
25
u-boot/arch/arm/include/asm/arch-pxa/config.h
Normal file
@@ -0,0 +1,25 @@
|
||||
/*
|
||||
* Copyright (C) 2014 Andrew Ruder <andrew.ruder@elecsyscorp.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef _ASM_ARM_PXA_CONFIG_
|
||||
#define _ASM_ARM_PXA_CONFIG_
|
||||
|
||||
#include <asm/arch/pxa-regs.h>
|
||||
|
||||
/*
|
||||
* Generic timer support
|
||||
*/
|
||||
#if defined(CONFIG_CPU_PXA27X) || defined(CONFIG_CPU_MONAHANS)
|
||||
#define CONFIG_SYS_TIMER_RATE 3250000
|
||||
#elif defined(CONFIG_CPU_PXA25X)
|
||||
#define CONFIG_SYS_TIMER_RATE 3686400
|
||||
#else
|
||||
#error "Timer frequency unknown - please config PXA CPU type"
|
||||
#endif
|
||||
|
||||
#define CONFIG_SYS_TIMER_COUNTER OSCR
|
||||
|
||||
#endif /* _ASM_ARM_PXA_CONFIG_ */
|
||||
111
u-boot/arch/arm/include/asm/arch-pxa/hardware.h
Normal file
111
u-boot/arch/arm/include/asm/arch-pxa/hardware.h
Normal file
@@ -0,0 +1,111 @@
|
||||
/*
|
||||
* linux/include/asm-arm/arch-pxa/hardware.h
|
||||
*
|
||||
* Author: Nicolas Pitre
|
||||
* Created: Jun 15, 2001
|
||||
* Copyright: MontaVista Software Inc.
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License version 2 as
|
||||
* published by the Free Software Foundation.
|
||||
*
|
||||
* Note: This file was taken from linux-2.4.19-rmk4-pxa1
|
||||
*
|
||||
* - 2003/01/20 implementation specifics activated
|
||||
* Robert Schwebel <r.schwebel@pengutronix.de>
|
||||
*/
|
||||
|
||||
#ifndef __ASM_ARCH_HARDWARE_H
|
||||
#define __ASM_ARCH_HARDWARE_H
|
||||
|
||||
#include <asm/mach-types.h>
|
||||
|
||||
/*
|
||||
* Define CONFIG_CPU_MONAHANS in case some CPU of the PXA3xx family is selected.
|
||||
* PXA300/310/320 all have distinct register mappings in some cases, that's why
|
||||
* the exact CPU has to be selected. CONFIG_CPU_MONAHANS is a helper for common
|
||||
* drivers and compatibility glue with old source then.
|
||||
*/
|
||||
#ifndef CONFIG_CPU_MONAHANS
|
||||
#if defined(CONFIG_CPU_PXA300) || \
|
||||
defined(CONFIG_CPU_PXA310) || \
|
||||
defined(CONFIG_CPU_PXA320)
|
||||
#define CONFIG_CPU_MONAHANS
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/*
|
||||
* These are statically mapped PCMCIA IO space for designs using it as a
|
||||
* generic IO bus, typically with ISA parts, hardwired IDE interfaces, etc.
|
||||
* The actual PCMCIA code is mapping required IO region at run time.
|
||||
*/
|
||||
#define PCMCIA_IO_0_BASE 0xf6000000
|
||||
#define PCMCIA_IO_1_BASE 0xf7000000
|
||||
|
||||
|
||||
/*
|
||||
* We requires absolute addresses.
|
||||
*/
|
||||
#define PCIO_BASE 0
|
||||
|
||||
/*
|
||||
* Workarounds for at least 2 errata so far require this.
|
||||
* The mapping is set in mach-pxa/generic.c.
|
||||
*/
|
||||
#define UNCACHED_PHYS_0 0xff000000
|
||||
#define UNCACHED_ADDR UNCACHED_PHYS_0
|
||||
|
||||
/*
|
||||
* Intel PXA internal I/O mappings:
|
||||
*
|
||||
* 0x40000000 - 0x41ffffff <--> 0xf8000000 - 0xf9ffffff
|
||||
* 0x44000000 - 0x45ffffff <--> 0xfa000000 - 0xfbffffff
|
||||
* 0x48000000 - 0x49ffffff <--> 0xfc000000 - 0xfdffffff
|
||||
*/
|
||||
|
||||
#include "pxa-regs.h"
|
||||
|
||||
#ifndef __ASSEMBLY__
|
||||
|
||||
/*
|
||||
* GPIO edge detection for IRQs:
|
||||
* IRQs are generated on Falling-Edge, Rising-Edge, or both.
|
||||
* This must be called *before* the corresponding IRQ is registered.
|
||||
* Use this instead of directly setting GRER/GFER.
|
||||
*/
|
||||
#define GPIO_FALLING_EDGE 1
|
||||
#define GPIO_RISING_EDGE 2
|
||||
#define GPIO_BOTH_EDGES 3
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
/*
|
||||
* Implementation specifics
|
||||
*/
|
||||
|
||||
#ifdef CONFIG_ARCH_LUBBOCK
|
||||
#include "lubbock.h"
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_PXA_IDP
|
||||
#include "idp.h"
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_PXA_CERF
|
||||
#include "cerf.h"
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_CSB226
|
||||
#include "csb226.h"
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_INNOKOM
|
||||
#include "innokom.h"
|
||||
#endif
|
||||
|
||||
#ifdef CONFIG_ARCH_PLEB
|
||||
#include "pleb.h"
|
||||
#endif
|
||||
|
||||
#endif /* _ASM_ARCH_HARDWARE_H */
|
||||
2635
u-boot/arch/arm/include/asm/arch-pxa/pxa-regs.h
Normal file
2635
u-boot/arch/arm/include/asm/arch-pxa/pxa-regs.h
Normal file
File diff suppressed because it is too large
Load Diff
29
u-boot/arch/arm/include/asm/arch-pxa/pxa.h
Normal file
29
u-boot/arch/arm/include/asm/arch-pxa/pxa.h
Normal file
@@ -0,0 +1,29 @@
|
||||
/*
|
||||
* PXA common functions
|
||||
*
|
||||
* Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __PXA_H__
|
||||
#define __PXA_H__
|
||||
|
||||
#define PXA255_A0 0x00000106
|
||||
#define PXA250_C0 0x00000105
|
||||
#define PXA250_B2 0x00000104
|
||||
#define PXA250_B1 0x00000103
|
||||
#define PXA250_B0 0x00000102
|
||||
#define PXA250_A1 0x00000101
|
||||
#define PXA250_A0 0x00000100
|
||||
#define PXA210_C0 0x00000125
|
||||
#define PXA210_B2 0x00000124
|
||||
#define PXA210_B1 0x00000123
|
||||
#define PXA210_B0 0x00000122
|
||||
|
||||
int cpu_is_pxa25x(void);
|
||||
int cpu_is_pxa27x(void);
|
||||
uint32_t pxa_get_cpu_revision(void);
|
||||
void pxa2xx_dram_init(void);
|
||||
|
||||
#endif /* __PXA_H__ */
|
||||
141
u-boot/arch/arm/include/asm/arch-pxa/regs-mmc.h
Normal file
141
u-boot/arch/arm/include/asm/arch-pxa/regs-mmc.h
Normal file
@@ -0,0 +1,141 @@
|
||||
/*
|
||||
* Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __REGS_MMC_H__
|
||||
#define __REGS_MMC_H__
|
||||
|
||||
#define MMC0_BASE 0x41100000
|
||||
#define MMC1_BASE 0x42000000
|
||||
|
||||
int pxa_mmc_register(int card_index);
|
||||
|
||||
struct pxa_mmc_regs {
|
||||
uint32_t strpcl;
|
||||
uint32_t stat;
|
||||
uint32_t clkrt;
|
||||
uint32_t spi;
|
||||
uint32_t cmdat;
|
||||
uint32_t resto;
|
||||
uint32_t rdto;
|
||||
uint32_t blklen;
|
||||
uint32_t nob;
|
||||
uint32_t prtbuf;
|
||||
uint32_t i_mask;
|
||||
uint32_t i_reg;
|
||||
uint32_t cmd;
|
||||
uint32_t argh;
|
||||
uint32_t argl;
|
||||
uint32_t res;
|
||||
uint32_t rxfifo;
|
||||
uint32_t txfifo;
|
||||
};
|
||||
|
||||
/* MMC_STRPCL */
|
||||
#define MMC_STRPCL_STOP_CLK (1 << 0)
|
||||
#define MMC_STRPCL_START_CLK (1 << 1)
|
||||
|
||||
/* MMC_STAT */
|
||||
#define MMC_STAT_END_CMD_RES (1 << 13)
|
||||
#define MMC_STAT_PRG_DONE (1 << 12)
|
||||
#define MMC_STAT_DATA_TRAN_DONE (1 << 11)
|
||||
#define MMC_STAT_CLK_EN (1 << 8)
|
||||
#define MMC_STAT_RECV_FIFO_FULL (1 << 7)
|
||||
#define MMC_STAT_XMIT_FIFO_EMPTY (1 << 6)
|
||||
#define MMC_STAT_RES_CRC_ERROR (1 << 5)
|
||||
#define MMC_STAT_SPI_READ_ERROR_TOKEN (1 << 4)
|
||||
#define MMC_STAT_CRC_READ_ERROR (1 << 3)
|
||||
#define MMC_STAT_CRC_WRITE_ERROR (1 << 2)
|
||||
#define MMC_STAT_TIME_OUT_RESPONSE (1 << 1)
|
||||
#define MMC_STAT_READ_TIME_OUT (1 << 0)
|
||||
|
||||
/* MMC_CLKRT */
|
||||
#define MMC_CLKRT_20MHZ 0
|
||||
#define MMC_CLKRT_10MHZ 1
|
||||
#define MMC_CLKRT_5MHZ 2
|
||||
#define MMC_CLKRT_2_5MHZ 3
|
||||
#define MMC_CLKRT_1_25MHZ 4
|
||||
#define MMC_CLKRT_0_625MHZ 5
|
||||
#define MMC_CLKRT_0_3125MHZ 6
|
||||
|
||||
/* MMC_SPI */
|
||||
#define MMC_SPI_EN (1 << 0)
|
||||
#define MMC_SPI_CS_EN (1 << 2)
|
||||
#define MMC_SPI_CS_ADDRESS (1 << 3)
|
||||
#define MMC_SPI_CRC_ON (1 << 1)
|
||||
|
||||
/* MMC_CMDAT */
|
||||
#define MMC_CMDAT_SD_4DAT (1 << 8)
|
||||
#define MMC_CMDAT_MMC_DMA_EN (1 << 7)
|
||||
#define MMC_CMDAT_INIT (1 << 6)
|
||||
#define MMC_CMDAT_BUSY (1 << 5)
|
||||
#define MMC_CMDAT_BCR (MMC_CMDAT_BUSY | MMC_CMDAT_INIT)
|
||||
#define MMC_CMDAT_STREAM (1 << 4)
|
||||
#define MMC_CMDAT_WRITE (1 << 3)
|
||||
#define MMC_CMDAT_DATA_EN (1 << 2)
|
||||
#define MMC_CMDAT_R0 0
|
||||
#define MMC_CMDAT_R1 1
|
||||
#define MMC_CMDAT_R2 2
|
||||
#define MMC_CMDAT_R3 3
|
||||
|
||||
/* MMC_RESTO */
|
||||
#define MMC_RES_TO_MAX_MASK 0x7f
|
||||
|
||||
/* MMC_RDTO */
|
||||
#define MMC_READ_TO_MAX_MASK 0xffff
|
||||
|
||||
/* MMC_BLKLEN */
|
||||
#define MMC_BLK_LEN_MAX_MASK 0x3ff
|
||||
|
||||
/* MMC_PRTBUF */
|
||||
#define MMC_PRTBUF_BUF_PART_FULL (1 << 0)
|
||||
|
||||
/* MMC_I_MASK */
|
||||
#define MMC_I_MASK_TXFIFO_WR_REQ (1 << 6)
|
||||
#define MMC_I_MASK_RXFIFO_RD_REQ (1 << 5)
|
||||
#define MMC_I_MASK_CLK_IS_OFF (1 << 4)
|
||||
#define MMC_I_MASK_STOP_CMD (1 << 3)
|
||||
#define MMC_I_MASK_END_CMD_RES (1 << 2)
|
||||
#define MMC_I_MASK_PRG_DONE (1 << 1)
|
||||
#define MMC_I_MASK_DATA_TRAN_DONE (1 << 0)
|
||||
#define MMC_I_MASK_ALL 0x7f
|
||||
|
||||
|
||||
/* MMC_I_REG */
|
||||
#define MMC_I_REG_TXFIFO_WR_REQ (1 << 6)
|
||||
#define MMC_I_REG_RXFIFO_RD_REQ (1 << 5)
|
||||
#define MMC_I_REG_CLK_IS_OFF (1 << 4)
|
||||
#define MMC_I_REG_STOP_CMD (1 << 3)
|
||||
#define MMC_I_REG_END_CMD_RES (1 << 2)
|
||||
#define MMC_I_REG_PRG_DONE (1 << 1)
|
||||
#define MMC_I_REG_DATA_TRAN_DONE (1 << 0)
|
||||
|
||||
/* MMC_CMD */
|
||||
#define MMC_CMD_INDEX_MAX 0x6f
|
||||
|
||||
#define MMC_R1_IDLE_STATE 0x01
|
||||
#define MMC_R1_ERASE_STATE 0x02
|
||||
#define MMC_R1_ILLEGAL_CMD 0x04
|
||||
#define MMC_R1_COM_CRC_ERR 0x08
|
||||
#define MMC_R1_ERASE_SEQ_ERR 0x01
|
||||
#define MMC_R1_ADDR_ERR 0x02
|
||||
#define MMC_R1_PARAM_ERR 0x04
|
||||
|
||||
#define MMC_R1B_WP_ERASE_SKIP 0x0002
|
||||
#define MMC_R1B_ERR 0x0004
|
||||
#define MMC_R1B_CC_ERR 0x0008
|
||||
#define MMC_R1B_CARD_ECC_ERR 0x0010
|
||||
#define MMC_R1B_WP_VIOLATION 0x0020
|
||||
#define MMC_R1B_ERASE_PARAM 0x0040
|
||||
#define MMC_R1B_OOR 0x0080
|
||||
#define MMC_R1B_IDLE_STATE 0x0100
|
||||
#define MMC_R1B_ERASE_RESET 0x0200
|
||||
#define MMC_R1B_ILLEGAL_CMD 0x0400
|
||||
#define MMC_R1B_COM_CRC_ERR 0x0800
|
||||
#define MMC_R1B_ERASE_SEQ_ERR 0x1000
|
||||
#define MMC_R1B_ADDR_ERR 0x2000
|
||||
#define MMC_R1B_PARAM_ERR 0x4000
|
||||
|
||||
#endif /* __REGS_MMC_H__ */
|
||||
96
u-boot/arch/arm/include/asm/arch-pxa/regs-uart.h
Normal file
96
u-boot/arch/arm/include/asm/arch-pxa/regs-uart.h
Normal file
@@ -0,0 +1,96 @@
|
||||
/*
|
||||
* Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __REGS_UART_H__
|
||||
#define __REGS_UART_H__
|
||||
|
||||
#define FFUART_BASE 0x40100000
|
||||
#define BTUART_BASE 0x40200000
|
||||
#define STUART_BASE 0x40700000
|
||||
#define HWUART_BASE 0x41600000
|
||||
|
||||
struct pxa_uart_regs {
|
||||
union {
|
||||
uint32_t thr;
|
||||
uint32_t rbr;
|
||||
uint32_t dll;
|
||||
};
|
||||
union {
|
||||
uint32_t ier;
|
||||
uint32_t dlh;
|
||||
};
|
||||
union {
|
||||
uint32_t fcr;
|
||||
uint32_t iir;
|
||||
};
|
||||
uint32_t lcr;
|
||||
uint32_t mcr;
|
||||
uint32_t lsr;
|
||||
uint32_t msr;
|
||||
uint32_t spr;
|
||||
uint32_t isr;
|
||||
};
|
||||
|
||||
#define IER_DMAE (1 << 7)
|
||||
#define IER_UUE (1 << 6)
|
||||
#define IER_NRZE (1 << 5)
|
||||
#define IER_RTIOE (1 << 4)
|
||||
#define IER_MIE (1 << 3)
|
||||
#define IER_RLSE (1 << 2)
|
||||
#define IER_TIE (1 << 1)
|
||||
#define IER_RAVIE (1 << 0)
|
||||
|
||||
#define IIR_FIFOES1 (1 << 7)
|
||||
#define IIR_FIFOES0 (1 << 6)
|
||||
#define IIR_TOD (1 << 3)
|
||||
#define IIR_IID2 (1 << 2)
|
||||
#define IIR_IID1 (1 << 1)
|
||||
#define IIR_IP (1 << 0)
|
||||
|
||||
#define FCR_ITL2 (1 << 7)
|
||||
#define FCR_ITL1 (1 << 6)
|
||||
#define FCR_RESETTF (1 << 2)
|
||||
#define FCR_RESETRF (1 << 1)
|
||||
#define FCR_TRFIFOE (1 << 0)
|
||||
#define FCR_ITL_1 0
|
||||
#define FCR_ITL_8 (FCR_ITL1)
|
||||
#define FCR_ITL_16 (FCR_ITL2)
|
||||
#define FCR_ITL_32 (FCR_ITL2|FCR_ITL1)
|
||||
|
||||
#define LCR_DLAB (1 << 7)
|
||||
#define LCR_SB (1 << 6)
|
||||
#define LCR_STKYP (1 << 5)
|
||||
#define LCR_EPS (1 << 4)
|
||||
#define LCR_PEN (1 << 3)
|
||||
#define LCR_STB (1 << 2)
|
||||
#define LCR_WLS1 (1 << 1)
|
||||
#define LCR_WLS0 (1 << 0)
|
||||
|
||||
#define LSR_FIFOE (1 << 7)
|
||||
#define LSR_TEMT (1 << 6)
|
||||
#define LSR_TDRQ (1 << 5)
|
||||
#define LSR_BI (1 << 4)
|
||||
#define LSR_FE (1 << 3)
|
||||
#define LSR_PE (1 << 2)
|
||||
#define LSR_OE (1 << 1)
|
||||
#define LSR_DR (1 << 0)
|
||||
|
||||
#define MCR_LOOP (1 << 4)
|
||||
#define MCR_OUT2 (1 << 3)
|
||||
#define MCR_OUT1 (1 << 2)
|
||||
#define MCR_RTS (1 << 1)
|
||||
#define MCR_DTR (1 << 0)
|
||||
|
||||
#define MSR_DCD (1 << 7)
|
||||
#define MSR_RI (1 << 6)
|
||||
#define MSR_DSR (1 << 5)
|
||||
#define MSR_CTS (1 << 4)
|
||||
#define MSR_DDCD (1 << 3)
|
||||
#define MSR_TERI (1 << 2)
|
||||
#define MSR_DDSR (1 << 1)
|
||||
#define MSR_DCTS (1 << 0)
|
||||
|
||||
#endif /* __REGS_UART_H__ */
|
||||
147
u-boot/arch/arm/include/asm/arch-pxa/regs-usb.h
Normal file
147
u-boot/arch/arm/include/asm/arch-pxa/regs-usb.h
Normal file
@@ -0,0 +1,147 @@
|
||||
/*
|
||||
* PXA25x UDC definitions
|
||||
*
|
||||
* Copyright (C) 2012 Łukasz Dałek <luk0104@gmail.com>
|
||||
*
|
||||
* SPDX-License-Identifier: GPL-2.0+
|
||||
*/
|
||||
|
||||
#ifndef __REGS_USB_H__
|
||||
#define __REGS_USB_H__
|
||||
|
||||
struct pxa25x_udc_regs {
|
||||
/* UDC Control Register */
|
||||
uint32_t udccr; /* 0x000 */
|
||||
uint32_t reserved1;
|
||||
|
||||
/* UDC Control Function Register */
|
||||
uint32_t udccfr; /* 0x008 */
|
||||
uint32_t reserved2;
|
||||
|
||||
/* UDC Endpoint Control/Status Registers */
|
||||
uint32_t udccs[16]; /* 0x010 - 0x04c */
|
||||
|
||||
/* UDC Interrupt Control/Status Registers */
|
||||
uint32_t uicr0; /* 0x050 */
|
||||
uint32_t uicr1; /* 0x054 */
|
||||
uint32_t usir0; /* 0x058 */
|
||||
uint32_t usir1; /* 0x05c */
|
||||
|
||||
/* UDC Frame Number/Byte Count Registers */
|
||||
uint32_t ufnrh; /* 0x060 */
|
||||
uint32_t ufnrl; /* 0x064 */
|
||||
uint32_t ubcr2; /* 0x068 */
|
||||
uint32_t ubcr4; /* 0x06c */
|
||||
uint32_t ubcr7; /* 0x070 */
|
||||
uint32_t ubcr9; /* 0x074 */
|
||||
uint32_t ubcr12; /* 0x078 */
|
||||
uint32_t ubcr14; /* 0x07c */
|
||||
|
||||
/* UDC Endpoint Data Registers */
|
||||
uint32_t uddr0; /* 0x080 */
|
||||
uint32_t reserved3[7];
|
||||
uint32_t uddr5; /* 0x0a0 */
|
||||
uint32_t reserved4[7];
|
||||
uint32_t uddr10; /* 0x0c0 */
|
||||
uint32_t reserved5[7];
|
||||
uint32_t uddr15; /* 0x0e0 */
|
||||
uint32_t reserved6[7];
|
||||
uint32_t uddr1; /* 0x100 */
|
||||
uint32_t reserved7[31];
|
||||
uint32_t uddr2; /* 0x180 */
|
||||
uint32_t reserved8[31];
|
||||
uint32_t uddr3; /* 0x200 */
|
||||
uint32_t reserved9[127];
|
||||
uint32_t uddr4; /* 0x400 */
|
||||
uint32_t reserved10[127];
|
||||
uint32_t uddr6; /* 0x600 */
|
||||
uint32_t reserved11[31];
|
||||
uint32_t uddr7; /* 0x680 */
|
||||
uint32_t reserved12[31];
|
||||
uint32_t uddr8; /* 0x700 */
|
||||
uint32_t reserved13[127];
|
||||
uint32_t uddr9; /* 0x900 */
|
||||
uint32_t reserved14[127];
|
||||
uint32_t uddr11; /* 0xb00 */
|
||||
uint32_t reserved15[31];
|
||||
uint32_t uddr12; /* 0xb80 */
|
||||
uint32_t reserved16[31];
|
||||
uint32_t uddr13; /* 0xc00 */
|
||||
uint32_t reserved17[127];
|
||||
uint32_t uddr14; /* 0xe00 */
|
||||
|
||||
};
|
||||
|
||||
#define PXA25X_UDC_BASE 0x40600000
|
||||
|
||||
#define UDCCR_UDE (1 << 0)
|
||||
#define UDCCR_UDA (1 << 1)
|
||||
#define UDCCR_RSM (1 << 2)
|
||||
#define UDCCR_RESIR (1 << 3)
|
||||
#define UDCCR_SUSIR (1 << 4)
|
||||
#define UDCCR_SRM (1 << 5)
|
||||
#define UDCCR_RSTIR (1 << 6)
|
||||
#define UDCCR_REM (1 << 7)
|
||||
|
||||
/* Bulk IN endpoint 1/6/11 */
|
||||
#define UDCCS_BI_TSP (1 << 7)
|
||||
#define UDCCS_BI_FST (1 << 5)
|
||||
#define UDCCS_BI_SST (1 << 4)
|
||||
#define UDCCS_BI_TUR (1 << 3)
|
||||
#define UDCCS_BI_FTF (1 << 2)
|
||||
#define UDCCS_BI_TPC (1 << 1)
|
||||
#define UDCCS_BI_TFS (1 << 0)
|
||||
|
||||
/* Bulk OUT endpoint 2/7/12 */
|
||||
#define UDCCS_BO_RSP (1 << 7)
|
||||
#define UDCCS_BO_RNE (1 << 6)
|
||||
#define UDCCS_BO_FST (1 << 5)
|
||||
#define UDCCS_BO_SST (1 << 4)
|
||||
#define UDCCS_BO_DME (1 << 3)
|
||||
#define UDCCS_BO_RPC (1 << 1)
|
||||
#define UDCCS_BO_RFS (1 << 0)
|
||||
|
||||
/* Isochronous OUT endpoint 4/9/14 */
|
||||
#define UDCCS_IO_RSP (1 << 7)
|
||||
#define UDCCS_IO_RNE (1 << 6)
|
||||
#define UDCCS_IO_DME (1 << 3)
|
||||
#define UDCCS_IO_ROF (1 << 2)
|
||||
#define UDCCS_IO_RPC (1 << 1)
|
||||
#define UDCCS_IO_RFS (1 << 0)
|
||||
|
||||
/* Control endpoint 0 */
|
||||
#define UDCCS0_OPR (1 << 0)
|
||||
#define UDCCS0_IPR (1 << 1)
|
||||
#define UDCCS0_FTF (1 << 2)
|
||||
#define UDCCS0_DRWF (1 << 3)
|
||||
#define UDCCS0_SST (1 << 4)
|
||||
#define UDCCS0_FST (1 << 5)
|
||||
#define UDCCS0_RNE (1 << 6)
|
||||
#define UDCCS0_SA (1 << 7)
|
||||
|
||||
#define UICR0_IM0 (1 << 0)
|
||||
|
||||
#define USIR0_IR0 (1 << 0)
|
||||
#define USIR0_IR1 (1 << 1)
|
||||
#define USIR0_IR2 (1 << 2)
|
||||
#define USIR0_IR3 (1 << 3)
|
||||
#define USIR0_IR4 (1 << 4)
|
||||
#define USIR0_IR5 (1 << 5)
|
||||
#define USIR0_IR6 (1 << 6)
|
||||
#define USIR0_IR7 (1 << 7)
|
||||
|
||||
#define UDCCFR_AREN (1 << 7) /* ACK response enable (now) */
|
||||
#define UDCCFR_ACM (1 << 2) /* ACK control mode (wait for AREN) */
|
||||
/*
|
||||
* Intel(R) PXA255 Processor Specification, September 2003 (page 31)
|
||||
* define new "must be one" bits in UDCCFR (see Table 12-13.)
|
||||
*/
|
||||
#define UDCCFR_MB1 (0xff & ~(UDCCFR_AREN | UDCCFR_ACM))
|
||||
|
||||
#define UFNRH_SIR (1 << 7) /* SOF interrupt request */
|
||||
#define UFNRH_SIM (1 << 6) /* SOF interrupt mask */
|
||||
#define UFNRH_IPE14 (1 << 5) /* ISO packet error, ep14 */
|
||||
#define UFNRH_IPE9 (1 << 4) /* ISO packet error, ep9 */
|
||||
#define UFNRH_IPE4 (1 << 3) /* ISO packet error, ep4 */
|
||||
|
||||
#endif /* __REGS_USB_H__ */
|
||||
Reference in New Issue
Block a user