superio.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * Copyright (C) 2013 Imagination Technologies
  3. * Author: Paul Burton <paul.burton@imgtec.com>
  4. *
  5. * Setup code for the FDC37M817 super I/O controller
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #include <common.h>
  10. #include <asm/io.h>
  11. #define SIO_CONF_PORT 0x3f0
  12. #define SIO_DATA_PORT 0x3f1
  13. enum sio_conf_key {
  14. SIOCONF_DEVNUM = 0x07,
  15. SIOCONF_ACTIVATE = 0x30,
  16. SIOCONF_ENTER_SETUP = 0x55,
  17. SIOCONF_BASE_HIGH = 0x60,
  18. SIOCONF_BASE_LOW = 0x61,
  19. SIOCONF_PRIMARY_INT = 0x70,
  20. SIOCONF_EXIT_SETUP = 0xaa,
  21. SIOCONF_MODE = 0xf0,
  22. };
  23. static struct {
  24. u8 key;
  25. u8 data;
  26. } sio_config[] = {
  27. /* tty0 */
  28. { SIOCONF_DEVNUM, 0x04 },
  29. { SIOCONF_BASE_HIGH, 0x03 },
  30. { SIOCONF_BASE_LOW, 0xf8 },
  31. { SIOCONF_MODE, 0x02 },
  32. { SIOCONF_PRIMARY_INT, 0x04 },
  33. { SIOCONF_ACTIVATE, 0x01 },
  34. /* tty1 */
  35. { SIOCONF_DEVNUM, 0x05 },
  36. { SIOCONF_BASE_HIGH, 0x02 },
  37. { SIOCONF_BASE_LOW, 0xf8 },
  38. { SIOCONF_MODE, 0x02 },
  39. { SIOCONF_PRIMARY_INT, 0x03 },
  40. { SIOCONF_ACTIVATE, 0x01 },
  41. };
  42. void malta_superio_init(void)
  43. {
  44. unsigned i;
  45. /* enter config state */
  46. outb(SIOCONF_ENTER_SETUP, SIO_CONF_PORT);
  47. /* configure peripherals */
  48. for (i = 0; i < ARRAY_SIZE(sio_config); i++) {
  49. outb(sio_config[i].key, SIO_CONF_PORT);
  50. outb(sio_config[i].data, SIO_DATA_PORT);
  51. }
  52. /* exit config state */
  53. outb(SIOCONF_EXIT_SETUP, SIO_CONF_PORT);
  54. }