source: trunk/boot/tsar_mips32/boot_tty_driver.c @ 594

Last change on this file since 594 was 572, checked in by alain, 6 years ago

Introduce the cluster_info[x][y] in the boot_info.h structure for the TSAR architecture.

File size: 3.5 KB
RevLine 
[439]1/*
2 * boot_tty_driver.c - TSAR bootloader TTY driver implementation.
3 *
4 * Authors :   Alain Greiner / Vu Son  (2016)
5 *
6 * Copyright (c) UPMC Sorbonne Universites
7 *
8 * This file is part of ALMOS-MKH.
9 *
10 * ALMOS-MKH is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; version 2.0 of the License.
13 *
14 * ALMOS-MKH is distributed in the hope that it will be useful, but
15 * WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
17 * General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with ALMOS-MKH; if not, write to the Free Software Foundation,
21 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
22 */
23
24#include <boot_config.h>
25#include <boot_tty_driver.h>
[457]26#include <hal_kernel_types.h>
[439]27#include <boot_utils.h>
28
29#ifndef SEG_TXT_BASE
30# error "The SEG_TXT_BASE value should be defined in the 'hard_config.h' file"
31#endif
32
33#ifndef X_IO 
34# error "The X_IO value should be defined in the 'hard_config.h' file"
35#endif
36
37#ifndef Y_IO 
38# error "The Y_IO value should be defined in the 'hard_config.h' file"
39#endif
40
41#ifndef Y_WIDTH
42# error "The Y_WIDTH value should be defined in the 'hard_config.h' file"
43#endif
44
45/////////////////////////////////////////////////////////////////////////////
46// This function returns the value contained in a TTY0 register.
47// @ reg    : register to be read.
48// @ returns the value stored in 'reg'.
49/////////////////////////////////////////////////////////////////////////////
50static uint32_t boot_tty_get_register( uint32_t reg )
51{
[572]52    cxy_t      cxy = (X_IO << Y_WIDTH) + Y_IO;
[439]53    uint32_t * ptr = (uint32_t *)SEG_TXT_BASE + reg;
54   
55    return boot_remote_lw( XPTR( cxy , ptr ) ); 
56   
57} // boot_tty_get_register()
58
59/////////////////////////////////////////////////////////////////////////////
60// This function sets a new value to a TTY0 register.
61// @ reg    : register to be configured.
62// @ val    : new value to be written to 'reg'.
63/////////////////////////////////////////////////////////////////////////////
64static void boot_tty_set_register( uint32_t reg, 
65                                   uint32_t val )
66{
[572]67    cxy_t      cxy = (X_IO << Y_WIDTH) + Y_IO;
[439]68    uint32_t * ptr = (uint32_t *)SEG_TXT_BASE + reg;
69
70    boot_remote_sw( XPTR( cxy , ptr ) , val ); 
71
72} // boot_tty_set_register()
73
[572]74/////////////////////////////////////
[521]75int boot_tty_write( const char * buf,
76                    uint32_t     nbytes )
[439]77{
78    uint32_t nb_printed;
79    uint32_t nb_test;
80    uint32_t error; 
81
82    // Print nbytes to TTY0 terminal
83    for (nb_printed = 0; nb_printed < nbytes; nb_printed++)
84    {
85        // Poll the TTY0 status.
86        if ((boot_tty_get_register(TTY_STATUS_REG) & TTY_STATUS_TX_FULL))
87        {
88            error = 1;
89            for (nb_test = 0; nb_test < 10000; nb_test++)
90            {
91                if ((boot_tty_get_register(TTY_STATUS_REG) & TTY_STATUS_TX_FULL) == 0)
92                {
93                    error = 0;
94                    break;
95                }
96            }
97
98            // Report error after 10000 retries.
99            if (error) return -1;
100        }
101
[541]102        // Write one character to TTY0 terminal.
[439]103        // Special treatment for a newline: Carriage Return before Line Feed.
104        if (buf[nb_printed] == '\n') boot_tty_set_register(TTY_WRITE_REG , (uint32_t)'\r');
105        boot_tty_set_register(TTY_WRITE_REG , (uint32_t)buf[nb_printed]);
106    }
107
108    return 0;
109
110} // boot_tty_write()
Note: See TracBrowser for help on using the repository browser.