f-stack/freebsd/mips/adm5120/uart_dev_adm5120.h

81 lines
2.8 KiB
C

/* $NetBSD: uart.h,v 1.1 2007/03/20 08:52:02 dyoung Exp $ */
/*-
* Copyright (c) 2007 Ruslan Ermilov and Vsevolod Lobko.
* 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.
* 3. The names of the authors may not be used to endorse or promote
* products derived from this software without specific prior
* written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``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 AUTHORS
* 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.
*
* $FreeBSD$
*/
#ifndef _ADMUART_H
#define _ADMUART_H
/* UART registers */
#define UART_DR_REG 0x00
#define UART_RSR_REG 0x04
#define UART_RSR_FE 0x01
#define UART_RSR_PE 0x02
#define UART_RSR_BE 0x04
#define UART_RSR_OE 0x08
#define UART_ECR_REG 0x04
#define UART_ECR_RSR 0x80
#define UART_LCR_H_REG 0x08
#define UART_LCR_H_FEN 0x10
#define UART_LCR_M_REG 0x0c
#define UART_LCR_L_REG 0x10
#define UART_CR_REG 0x14
#define UART_CR_PORT_EN 0x01
#define UART_CR_SIREN 0x02
#define UART_CR_SIRLP 0x04
#define UART_CR_MODEM_STATUS_INT_EN 0x08
#define UART_CR_RX_INT_EN 0x10
#define UART_CR_TX_INT_EN 0x20
#define UART_CR_RX_TIMEOUT_INT_EN 0x40
#define UART_CR_LOOPBACK_EN 0x80
#define UART_FR_REG 0x18
#define UART_FR_CTS 0x01
#define UART_FR_DSR 0x02
#define UART_FR_DCD 0x04
#define UART_FR_BUSY 0x08
#define UART_FR_RX_FIFO_EMPTY 0x10
#define UART_FR_TX_FIFO_FULL 0x20
#define UART_FR_RX_FIFO_FULL 0x40
#define UART_FR_TX_FIFO_EMPTY 0x80
#define UART_IR_REG 0x1c
#define UART_IR_MODEM_STATUS_INT 0x01
#define UART_IR_RX_INT 0x02
#define UART_IR_TX_INT 0x04
#define UART_IR_RX_TIMEOUT_INT 0x08
#define UART_IR_INT_MASK 0x0f
#define UART_IR_UICR 0x80
#define UART_ILPR_REG 0x20
/* UART interrupts */
int uart_cnattach(void);
#endif /* _ADMUART_H */