Files
Custom-Operating-System/kernel/include/drivers/irq/arm/gicv2.h

70 lines
1.8 KiB
C

#ifndef _KERNEL_DRIVERS_IRQ_ARM_GICV2_H
#define _KERNEL_DRIVERS_IRQ_ARM_GICV2_H
#include <drivers/driver_manager.h>
#include <drivers/irq/irq_api.h>
#include <libkern/mask.h>
#include <libkern/types.h>
enum GICDControlMasks {
MASKDEFINE(GICD_ENABLE, 0, 1),
};
enum GICCControlMasks {
MASKDEFINE(GICC_ENABLE_GR1, 0, 1),
MASKDEFINE(GICC_FIQ_BYP_DIS_GR1, 5, 1),
MASKDEFINE(GICC_IRQ_BYP_DIS_GR1, 6, 1),
MASKDEFINE(GICC_EO_IMODE_NS, 9, 1),
};
struct gicv2_distributor_registers {
uint32_t control;
uint32_t typer;
uint32_t iidr;
SKIP(0x008 + 0x4, 0x080);
uint32_t igroup[8];
SKIP(0x09C + 0x4, 0x100);
uint32_t isenabler[8];
SKIP(0x11C + 0x4, 0x180);
uint32_t icenabler[8];
SKIP(0x19C + 0x4, 0x200);
uint32_t ispendr[8];
SKIP(0x21C + 0x4, 0x280);
uint32_t icpendr[8];
SKIP(0x29C + 0x4, 0x300);
uint32_t isactiver[8];
SKIP(0x31C + 0x4, 0x380);
uint32_t icactiver[8];
SKIP(0x39C + 0x4, 0x400);
uint32_t ipriorityr[64];
SKIP(0x4FC + 0x4, 0x800);
uint32_t itargetsr[64];
SKIP(0x8FC + 0x4, 0xC00);
uint32_t icfgr[16];
// TO BE CONTINUED
};
typedef struct gicv2_distributor_registers gicv2_distributor_registers_t;
struct gicv2_cpu_interface_registers {
uint32_t control;
uint32_t pmr;
uint32_t bpr;
uint32_t iar;
uint32_t eoir;
uint32_t hppir;
uint32_t abpr;
uint32_t aiar;
uint32_t aeoir;
uint32_t ahppir;
// TO BE CONTINUED
};
typedef struct gicv2_cpu_interface_registers gicv2_cpu_interface_registers_t;
void gicv2_enable_irq(irq_line_t id, irq_priority_t prior, irq_flags_t flags, int cpu_mask);
void gicv2_install();
void gicv2_install_secondary_cpu();
uint32_t gicv2_interrupt_descriptor();
void gicv2_end(uint32_t int_disc);
#endif //_KERNEL_DRIVERS_IRQ_ARM_GICV2_H