hpsim_console.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. /*
  2. * Platform dependent support for HP simulator.
  3. *
  4. * Copyright (C) 1998, 1999, 2002 Hewlett-Packard Co
  5. * David Mosberger-Tang <davidm@hpl.hp.com>
  6. * Copyright (C) 1999 Vijay Chander <vijay@engr.sgi.com>
  7. */
  8. #include <linux/init.h>
  9. #include <linux/kernel.h>
  10. #include <linux/param.h>
  11. #include <linux/string.h>
  12. #include <linux/types.h>
  13. #include <linux/tty.h>
  14. #include <linux/kdev_t.h>
  15. #include <linux/console.h>
  16. #include <asm/delay.h>
  17. #include <asm/irq.h>
  18. #include <asm/pal.h>
  19. #include <asm/machvec.h>
  20. #include <asm/pgtable.h>
  21. #include <asm/sal.h>
  22. #include "hpsim_ssc.h"
  23. static int simcons_init (struct console *, char *);
  24. static void simcons_write (struct console *, const char *, unsigned);
  25. static struct tty_driver *simcons_console_device (struct console *, int *);
  26. struct console hpsim_cons = {
  27. .name = "simcons",
  28. .write = simcons_write,
  29. .device = simcons_console_device,
  30. .setup = simcons_init,
  31. .flags = CON_PRINTBUFFER,
  32. .index = -1,
  33. };
  34. static int
  35. simcons_init (struct console *cons, char *options)
  36. {
  37. return 0;
  38. }
  39. static void
  40. simcons_write (struct console *cons, const char *buf, unsigned count)
  41. {
  42. unsigned long ch;
  43. while (count-- > 0) {
  44. ch = *buf++;
  45. ia64_ssc(ch, 0, 0, 0, SSC_PUTCHAR);
  46. if (ch == '\n')
  47. ia64_ssc('\r', 0, 0, 0, SSC_PUTCHAR);
  48. }
  49. }
  50. static struct tty_driver *simcons_console_device (struct console *c, int *index)
  51. {
  52. extern struct tty_driver *hp_simserial_driver;
  53. *index = c->index;
  54. return hp_simserial_driver;
  55. }