summaryrefslogtreecommitdiffstats
path: root/c/src/lib/libbsp/i386/shared/irq/irq_asm.h
blob: 31575adb94e6e7ef76118eeade08e47c5728e2fa (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/**
 * @file
 * @ingroup i386_irq
 * @brief
 */

/* irq_asm.h
 *
 *  This include file has defines to represent some contant used
 *  to program and manage the  Intel 8259 interrupt controller
 *
 *
 *  COPYRIGHT (c) 1998 valette@crf.canon.fr
 *
 *  The license and distribution terms for this file may be
 *  found in the file LICENSE in this distribution or at
 *  http://www.rtems.org/license/LICENSE.
 */
#ifndef __IRQ_ASM_H__
#define __IRQ_ASM_H__

#define BSP_ASM_IRQ_VECTOR_BASE 0x20
    /** @brief PIC's command and mask registers */
#define PIC_MASTER_COMMAND_IO_PORT		0x20	///< Master PIC command register
#define PIC_SLAVE_COMMAND_IO_PORT		0xa0	///< Slave PIC command register
#define PIC_MASTER_IMR_IO_PORT			0x21	///< Master PIC Interrupt Mask Register
#define PIC_SLAVE_IMR_IO_PORT		 	0xa1	///< Slave PIC Interrupt Mask Register

    /** @brief Command for specific EOI (End Of Interrupt): Interrupt acknowledge */
#define PIC_EOSI	0x60	///< End of Specific Interrupt (EOSI)
#define PIC_EOI		0x20	///< Generic End of Interrupt (EOI)

#endif