Diferencias
Muestra las diferencias entre dos versiones de la página.
Ambos lados, revisión anterior Revisión previa Próxima revisión | Revisión previa | ||
arm_interrupt_controllers [2023/05/16 23:41] cnigri Configuracion GIC codigo ensamblador |
arm_interrupt_controllers [2024/06/03 20:16] (actual) cnigri Fix Incorporacion de registro de control de la interfaz con el CPU |
||
---|---|---|---|
Línea 4: | Línea 4: | ||
Antes de comenzar vale la pena recordar dos conceptos elementales: | Antes de comenzar vale la pena recordar dos conceptos elementales: | ||
* Un controlador de interrupción es un módulo (IC, ASIC, FPGA, etc) que se encuentran entre las fuentes de interrupción (periféricos) y **los núcleos** ARM, el cual decide cómo gestionar (priorizar, habilitar, direccionar) las interrupciones. | * Un controlador de interrupción es un módulo (IC, ASIC, FPGA, etc) que se encuentran entre las fuentes de interrupción (periféricos) y **los núcleos** ARM, el cual decide cómo gestionar (priorizar, habilitar, direccionar) las interrupciones. | ||
- | * El núcleo ARM acepta solo dos señales de entrada no programadas que manejan interrupciones de los sistemas externos: nIRQ y nFIQ. Como se debería saber si se recibe IRQ, el sistema ingresa al modo IRQ o FIQ, si se recibe | + | * El núcleo ARM acepta solo **dos señales** de entrada no programadas que manejan interrupciones de los sistemas externos: |
Si bien dependiendo de las licencias ARM, es decir del fabricante de SoC, se decide el mecanismo para direccionar las señales de interrupción al núcleo, en este artículo se tratará el método estandarizado y más frecuentemente empleado, el [[https:// | Si bien dependiendo de las licencias ARM, es decir del fabricante de SoC, se decide el mecanismo para direccionar las señales de interrupción al núcleo, en este artículo se tratará el método estandarizado y más frecuentemente empleado, el [[https:// | ||
Línea 13: | Línea 13: | ||
{{ : | {{ : | ||
- | Si bien el diagrama presenta la arquitectura para múltiples núcleos (processors), | + | Si bien el diagrama presenta la arquitectura para múltiples núcleos (processors), |
Según la fuente, hay tres tipos principales de interrupciones definidas. | Según la fuente, hay tres tipos principales de interrupciones definidas. | ||
Línea 56: | Línea 56: | ||
CPU Interface | CPU Interface | ||
- | < | + | El valor especifico de la dirección base se brinda en la documentación especifica de cada fabricante ([[https:// |
+ | < | ||
#include < | #include < | ||
- | /*GIC Register Definitions | + | /*GIC Register Definitions*/ |
- | #define ICCICR | + | #if defined(__PB_A8__) |
- | #define ICDDCR | + | #define GIC0_CPU_BASE |
- | #define ICDICTR | + | #define GIC0_DISTRIBUTOR_BASE |
- | #define ICDISER(n) | + | #elif defined(i386) |
- | #define ICDICER(n) | + | #define GIC0_CPU_BASE |
- | #define ICDIPR(n) | + | #define GIC0_DISTRIBUTOR_BASE |
- | #define ICDIPTR(n) | + | #endif |
- | #define ICDICFR(n) | + | |
+ | #define ICCICR | ||
+ | #define ICCPMR | ||
+ | #define ICCBPR | ||
+ | #define ICCIAR | ||
+ | #define ICCEOIR | ||
+ | #define ICDDCR | ||
+ | #define ICDICTR | ||
+ | #define ICDISER(n) | ||
+ | #define ICDICER(n) | ||
+ | #define ICDIPR(n) | ||
+ | #define ICDIPTR(n) | ||
+ | #define ICDICFR(n) | ||
</ | </ | ||
Línea 97: | Línea 110: | ||
| | ||
} | } | ||
- | </ | + | </ |
+ | |||
+ | |||
+ | ===== Gestión de las interrupciones en el Core ===== | ||
+ | En los párrafos precedentes se brindó una referencia básica sobre la operación y configuración del //GIC//, es decir sobre el sistema de gestión de interrupciones externo al/los núcleos, a continuación el artículo se centrará sobre la contra-parte situada en el propio núcleo. | ||
+ | En esta instancia es bien sabido que cada [[https:// | ||
+ | |||
+ | <code asm> | ||
+ | stack_setup_irq: | ||
+ | cps #0xd2 | ||
+ | |||
+ | ldr r0, # | ||
+ | sub sp, r0, # | ||
+ | |||
+ | cpsie if, #0x13 | ||
+ | |||
+ | mov pc, lr @retorna | ||
+ | </ | ||
+ | |||
+ | Una vez que el //GIC// a señalizado al núcleo respecto a una interrupción pendiente, este debe realizar una [[https:// | ||
+ | |||
+ | <code asm> | ||
+ | irq_handler: | ||
+ | sub lr, lr, #4 @retornar a la instruccion en ejecucion al momento de la interrupcion | ||
+ | stmfd sp!, {r0-r12, lr} | ||
+ | |||
+ | mrs r11, spsr | ||
+ | push {r11} | ||
+ | |||
+ | @bl handler_dispatch | ||
+ | bl timer0_handler | ||
+ | |||
+ | @bl data_synchronization_barrier | ||
+ | |||
+ | pop {r11} | ||
+ | msr spsr, r11 | ||
+ | |||
+ | ldmfd sp!, {r0-r12, pc}^ @restaura contexto y retorna | ||
+ | </ | ||
===== Caso de uso PB-A8 ===== | ===== Caso de uso PB-A8 ===== | ||
A los fines de la placa empleada, para la resolución de la guía de trabajos prácticos del primer cuatrimestre, | A los fines de la placa empleada, para la resolución de la guía de trabajos prácticos del primer cuatrimestre, | ||
Línea 110: | Línea 162: | ||
mov r0, #0 | mov r0, #0 | ||
ldr r1, =0x1E001000 | ldr r1, =0x1E001000 | ||
- | | + | |
mov r0, #36 @IRQ ID 36 para Timer0 | mov r0, #36 @IRQ ID 36 para Timer0 | ||
Línea 124: | Línea 176: | ||
mov r0, #1 | mov r0, #1 | ||
ldr r1, =0x1E000000 | ldr r1, =0x1E000000 | ||
- | | + | |
mov r0, #1 | mov r0, #1 | ||
ldr r1, =0x1E001000 | ldr r1, =0x1E001000 | ||
- | | + | |
pop {r0-r1, pc} | pop {r0-r1, pc} | ||
Línea 174: | Línea 226: | ||
{{ : | {{ : | ||
- | --- // | + | --- // |