serial_8250.h 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /*
  2. * linux/include/linux/serial_8250.h
  3. *
  4. * Copyright (C) 2004 Russell King
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. */
  11. #ifndef _LINUX_SERIAL_8250_H
  12. #define _LINUX_SERIAL_8250_H
  13. #include <linux/serial_core.h>
  14. #include <linux/platform_device.h>
  15. /*
  16. * This is the platform device platform_data structure
  17. */
  18. struct plat_serial8250_port {
  19. unsigned long iobase; /* io base address */
  20. void __iomem *membase; /* ioremap cookie or NULL */
  21. resource_size_t mapbase; /* resource base */
  22. unsigned int irq; /* interrupt number */
  23. unsigned long irqflags; /* request_irq flags */
  24. unsigned int uartclk; /* UART clock rate */
  25. void *private_data;
  26. unsigned char regshift; /* register shift */
  27. unsigned char iotype; /* UPIO_* */
  28. unsigned char hub6;
  29. upf_t flags; /* UPF_* flags */
  30. unsigned int type; /* If UPF_FIXED_TYPE */
  31. unsigned int (*serial_in)(struct uart_port *, int);
  32. void (*serial_out)(struct uart_port *, int, int);
  33. };
  34. /*
  35. * Allocate 8250 platform device IDs. Nothing is implied by
  36. * the numbering here, except for the legacy entry being -1.
  37. */
  38. enum {
  39. PLAT8250_DEV_LEGACY = -1,
  40. PLAT8250_DEV_PLATFORM,
  41. PLAT8250_DEV_PLATFORM1,
  42. PLAT8250_DEV_PLATFORM2,
  43. PLAT8250_DEV_FOURPORT,
  44. PLAT8250_DEV_ACCENT,
  45. PLAT8250_DEV_BOCA,
  46. PLAT8250_DEV_EXAR_ST16C554,
  47. PLAT8250_DEV_HUB6,
  48. PLAT8250_DEV_MCA,
  49. PLAT8250_DEV_AU1X00,
  50. PLAT8250_DEV_SM501,
  51. };
  52. /*
  53. * This should be used by drivers which want to register
  54. * their own 8250 ports without registering their own
  55. * platform device. Using these will make your driver
  56. * dependent on the 8250 driver.
  57. */
  58. struct uart_port;
  59. int serial8250_register_port(struct uart_port *);
  60. void serial8250_unregister_port(int line);
  61. void serial8250_suspend_port(int line);
  62. void serial8250_resume_port(int line);
  63. extern int early_serial_setup(struct uart_port *port);
  64. extern int serial8250_find_port(struct uart_port *p);
  65. extern int serial8250_find_port_for_earlycon(void);
  66. extern int setup_early_serial8250_console(char *cmdline);
  67. #endif