stdio.c 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  1. /*
  2. * Copyright (C) 2009 Sergey Kubushyn <ksi@koi8.net>
  3. *
  4. * Changes for multibus/multiadapter I2C support.
  5. *
  6. * (C) Copyright 2000
  7. * Paolo Scaffardi, AIRVENT SAM s.p.a - RIMINI(ITALY), arsenio@tin.it
  8. *
  9. * SPDX-License-Identifier: GPL-2.0+
  10. */
  11. #include <config.h>
  12. #include <common.h>
  13. #include <stdarg.h>
  14. #include <malloc.h>
  15. #include <stdio_dev.h>
  16. #include <serial.h>
  17. #ifdef CONFIG_LOGBUFFER
  18. #include <logbuff.h>
  19. #endif
  20. #if defined(CONFIG_HARD_I2C) || defined(CONFIG_SYS_I2C)
  21. #include <i2c.h>
  22. #endif
  23. DECLARE_GLOBAL_DATA_PTR;
  24. static struct stdio_dev devs;
  25. struct stdio_dev *stdio_devices[] = { NULL, NULL, NULL };
  26. char *stdio_names[MAX_FILES] = { "stdin", "stdout", "stderr" };
  27. #if defined(CONFIG_SPLASH_SCREEN) && !defined(CONFIG_SYS_DEVICE_NULLDEV)
  28. #define CONFIG_SYS_DEVICE_NULLDEV 1
  29. #endif
  30. #ifdef CONFIG_SYS_DEVICE_NULLDEV
  31. void nulldev_putc(struct stdio_dev *dev, const char c)
  32. {
  33. /* nulldev is empty! */
  34. }
  35. void nulldev_puts(struct stdio_dev *dev, const char *s)
  36. {
  37. /* nulldev is empty! */
  38. }
  39. int nulldev_input(struct stdio_dev *dev)
  40. {
  41. /* nulldev is empty! */
  42. return 0;
  43. }
  44. #endif
  45. void stdio_serial_putc(struct stdio_dev *dev, const char c)
  46. {
  47. serial_putc(c);
  48. }
  49. void stdio_serial_puts(struct stdio_dev *dev, const char *s)
  50. {
  51. serial_puts(s);
  52. }
  53. int stdio_serial_getc(struct stdio_dev *dev)
  54. {
  55. return serial_getc();
  56. }
  57. int stdio_serial_tstc(struct stdio_dev *dev)
  58. {
  59. return serial_tstc();
  60. }
  61. /**************************************************************************
  62. * SYSTEM DRIVERS
  63. **************************************************************************
  64. */
  65. static void drv_system_init (void)
  66. {
  67. struct stdio_dev dev;
  68. memset (&dev, 0, sizeof (dev));
  69. strcpy (dev.name, "serial");
  70. dev.flags = DEV_FLAGS_OUTPUT | DEV_FLAGS_INPUT | DEV_FLAGS_SYSTEM;
  71. dev.putc = stdio_serial_putc;
  72. dev.puts = stdio_serial_puts;
  73. dev.getc = stdio_serial_getc;
  74. dev.tstc = stdio_serial_tstc;
  75. stdio_register (&dev);
  76. #ifdef CONFIG_SYS_DEVICE_NULLDEV
  77. memset (&dev, 0, sizeof (dev));
  78. strcpy (dev.name, "nulldev");
  79. dev.flags = DEV_FLAGS_OUTPUT | DEV_FLAGS_INPUT | DEV_FLAGS_SYSTEM;
  80. dev.putc = nulldev_putc;
  81. dev.puts = nulldev_puts;
  82. dev.getc = nulldev_input;
  83. dev.tstc = nulldev_input;
  84. stdio_register (&dev);
  85. #endif
  86. }
  87. /**************************************************************************
  88. * DEVICES
  89. **************************************************************************
  90. */
  91. struct list_head* stdio_get_list(void)
  92. {
  93. return &(devs.list);
  94. }
  95. struct stdio_dev* stdio_get_by_name(const char *name)
  96. {
  97. struct list_head *pos;
  98. struct stdio_dev *dev;
  99. if(!name)
  100. return NULL;
  101. list_for_each(pos, &(devs.list)) {
  102. dev = list_entry(pos, struct stdio_dev, list);
  103. if(strcmp(dev->name, name) == 0)
  104. return dev;
  105. }
  106. return NULL;
  107. }
  108. struct stdio_dev* stdio_clone(struct stdio_dev *dev)
  109. {
  110. struct stdio_dev *_dev;
  111. if(!dev)
  112. return NULL;
  113. _dev = calloc(1, sizeof(struct stdio_dev));
  114. if(!_dev)
  115. return NULL;
  116. memcpy(_dev, dev, sizeof(struct stdio_dev));
  117. return _dev;
  118. }
  119. int stdio_register (struct stdio_dev * dev)
  120. {
  121. struct stdio_dev *_dev;
  122. _dev = stdio_clone(dev);
  123. if(!_dev)
  124. return -1;
  125. list_add_tail(&(_dev->list), &(devs.list));
  126. return 0;
  127. }
  128. /* deregister the device "devname".
  129. * returns 0 if success, -1 if device is assigned and 1 if devname not found
  130. */
  131. #ifdef CONFIG_SYS_STDIO_DEREGISTER
  132. int stdio_deregister(const char *devname)
  133. {
  134. int l;
  135. struct list_head *pos;
  136. struct stdio_dev *dev;
  137. char temp_names[3][16];
  138. dev = stdio_get_by_name(devname);
  139. if(!dev) /* device not found */
  140. return -1;
  141. /* get stdio devices (ListRemoveItem changes the dev list) */
  142. for (l=0 ; l< MAX_FILES; l++) {
  143. if (stdio_devices[l] == dev) {
  144. /* Device is assigned -> report error */
  145. return -1;
  146. }
  147. memcpy (&temp_names[l][0],
  148. stdio_devices[l]->name,
  149. sizeof(temp_names[l]));
  150. }
  151. list_del(&(dev->list));
  152. /* reassign Device list */
  153. list_for_each(pos, &(devs.list)) {
  154. dev = list_entry(pos, struct stdio_dev, list);
  155. for (l=0 ; l< MAX_FILES; l++) {
  156. if(strcmp(dev->name, temp_names[l]) == 0)
  157. stdio_devices[l] = dev;
  158. }
  159. }
  160. return 0;
  161. }
  162. #endif /* CONFIG_SYS_STDIO_DEREGISTER */
  163. int stdio_init (void)
  164. {
  165. #if defined(CONFIG_NEEDS_MANUAL_RELOC)
  166. /* already relocated for current ARM implementation */
  167. ulong relocation_offset = gd->reloc_off;
  168. int i;
  169. /* relocate device name pointers */
  170. for (i = 0; i < (sizeof (stdio_names) / sizeof (char *)); ++i) {
  171. stdio_names[i] = (char *) (((ulong) stdio_names[i]) +
  172. relocation_offset);
  173. }
  174. #endif /* CONFIG_NEEDS_MANUAL_RELOC */
  175. /* Initialize the list */
  176. INIT_LIST_HEAD(&(devs.list));
  177. #ifdef CONFIG_SYS_I2C
  178. i2c_init_all();
  179. #else
  180. #if defined(CONFIG_HARD_I2C)
  181. i2c_init (CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE);
  182. #endif
  183. #endif
  184. #ifdef CONFIG_LCD
  185. drv_lcd_init ();
  186. #endif
  187. #if defined(CONFIG_VIDEO) || defined(CONFIG_CFB_CONSOLE)
  188. drv_video_init ();
  189. #endif
  190. #ifdef CONFIG_KEYBOARD
  191. drv_keyboard_init ();
  192. #endif
  193. #ifdef CONFIG_LOGBUFFER
  194. drv_logbuff_init ();
  195. #endif
  196. drv_system_init ();
  197. serial_stdio_init ();
  198. #ifdef CONFIG_USB_TTY
  199. drv_usbtty_init ();
  200. #endif
  201. #ifdef CONFIG_NETCONSOLE
  202. drv_nc_init ();
  203. #endif
  204. #ifdef CONFIG_JTAG_CONSOLE
  205. drv_jtag_console_init ();
  206. #endif
  207. #ifdef CONFIG_CBMEM_CONSOLE
  208. cbmemc_init();
  209. #endif
  210. return (0);
  211. }