source: mainline/boot/arch/arm32/src/putchar.c@ 876160ca

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 876160ca was f9ab562, checked in by Jakub Jermar <jakub@…>, 13 years ago

Remove support for the testarm machine.

  • Property mode set to 100644
File size: 3.3 KB
Line 
1/*
2 * Copyright (c) 2007 Michal Kebrt
3 * Copyright (c) 2009 Vineeth Pillai
4 * Copyright (c) 2010 Jiri Svoboda
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * - Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 * - Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 * - The name of the author may not be used to endorse or promote products
17 * derived from this software without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
20 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
21 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
23 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
24 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
28 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */
30
31/** @addtogroup arm32boot
32 * @{
33 */
34/** @file
35 * @brief bootloader output logic
36 */
37
38#include <typedefs.h>
39#include <arch/main.h>
40#include <putchar.h>
41#include <str.h>
42
43#ifdef MACHINE_beagleboardxm
44
45/** Send a byte to the amdm37x serial console.
46 *
47 * @param byte Byte to send.
48 */
49static void scons_sendb_bbxm(uint8_t byte)
50{
51 volatile uint32_t *thr =
52 (volatile uint32_t *)BBXM_SCONS_THR;
53 volatile uint32_t *ssr =
54 (volatile uint32_t *)BBXM_SCONS_SSR;
55
56 /* Wait until transmitter is empty. */
57 while ((*ssr & BBXM_THR_FULL) == 1) ;
58
59 /* Transmit byte. */
60 *thr = (uint32_t) byte;
61}
62
63#endif
64
65#ifdef MACHINE_gta02
66
67/** Send a byte to the gta02 serial console.
68 *
69 * @param byte Byte to send.
70 */
71static void scons_sendb_gta02(uint8_t byte)
72{
73 volatile uint32_t *utrstat;
74 volatile uint32_t *utxh;
75
76 utrstat = (volatile uint32_t *) GTA02_SCONS_UTRSTAT;
77 utxh = (volatile uint32_t *) GTA02_SCONS_UTXH;
78
79 /* Wait until transmitter is empty. */
80 while ((*utrstat & S3C24XX_UTXH_TX_EMPTY) == 0)
81 ;
82
83 /* Transmit byte. */
84 *utxh = (uint32_t) byte;
85}
86
87#endif
88
89#ifdef MACHINE_integratorcp
90
91/** Send a byte to the IntegratorCP serial console.
92 *
93 * @param byte Byte to send.
94 */
95static void scons_sendb_icp(uint8_t byte)
96{
97 *((volatile uint8_t *) ICP_SCONS_ADDR) = byte;
98}
99
100#endif
101
102/** Send a byte to the serial console.
103 *
104 * @param byte Byte to send.
105 */
106static void scons_sendb(uint8_t byte)
107{
108#ifdef MACHINE_beagleboardxm
109 scons_sendb_bbxm(byte);
110#endif
111#ifdef MACHINE_gta02
112 scons_sendb_gta02(byte);
113#endif
114#ifdef MACHINE_integratorcp
115 scons_sendb_icp(byte);
116#endif
117}
118
119/** Display a character
120 *
121 * @param ch Character to display
122 */
123void putchar(const wchar_t ch)
124{
125 if (ch == '\n')
126 scons_sendb('\r');
127
128 if (ascii_check(ch))
129 scons_sendb((uint8_t) ch);
130 else
131 scons_sendb(U_SPECIAL);
132}
133
134/** @}
135 */
Note: See TracBrowser for help on using the repository browser.