/* * Copyright 2013 Tilera Corporation. All Rights Reserved. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation, version 2. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or * NON INFRINGEMENT. See the GNU General Public License for * more details. */ #ifndef _GXIO_UART_H_ #define _GXIO_UART_H_ #include "common.h" #include <hv/drv_uart_intf.h> #include <hv/iorpc.h> /* * * An API for manipulating UART interface. */ /* * * The Rshim allows access to the processor's UART interface. */ /* A context object used to manage UART resources. */ typedef struct { /* File descriptor for calling up to the hypervisor. */ int fd; /* The VA at which our MMIO registers are mapped. */ char *mmio_base; } gxio_uart_context_t; /* Request UART interrupts. * * Request that interrupts be delivered to a tile when the UART's * Receive FIFO is written, or the Write FIFO is read. * * @param context Pointer to a properly initialized gxio_uart_context_t. * @param bind_cpu_x X coordinate of CPU to which interrupt will be delivered. * @param bind_cpu_y Y coordinate of CPU to which interrupt will be delivered. * @param bind_interrupt IPI interrupt number. * @param bind_event Sub-interrupt event bit number; a negative value can * disable the interrupt. * @return Zero if all of the requested UART events were successfully * configured to interrupt. */ extern int gxio_uart_cfg_interrupt(gxio_uart_context_t *context, int bind_cpu_x, int bind_cpu_y, int bind_interrupt, int bind_event); /* Initialize a UART context. * * A properly initialized context must be obtained before any of the other * gxio_uart routines may be used. * * @param context Pointer to a gxio_uart_context_t, which will be initialized * by this routine, if it succeeds. * @param uart_index Index of the UART to use. * @return Zero if the context was successfully initialized, else a * GXIO_ERR_xxx error code. */ extern int gxio_uart_init(gxio_uart_context_t *context, int uart_index); /* Destroy a UART context. * * Once destroyed, a context may not be used with any gxio_uart routines * other than gxio_uart_init(). After this routine returns, no further * interrupts requested on this context will be delivered. The state and * configuration of the pins which had been attached to this context are * unchanged by this operation. * * @param context Pointer to a gxio_uart_context_t. * @return Zero if the context was successfully destroyed, else a * GXIO_ERR_xxx error code. */ extern int gxio_uart_destroy(gxio_uart_context_t *context); /* Write UART register. * @param context Pointer to a gxio_uart_context_t. * @param offset UART register offset. * @param word Data will be wrote to UART reigister. */ extern void gxio_uart_write(gxio_uart_context_t *context, uint64_t offset, uint64_t word); /* Read UART register. * @param context Pointer to a gxio_uart_context_t. * @param offset UART register offset. * @return Data read from UART register. */ extern uint64_t gxio_uart_read(gxio_uart_context_t *context, uint64_t offset); #endif /* _GXIO_UART_H_ */