200 lines
6.8 KiB
C
200 lines
6.8 KiB
C
/*
|
|
|
|
Part of the Raspberry-Pi Bare Metal Tutorials
|
|
Copyright (c) 2013-2015, Brian Sidebotham
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
1. Redistributions of source code must retain the above copyright notice,
|
|
this list of conditions and the following disclaimer.
|
|
|
|
2. Redistributions in binary form must reproduce the above copyright notice,
|
|
this list of conditions and the following disclaimer in the
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
#ifndef RPI_AUX_H
|
|
#define RPI_AUX_H
|
|
|
|
#include "rpi-base.h"
|
|
|
|
/* Although these values were originally from the BCM2835 Arm peripherals PDF
|
|
it's clear that was rushed and has some glaring errors - so these values
|
|
may appear to be different. These values have been changed due to data on
|
|
the elinux BCM2835 datasheet errata:
|
|
http://elinux.org/BCM2835_datasheet_errata */
|
|
|
|
#define AUX_BASE ( PERIPHERAL_BASE + 0x215000 )
|
|
|
|
#define AUX_ENA_MINIUART ( 1 << 0 )
|
|
#define AUX_ENA_SPI1 ( 1 << 1 )
|
|
#define AUX_ENA_SPI2 ( 1 << 2 )
|
|
|
|
#define AUX_IRQ_SPI2 ( 1 << 2 )
|
|
#define AUX_IRQ_SPI1 ( 1 << 1 )
|
|
#define AUX_IRQ_MU ( 1 << 0 )
|
|
|
|
#define AUX_MULCR_8BIT_MODE ( 3 << 0 ) /* See errata for this value */
|
|
#define AUX_MULCR_BREAK ( 1 << 6 )
|
|
#define AUX_MULCR_DLAB_ACCESS ( 1 << 7 )
|
|
|
|
#define AUX_MUMCR_RTS ( 1 << 1 )
|
|
|
|
#define AUX_MULSR_DATA_READY ( 1 << 0 )
|
|
#define AUX_MULSR_RX_OVERRUN ( 1 << 1 )
|
|
#define AUX_MULSR_TX_EMPTY ( 1 << 5 )
|
|
#define AUX_MULSR_TX_IDLE ( 1 << 6 )
|
|
|
|
#define AUX_MUMSR_CTS ( 1 << 5 )
|
|
|
|
#define AUX_MUCNTL_RX_ENABLE ( 1 << 0 )
|
|
#define AUX_MUCNTL_TX_ENABLE ( 1 << 1 )
|
|
#define AUX_MUCNTL_RTS_FLOW ( 1 << 2 )
|
|
#define AUX_MUCNTL_CTS_FLOW ( 1 << 3 )
|
|
#define AUX_MUCNTL_RTS_FIFO ( 3 << 4 )
|
|
#define AUX_MUCNTL_RTS_ASSERT ( 1 << 6 )
|
|
#define AUX_MUCNTL_CTS_ASSERT ( 1 << 7 )
|
|
|
|
#define AUX_MUSTAT_SYMBOL_AV ( 1 << 0 )
|
|
#define AUX_MUSTAT_SPACE_AV ( 1 << 1 )
|
|
#define AUX_MUSTAT_RX_IDLE ( 1 << 2 )
|
|
#define AUX_MUSTAT_TX_IDLE ( 1 << 3 )
|
|
#define AUX_MUSTAT_RX_OVERRUN ( 1 << 4 )
|
|
#define AUX_MUSTAT_TX_FIFO_FULL ( 1 << 5 )
|
|
#define AUX_MUSTAT_RTS ( 1 << 6 )
|
|
#define AUX_MUSTAT_CTS ( 1 << 7 )
|
|
#define AUX_MUSTAT_TX_EMPTY ( 1 << 8 )
|
|
#define AUX_MUSTAT_TX_DONE ( 1 << 9 )
|
|
#define AUX_MUSTAT_RX_FIFO_LEVEL ( 7 << 16 )
|
|
#define AUX_MUSTAT_TX_FIFO_LEVEL ( 7 << 24 )
|
|
|
|
// Interrupt enables are incorrect on page 12 of:
|
|
// https://www.raspberrypi.org/wp-content/uploads/2012/02/BCM2835-ARM-Peripherals.pdf
|
|
// See errata:
|
|
// http://elinux.org/BCM2835_datasheet_errata#p12
|
|
#define AUX_MUIER_TX_INT ( (1 << 1) )
|
|
#define AUX_MUIER_RX_INT ( (1 << 0 )| (1 << 2) )
|
|
|
|
#define AUX_MUIIR_INT_NOT_PENDING ( 1 << 0 )
|
|
#define AUX_MUIIR_INT_IS_TX ( 1 << 1 )
|
|
#define AUX_MUIIR_INT_IS_RX ( 1 << 2 )
|
|
|
|
|
|
|
|
#define FSEL0(x) ( x )
|
|
#define FSEL1(x) ( x << 3 )
|
|
#define FSEL2(x) ( x << 6 )
|
|
#define FSEL3(x) ( x << 9 )
|
|
#define FSEL4(x) ( x << 12 )
|
|
#define FSEL5(x) ( x << 15 )
|
|
#define FSEL6(x) ( x << 18 )
|
|
#define FSEL7(x) ( x << 21 )
|
|
#define FSEL8(x) ( x << 24 )
|
|
#define FSEL9(x) ( x << 27 )
|
|
|
|
#define FSEL10(x) ( x )
|
|
#define FSEL11(x) ( x << 3 )
|
|
#define FSEL12(x) ( x << 6 )
|
|
#define FSEL13(x) ( x << 9 )
|
|
#define FSEL14(x) ( x << 12 )
|
|
#define FSEL15(x) ( x << 15 )
|
|
#define FSEL16(x) ( x << 18 )
|
|
#define FSEL17(x) ( x << 21 )
|
|
#define FSEL18(x) ( x << 24 )
|
|
#define FSEL19(x) ( x << 27 )
|
|
|
|
#define FSEL20(x) ( x )
|
|
#define FSEL21(x) ( x << 3 )
|
|
#define FSEL22(x) ( x << 6 )
|
|
#define FSEL23(x) ( x << 9 )
|
|
#define FSEL24(x) ( x << 12 )
|
|
#define FSEL25(x) ( x << 15 )
|
|
#define FSEL26(x) ( x << 18 )
|
|
#define FSEL27(x) ( x << 21 )
|
|
#define FSEL28(x) ( x << 24 )
|
|
#define FSEL29(x) ( x << 27 )
|
|
|
|
#define FSEL30(x) ( x )
|
|
#define FSEL31(x) ( x << 3 )
|
|
#define FSEL32(x) ( x << 6 )
|
|
#define FSEL33(x) ( x << 9 )
|
|
#define FSEL34(x) ( x << 12 )
|
|
#define FSEL35(x) ( x << 15 )
|
|
#define FSEL36(x) ( x << 18 )
|
|
#define FSEL37(x) ( x << 21 )
|
|
#define FSEL38(x) ( x << 24 )
|
|
#define FSEL39(x) ( x << 27 )
|
|
|
|
#define FSEL40(x) ( x )
|
|
#define FSEL41(x) ( x << 3 )
|
|
#define FSEL42(x) ( x << 6 )
|
|
#define FSEL43(x) ( x << 9 )
|
|
#define FSEL44(x) ( x << 12 )
|
|
#define FSEL45(x) ( x << 15 )
|
|
#define FSEL46(x) ( x << 18 )
|
|
#define FSEL47(x) ( x << 21 )
|
|
#define FSEL48(x) ( x << 24 )
|
|
#define FSEL49(x) ( x << 27 )
|
|
|
|
#define FSEL50(x) ( x )
|
|
#define FSEL51(x) ( x << 3 )
|
|
#define FSEL52(x) ( x << 6 )
|
|
#define FSEL53(x) ( x << 9 )
|
|
|
|
typedef struct
|
|
{
|
|
volatile unsigned int IRQ;
|
|
volatile unsigned int ENABLES;
|
|
|
|
volatile unsigned int reserved1[((0x40 - 0x04) / 4) - 1];
|
|
|
|
volatile unsigned int MU_IO;
|
|
volatile unsigned int MU_IER;
|
|
volatile unsigned int MU_IIR;
|
|
volatile unsigned int MU_LCR;
|
|
volatile unsigned int MU_MCR;
|
|
volatile unsigned int MU_LSR;
|
|
volatile unsigned int MU_MSR;
|
|
volatile unsigned int MU_SCRATCH;
|
|
volatile unsigned int MU_CNTL;
|
|
volatile unsigned int MU_STAT;
|
|
volatile unsigned int MU_BAUD;
|
|
|
|
volatile unsigned int reserved2[(0x80 - 0x68) / 4];
|
|
|
|
volatile unsigned int SPI0_CNTL0;
|
|
volatile unsigned int SPI0_CNTL1;
|
|
volatile unsigned int SPI0_STAT;
|
|
volatile unsigned int SPI0_IO;
|
|
volatile unsigned int SPI0_PEEK;
|
|
|
|
volatile unsigned int reserved3[(0xC0 - 0x94) / 4];
|
|
|
|
volatile unsigned int SPI1_CNTL0;
|
|
volatile unsigned int SPI1_CNTL1;
|
|
volatile unsigned int SPI1_STAT;
|
|
volatile unsigned int SPI1_IO;
|
|
volatile unsigned int SPI1_PEEK;
|
|
} aux_t;
|
|
|
|
extern aux_t* RPI_GetAux(void);
|
|
extern void RPI_AuxMiniUartInit(int baud, int bits);
|
|
extern void RPI_AuxMiniUartWrite(char c);
|
|
extern void RPI_EnableUart(char* pMessage);
|
|
|
|
#endif
|