x86: Set serial port IRQ for SMSC LPC47M

For starting a Linux console on the superio serial port under
interrupt mode, the IRQ number must be configured.

Signed-off-by: Jian Luo <jian.luo4@boschrexroth.de>
Signed-off-by: Bin Meng <bmeng.cn@gmail.com>
Acked-by: Simon Glass <sjg@chromium.org>
master
Bin Meng 10 years ago committed by Simon Glass
parent d21d05f19a
commit 19268834fb
  1. 3
      arch/x86/include/asm/ibmpc.h
  2. 2
      board/intel/crownbay/crownbay.c
  3. 2
      board/intel/minnowmax/minnowmax.c
  4. 3
      drivers/misc/smsc_lpc47m.c
  5. 3
      include/smsc_lpc47m.h

@ -21,4 +21,7 @@
#define UART0_BASE 0x3f8 #define UART0_BASE 0x3f8
#define UART1_BASE 0x2f8 #define UART1_BASE 0x2f8
#define UART0_IRQ 4
#define UART1_IRQ 3
#endif #endif

@ -16,7 +16,7 @@ DECLARE_GLOBAL_DATA_PTR;
int board_early_init_f(void) int board_early_init_f(void)
{ {
lpc47m_enable_serial(SERIAL_DEV, UART0_BASE); lpc47m_enable_serial(SERIAL_DEV, UART0_BASE, UART0_IRQ);
return 0; return 0;
} }

@ -16,7 +16,7 @@ DECLARE_GLOBAL_DATA_PTR;
int board_early_init_f(void) int board_early_init_f(void)
{ {
lpc47m_enable_serial(SERIAL_DEV, UART0_BASE); lpc47m_enable_serial(SERIAL_DEV, UART0_BASE, UART0_IRQ);
return 0; return 0;
} }

@ -22,12 +22,13 @@ static void pnp_exit_conf_state(u16 dev)
outb(0xaa, port); outb(0xaa, port);
} }
void lpc47m_enable_serial(u16 dev, u16 iobase) void lpc47m_enable_serial(u16 dev, u16 iobase, u8 irq)
{ {
pnp_enter_conf_state(dev); pnp_enter_conf_state(dev);
pnp_set_logical_device(dev); pnp_set_logical_device(dev);
pnp_set_enable(dev, 0); pnp_set_enable(dev, 0);
pnp_set_iobase(dev, PNP_IDX_IO0, iobase); pnp_set_iobase(dev, PNP_IDX_IO0, iobase);
pnp_set_irq(dev, PNP_IDX_IRQ0, irq);
pnp_set_enable(dev, 1); pnp_set_enable(dev, 1);
pnp_exit_conf_state(dev); pnp_exit_conf_state(dev);
} }

@ -13,7 +13,8 @@
* *
* @dev: High 8 bits = Super I/O port, low 8 bits = logical device number. * @dev: High 8 bits = Super I/O port, low 8 bits = logical device number.
* @iobase: Processor I/O port address to assign to this serial device. * @iobase: Processor I/O port address to assign to this serial device.
* @irq: Processor IRQ number to assign to this serial device.
*/ */
void lpc47m_enable_serial(u16 dev, u16 iobase); void lpc47m_enable_serial(u16 dev, u16 iobase, u8 irq);
#endif /* _SMSC_LPC47M_H_ */ #endif /* _SMSC_LPC47M_H_ */

Loading…
Cancel
Save