source: rtems/c/src/lib/libbsp/mips/jmr3904/console/console-io.c @ 0fd4a13

4.104.114.84.95
Last change on this file since 0fd4a13 was 0fd4a13, checked in by Joel Sherrill <joel.sherrill@…>, on 01/03/01 at 16:42:59

2001-01-03 Joel Sherrill <joel@…>

  • clock/Makefile.am: Fixed reference to ckinit.c.
  • clock/clockdrv.c: Enabled fast idle.
  • console/console-io.c: Added console_initialize_hardware().
  • Property mode set to 100644
File size: 2.9 KB
Line 
1/*
2 *  This file contains the hardware specific portions of the TTY driver
3 *  for the serial ports on the jmr3904.
4 *
5 *  Logic based on the jmr3904-io.c file in newlib 1.8.2
6 *
7 *  COPYRIGHT (c) 1989-2000.
8 *  On-Line Applications Research Corporation (OAR).
9 *
10 *  The license and distribution terms for this file may be
11 *  found in the file LICENSE in this distribution or at
12 *  http://www.OARcorp.com/rtems/license.html.
13 *
14 *  $Id$
15 */
16
17#include <bsp.h>
18#include <rtems/libio.h>
19#include <stdlib.h>
20#include <assert.h>
21
22/* external prototypes for monitor interface routines */
23
24#define READ_UINT8( _register_, _value_ ) \
25        ((_value_) = *((volatile unsigned char *)(_register_)))
26
27#define WRITE_UINT8( _register_, _value_ ) \
28        (*((volatile unsigned char *)(_register_)) = (_value_))
29
30#define READ_UINT16( _register_, _value_ ) \
31     ((_value_) = *((volatile unsigned short *)(_register_)))
32
33#define WRITE_UINT16( _register_, _value_ ) \
34     (*((volatile unsigned short *)(_register_)) = (_value_))
35
36
37 /* - Board specific addresses for serial chip */
38#define DIAG_BASE       0xfffff300
39#define DIAG_SLCR       (DIAG_BASE+0x00)
40#define DIAG_SLSR       (DIAG_BASE+0x04)
41#define DIAG_SLDICR     (DIAG_BASE+0x08)
42#define DIAG_SLDISR     (DIAG_BASE+0x0C)
43#define DIAG_SFCR       (DIAG_BASE+0x10)
44#define DIAG_SBRG       (DIAG_BASE+0x14)
45#define DIAG_TFIFO      (DIAG_BASE+0x20)
46#define DIAG_RFIFO      (DIAG_BASE+0x30)
47
48#define BRG_T0          0x0000
49#define BRG_T2          0x0100
50#define BRG_T4          0x0200
51#define BRG_T5          0x0300
52
53/*
54 *  Eventually console-polled.c should hook to this better.
55 */
56
57static char initialized = 0;
58
59/*
60 *  console_initialize_hardware
61 *
62 *  This routine initializes the console hardware.
63 *
64 */
65
66void console_initialize_hardware(void)
67{
68  WRITE_UINT16 (DIAG_SLCR, 0x0020);
69  WRITE_UINT16 (DIAG_SLDICR, 0x0000);
70  WRITE_UINT16 (DIAG_SFCR, 0x0000);
71  WRITE_UINT16 (DIAG_SBRG, BRG_T2 | 5);
72}
73
74/*
75 *  console_outbyte_polled
76 *
77 *  This routine transmits a character using polling.
78 */
79
80void console_outbyte_polled(
81  int  port,
82  char ch
83)
84{
85  unsigned short disr;
86
87  for (;;) {
88    READ_UINT16 (DIAG_SLDISR, disr);
89    if (disr & 0x0002)
90      break;
91  }
92  disr = disr & ~0x0002;
93  WRITE_UINT8 (DIAG_TFIFO, (unsigned char) ch);
94  WRITE_UINT16 (DIAG_SLDISR, disr);
95}
96
97/*
98 *  console_inbyte_nonblocking
99 *
100 *  This routine polls for a character.
101 */
102
103int console_inbyte_nonblocking(
104  int port
105)
106{
107  unsigned char c;
108  unsigned short disr;
109
110  READ_UINT16 (DIAG_SLDISR, disr);
111  if (disr & 0x0001) {
112    disr = disr & ~0x0001;
113    READ_UINT8 (DIAG_RFIFO, c);
114    WRITE_UINT16 (DIAG_SLDISR, disr);
115    return (char) c;
116  }
117  return -1;
118}
119
120#include <bspIo.h>
121
122void JMR3904_output_char(char c) { console_outbyte_polled( 0, c ); }
123
124BSP_output_char_function_type           BSP_output_char = JMR3904_output_char;
125BSP_polling_getchar_function_type       BSP_poll_char = NULL;
126
Note: See TracBrowser for help on using the repository browser.