Blame view

kernel/linux-rt-4.4.41/arch/sparc/prom/console_32.c 1.18 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
  /*
   * console.c: Routines that deal with sending and receiving IO
   *            to/from the current console device using the PROM.
   *
   * Copyright (C) 1995 David S. Miller (davem@caip.rutgers.edu)
   * Copyright (C) 1998 Pete Zaitcev <zaitcev@yahoo.com>
   */
  
  #include <linux/types.h>
  #include <linux/kernel.h>
  #include <linux/sched.h>
  #include <asm/openprom.h>
  #include <asm/oplib.h>
  #include <linux/string.h>
  
  extern void restore_current(void);
  
  /* Non blocking put character to console device, returns -1 if
   * unsuccessful.
   */
  static int prom_nbputchar(const char *buf)
  {
  	unsigned long flags;
  	int i = -1;
  
  	spin_lock_irqsave(&prom_lock, flags);
  	switch(prom_vers) {
  	case PROM_V0:
  		if ((*(romvec->pv_nbputchar))(*buf))
  			i = 1;
  		break;
  	case PROM_V2:
  	case PROM_V3:
  		if ((*(romvec->pv_v2devops).v2_dev_write)(*romvec->pv_v2bootargs.fd_stdout,
  							  buf, 0x1) == 1)
  			i = 1;
  		break;
  	default:
  		break;
  	}
  	restore_current();
  	spin_unlock_irqrestore(&prom_lock, flags);
  	return i; /* Ugh, we could spin forever on unsupported proms ;( */
  }
  
  void prom_console_write_buf(const char *buf, int len)
  {
  	while (len) {
  		int n = prom_nbputchar(buf);
  		if (n < 0)
  			continue;
  		len--;
  		buf++;
  	}
  }