blob: 24031971f8067b9c9770f34b8f682d62c54b865c [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * printf.c: Internal prom library printf facility.
3 *
4 * Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu)
5 * Copyright (C) 1997 Jakub Jelinek (jj@sunsite.mff.cuni.cz)
6 * Copyright (c) 2002 Pete Zaitcev (zaitcev@yahoo.com)
7 *
8 * We used to warn all over the code: DO NOT USE prom_printf(),
9 * and yet people do. Anton's banking code was outputting banks
10 * with prom_printf for most of the 2.4 lifetime. Since an effective
11 * stick is not available, we deployed a carrot: an early printk
12 * through PROM by means of -p boot option. This ought to fix it.
13 * USE printk; if you need, deploy -p.
14 */
15
16#include <linux/kernel.h>
David S. Millerbd4352c2009-09-04 03:38:54 -070017#include <linux/compiler.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070018
19#include <asm/openprom.h>
20#include <asm/oplib.h>
21
22static char ppbuf[1024];
23
David S. Millerbd4352c2009-09-04 03:38:54 -070024void notrace prom_write(const char *buf, unsigned int n)
Linus Torvalds1da177e2005-04-16 15:20:36 -070025{
David S. Millere62cac12010-11-30 14:33:29 -080026 while (n-- != 0) {
27 char ch = *buf;
28 if (ch == '\n') {
29 char tmp = '\r';
30 prom_putchar(&tmp);
31 }
32 prom_putchar(buf);
33 buf++;
Linus Torvalds1da177e2005-04-16 15:20:36 -070034 }
35}
36
David S. Millerbd4352c2009-09-04 03:38:54 -070037void notrace prom_printf(const char *fmt, ...)
Linus Torvalds1da177e2005-04-16 15:20:36 -070038{
39 va_list args;
40 int i;
41
42 va_start(args, fmt);
43 i = vscnprintf(ppbuf, sizeof(ppbuf), fmt, args);
44 va_end(args);
45
46 prom_write(ppbuf, i);
47}