44 lines
		
	
	
		
			936 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			936 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  * 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
 | |
| 
 | |
| /* Direct addressed register */
 | |
| #define IO_APIC_INDEX		(IO_APIC_ADDR + 0x00)
 | |
| #define IO_APIC_DATA		(IO_APIC_ADDR + 0x10)
 | |
| 
 | |
| /* 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);
 | |
| 
 | |
| void io_apic_set_id(int ioapic_id);
 | |
| 
 | |
| #endif
 | 
