blob: ca869266b9f3d0106e60d7b8c28f5cdcf614826b [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{
26 char ch;
27
28 while (n != 0) {
29 --n;
30 if ((ch = *buf++) == '\n')
31 prom_putchar('\r');
32 prom_putchar(ch);
33 }
34}
35
David S. Millerbd4352c2009-09-04 03:38:54 -070036void notrace prom_printf(const char *fmt, ...)
Linus Torvalds1da177e2005-04-16 15:20:36 -070037{
38 va_list args;
39 int i;
40
41 va_start(args, fmt);
42 i = vscnprintf(ppbuf, sizeof(ppbuf), fmt, args);
43 va_end(args);
44
45 prom_write(ppbuf, i);
46}