2018-05-06 21:58:06 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2014-11-15 01:18:27 +00:00
|
|
|
/*
|
|
|
|
* From coreboot file of the same name
|
|
|
|
*
|
|
|
|
* Copyright (C) 2010 coresystems GmbH
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __ASM_IOAPIC_H
|
|
|
|
#define __ASM_IOAPIC_H
|
|
|
|
|
|
|
|
#define IO_APIC_ADDR 0xfec00000
|
|
|
|
|
2015-06-23 04:18:48 +00:00
|
|
|
/* Direct addressed register */
|
|
|
|
#define IO_APIC_INDEX (IO_APIC_ADDR + 0x00)
|
|
|
|
#define IO_APIC_DATA (IO_APIC_ADDR + 0x10)
|
2014-11-15 01:18:27 +00:00
|
|
|
|
2015-06-23 04:18:49 +00:00
|
|
|
/* Indirect addressed register offset */
|
|
|
|
#define IO_APIC_ID 0x00
|
|
|
|
#define IO_APIC_VER 0x01
|
|
|
|
|
|
|
|
/**
|
|
|
|
* io_apic_read() - Read I/O APIC register
|
|
|
|
*
|
|
|
|
* This routine reads I/O APIC indirect addressed register.
|
|
|
|
*
|
|
|
|
* @reg: address of indirect addressed register
|
|
|
|
* @return: register value to read
|
|
|
|
*/
|
|
|
|
u32 io_apic_read(u32 reg);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* io_apic_write() - Write I/O APIC register
|
|
|
|
*
|
|
|
|
* This routine writes I/O APIC indirect addressed register.
|
|
|
|
*
|
|
|
|
* @reg: address of indirect addressed register
|
|
|
|
* @val: register value to write
|
|
|
|
*/
|
|
|
|
void io_apic_write(u32 reg, u32 val);
|
|
|
|
|
2016-03-12 05:07:34 +00:00
|
|
|
void io_apic_set_id(int ioapic_id);
|
|
|
|
|
2014-11-15 01:18:27 +00:00
|
|
|
#endif
|