Changeset e9bc927 in mainline
- Timestamp:
- 2025-04-18T08:22:19Z (2 months ago)
- Branches:
- master
- Children:
- 25fdb2d
- Parents:
- 51949d0
- git-author:
- Jiří Zárevúcky <zarevucky.jiri@…> (2025-04-18 07:18:03)
- git-committer:
- Jiří Zárevúcky <zarevucky.jiri@…> (2025-04-18 08:22:19)
- Location:
- kernel
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/arch/ia64/src/drivers/ski.c
r51949d0 re9bc927 60 60 }; 61 61 62 static void ski_ putuchar(outdev_t *, const char32_t);62 static void ski_write(outdev_t *, const char *, size_t); 63 63 64 64 static outdev_operations_t skidev_ops = { 65 .write = ski_ putuchar,65 .write = ski_write, 66 66 .redraw = NULL, 67 67 .scroll_up = NULL, … … 182 182 } 183 183 184 static void ski_do_putchar( charch)184 static void ski_do_putchar(uint8_t ch) 185 185 { 186 186 asm volatile ( … … 203 203 * 204 204 */ 205 static void ski_putuchar(outdev_t *dev, char32_t ch) 206 { 205 static void ski_write(outdev_t *dev, const char *s, size_t n) 206 { 207 /* If the userspace owns the console, do not output anything. */ 207 208 if (ski_parea.mapped && !console_override) 208 209 return; 209 210 210 if (ascii_check(ch)) { 211 if (ch == '\n') 211 const char *top = s + n; 212 assert(top >= s); 213 214 for (; s < top; s++) { 215 if (*s == '\n') 212 216 ski_do_putchar('\r'); 213 217 214 ski_do_putchar(ch); 215 } else { 216 ski_do_putchar('?'); 218 ski_do_putchar((uint8_t) *s); 217 219 } 218 220 } -
kernel/arch/riscv64/src/drivers/ucb.c
r51949d0 re9bc927 41 41 static volatile uint64_t *fromhost; 42 42 43 static outdev_operations_t htifdev_ops = {44 .write = htif_putuchar,45 .redraw = NULL,46 .scroll_up = NULL,47 .scroll_down = NULL48 };49 50 43 static void poll_fromhost() 51 44 { … … 56 49 *fromhost = 0; 57 50 } 51 52 static void htif_cmd(uint8_t device, uint8_t cmd, uint64_t payload) 53 { 54 uint64_t val = (((uint64_t) device) << 56) | 55 (((uint64_t) cmd) << 48) | 56 (payload & UINT64_C(0xffffffffffff)); 57 58 while (*tohost) 59 poll_fromhost(); 60 61 *tohost = val; 62 } 63 64 static void htif_write(outdev_t *dev, const char *s, size_t n) 65 { 66 const char *top = s + n; 67 assert(top >= s); 68 69 for (; s < top; s++) { 70 if (*s == '\n') 71 htif_cmd(HTIF_DEVICE_CONSOLE, HTIF_CONSOLE_PUTC, '\r'); 72 73 htif_cmd(HTIF_DEVICE_CONSOLE, HTIF_CONSOLE_PUTC, (uint8_t) *s); 74 } 75 } 76 77 static outdev_operations_t htifdev_ops = { 78 .write = htif_write, 79 .redraw = NULL, 80 .scroll_up = NULL, 81 .scroll_down = NULL 82 }; 58 83 59 84 void htif_init(volatile uint64_t *tohost_addr, volatile uint64_t *fromhost_addr) … … 72 97 return htifdev; 73 98 } 74 75 static void htif_cmd(uint8_t device, uint8_t cmd, uint64_t payload)76 {77 uint64_t val = (((uint64_t) device) << 56) |78 (((uint64_t) cmd) << 48) |79 (payload & UINT64_C(0xffffffffffff));80 81 while (*tohost)82 poll_fromhost();83 84 *tohost = val;85 }86 87 void htif_putuchar(outdev_t *dev, const char32_t ch)88 {89 if (ascii_check(ch))90 htif_cmd(HTIF_DEVICE_CONSOLE, HTIF_CONSOLE_PUTC, ch);91 else92 htif_cmd(HTIF_DEVICE_CONSOLE, HTIF_CONSOLE_PUTC, U_SPECIAL);93 } -
kernel/arch/sparc64/src/drivers/niagara.c
r51949d0 re9bc927 57 57 static niagara_instance_t *instance = NULL; 58 58 59 static void niagara_ putuchar(outdev_t *, const char32_t);59 static void niagara_write(outdev_t *, const char *, size_t); 60 60 61 61 /** Character device operations */ 62 62 static outdev_operations_t niagara_ops = { 63 .write = niagara_ putuchar,63 .write = niagara_write, 64 64 .redraw = NULL, 65 65 .scroll_up = NULL, … … 95 95 96 96 /** Write a single character to the standard output. */ 97 static inline void do_putchar( charc)97 static inline void do_putchar(uint8_t c) 98 98 { 99 99 /* Repeat until the buffer is non-full */ … … 102 102 } 103 103 104 /** Write a single character to the standard output. */ 105 static void niagara_putuchar(outdev_t *dev, char32_t ch) 106 { 107 if ((!outbuf_parea.mapped) || (console_override)) { 108 if (ascii_check(ch)) { 109 do_putchar(ch); 110 if (ch == '\n') 111 do_putchar('\r'); 112 } else { 113 do_putchar('?'); 114 } 104 static void niagara_write(outdev_t *dev, const char *s, size_t n) 105 { 106 /* If the userspace owns the console, do not output anything. */ 107 if (outbuf_parea.mapped && !console_override) 108 return; 109 110 const char *top = s + n; 111 assert(top >= s); 112 113 for (; s < top; s++) { 114 if (*s == '\n') 115 do_putchar('\r'); 116 117 do_putchar((uint8_t) *s); 115 118 } 116 119 } -
kernel/genarch/src/drivers/dsrln/dsrlnout.c
r51949d0 re9bc927 49 49 } dsrlnout_instance_t; 50 50 51 static void dsrlnout_ putuchar(outdev_t *dev, const char32_t ch)51 static void dsrlnout_write(outdev_t *dev, const char *s, size_t n) 52 52 { 53 53 dsrlnout_instance_t *instance = (dsrlnout_instance_t *) dev->data; 54 54 55 if ((!instance->parea.mapped) || (console_override)) { 56 if (ascii_check(ch)) 57 pio_write_8(instance->base, ch); 58 else 59 pio_write_8(instance->base, U_SPECIAL); 55 if (instance->parea.mapped && !console_override) 56 return; 57 58 const char *top = s + n; 59 assert(top >= s); 60 61 for (; s < top; s++) { 62 if (*s == '\n') 63 pio_write_8(instance->base, '\r'); 64 65 pio_write_8(instance->base, (uint8_t) *s); 60 66 } 61 67 } 62 68 63 69 static outdev_operations_t dsrlndev_ops = { 64 .write = dsrlnout_ putuchar,70 .write = dsrlnout_write, 65 71 .redraw = NULL, 66 72 .scroll_up = NULL, -
kernel/genarch/src/drivers/omap/uart.c
r51949d0 re9bc927 49 49 } 50 50 51 static void omap_uart_ putuchar(outdev_t *dev, char32_t ch)51 static void omap_uart_write(outdev_t *dev, const char *s, size_t n) 52 52 { 53 53 omap_uart_t *uart = dev->data; 54 if (!ascii_check(ch)) { 55 omap_uart_txb(uart, U_SPECIAL); 56 } else { 57 if (ch == '\n') 54 55 const char *top = s + n; 56 assert(top >= s); 57 58 for (; s < top; s++) { 59 if (*s == '\n') 58 60 omap_uart_txb(uart, '\r'); 59 omap_uart_txb(uart, ch); 61 62 omap_uart_txb(uart, (uint8_t) *s); 60 63 } 61 64 } 62 65 63 66 static outdev_operations_t omap_uart_ops = { 64 .write = omap_uart_ putuchar,67 .write = omap_uart_write, 65 68 .redraw = NULL, 66 69 .scroll_up = NULL, -
kernel/genarch/src/drivers/s3c24xx/uart.c
r51949d0 re9bc927 49 49 #include <str.h> 50 50 51 static void s3c24xx_uart_sendb( outdev_t *dev, uint8_t byte)51 static void s3c24xx_uart_sendb(s3c24xx_uart_t *uart, uint8_t byte) 52 52 { 53 s3c24xx_uart_t *uart =54 (s3c24xx_uart_t *) dev->data;55 56 53 /* Wait for space becoming available in Tx FIFO. */ 57 54 while ((pio_read_32(&uart->io->ufstat) & S3C24XX_UFSTAT_TX_FULL) != 0) … … 61 58 } 62 59 63 static void s3c24xx_uart_ putuchar(outdev_t *dev, char32_t ch)60 static void s3c24xx_uart_write(outdev_t *dev, const char *s, size_t n) 64 61 { 65 s3c24xx_uart_t *uart = 66 (s3c24xx_uart_t *) dev->data; 62 s3c24xx_uart_t *uart = dev->data; 67 63 68 if ((!uart->parea.mapped) || (console_override)) { 69 if (!ascii_check(ch)) { 70 s3c24xx_uart_sendb(dev, U_SPECIAL); 71 } else { 72 if (ch == '\n') 73 s3c24xx_uart_sendb(dev, (uint8_t) '\r'); 74 s3c24xx_uart_sendb(dev, (uint8_t) ch); 75 } 64 /* If the userspace owns the console, do not output anything. */ 65 if (uart->parea.mapped && !console_override) 66 return; 67 68 const char *top = s + n; 69 assert(top >= s); 70 71 for (; s < top; s++) { 72 if (*s == '\n') 73 s3c24xx_uart_sendb(uart, '\r'); 74 75 s3c24xx_uart_sendb(uart, (uint8_t) *s); 76 76 } 77 77 } … … 94 94 95 95 static outdev_operations_t s3c24xx_uart_ops = { 96 .write = s3c24xx_uart_ putuchar,96 .write = s3c24xx_uart_write, 97 97 .redraw = NULL, 98 98 .scroll_up = NULL,
Note:
See TracChangeset
for help on using the changeset viewer.