forked from Imagelibrary/rtems
The umon support is only used by the csb337 BSP. This patch is a part of the BSP source reorganization. Update #3285.
132 lines
3.3 KiB
C
132 lines
3.3 KiB
C
/*
|
|
* uMon Support Output Driver
|
|
*
|
|
* COPYRIGHT (c) 1989-2009.
|
|
* On-Line Applications Research Corporation (OAR).
|
|
*
|
|
* Modified by Fernando Nicodemos <fgnicodemos@terra.com.br>
|
|
* from NCB - Sistemas Embarcados Ltda. (Brazil)
|
|
*
|
|
* The license and distribution terms for this file may be
|
|
* found in the file LICENSE in this distribution or at
|
|
* http://www.rtems.org/license/LICENSE.
|
|
*/
|
|
|
|
#include <rtems/umon.h>
|
|
#include <libchip/serial.h>
|
|
#include <libchip/sersupp.h>
|
|
|
|
/* static function prototypes */
|
|
static int umoncons_first_open(int major, int minor, void *arg);
|
|
static int umoncons_last_close(int major, int minor, void *arg);
|
|
static int umoncons_read(int minor);
|
|
static ssize_t umoncons_write(int minor, const char *buf, size_t len);
|
|
static void umoncons_init(int minor);
|
|
static void umoncons_write_polled(int minor, char c);
|
|
static int umoncons_set_attributes(int minor, const struct termios *t);
|
|
|
|
/* Pointers to functions for handling the UART. */
|
|
const console_fns umoncons_fns =
|
|
{
|
|
libchip_serial_default_probe,
|
|
umoncons_first_open,
|
|
umoncons_last_close,
|
|
umoncons_read,
|
|
umoncons_write,
|
|
umoncons_init,
|
|
umoncons_write_polled, /* not used in this driver */
|
|
umoncons_set_attributes,
|
|
false /* TRUE if interrupt driven, FALSE if not. */
|
|
};
|
|
|
|
/*********************************************************************/
|
|
/* Functions called via callbacks (i.e. the ones in uart_fns */
|
|
/*********************************************************************/
|
|
|
|
/*
|
|
* This is called the first time each device is opened. Since
|
|
* the driver is polled, we don't have to do anything. If the driver
|
|
* were interrupt driven, we'd enable interrupts here.
|
|
*/
|
|
static int umoncons_first_open(int major, int minor, void *arg)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
|
|
/*
|
|
* This is called the last time each device is closed. Since
|
|
* the driver is polled, we don't have to do anything. If the driver
|
|
* were interrupt driven, we'd disable interrupts here.
|
|
*/
|
|
static int umoncons_last_close(int major, int minor, void *arg)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
|
|
/*
|
|
* Read one character from UART.
|
|
*
|
|
* return -1 if there's no data, otherwise return
|
|
* the character in lowest 8 bits of returned int.
|
|
*/
|
|
static int umoncons_read(int minor)
|
|
{
|
|
if ( !mon_gotachar() )
|
|
return -1;
|
|
return mon_getchar();
|
|
}
|
|
|
|
|
|
/*
|
|
* Write buffer to LCD
|
|
*
|
|
* return 1 on success, -1 on error
|
|
*/
|
|
static ssize_t umoncons_write(int minor, const char *buf, size_t len)
|
|
{
|
|
size_t i;
|
|
|
|
for ( i=0 ; i<len ; i++ )
|
|
mon_putchar( buf[i] );
|
|
|
|
return len;
|
|
}
|
|
|
|
|
|
/* Set up the uMon driver. */
|
|
static void umoncons_init(int minor)
|
|
{
|
|
rtems_umon_connect();
|
|
}
|
|
|
|
/* This is used for putchark support */
|
|
static void umoncons_write_polled(int minor, char c)
|
|
{
|
|
mon_putchar( c );
|
|
}
|
|
|
|
/* This is for setting baud rate, bits, etc. */
|
|
static int umoncons_set_attributes(int minor, const struct termios *t)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/***********************************************************************/
|
|
/*
|
|
* The following functions are not used by TERMIOS, but other RTEMS
|
|
* functions use them instead.
|
|
*/
|
|
/***********************************************************************/
|
|
/*
|
|
* Read from UART. This is used in the exit code, and can't
|
|
* rely on interrupts.
|
|
*/
|
|
int umoncons_poll_read(int minor)
|
|
{
|
|
if (!mon_gotachar())
|
|
return -1;
|
|
return mon_getchar();
|
|
}
|