EmbeddedLab2023/GPIO_Interrupts/main.c

109 lines
2.0 KiB
C
Raw Permalink Normal View History

2023-09-04 10:37:29 +05:30
#include <stdint.h>
#include "tm4c123gh6pm.h"
/**
* main.c
*/
void GPIO_PORTF_Init(void);
void SystickHandler(void);
void Systick_Init(void);
volatile uint32_t systick_count = 1;
int main(void)
{
GPIO_PORTF_Init();
//Systick_Init();
while(1);
}
void SW2_Handler(void)
{
2023-09-04 12:44:36 +05:30
//GPIO_PORTF_ICR_R = 0x11;
if(GPIO_PORTF_MIS_R & 0x01)
{
//PIN0 (SW2) pressed
GPIO_PORTF_DATA_R |= 0x8;
}
else if (GPIO_PORTF_MIS_R & 0x10)
{
GPIO_PORTF_DATA_R &= ~0x8;
}
GPIO_PORTF_ICR_R = 0x11;
__asm(" nop");
2023-09-04 10:37:29 +05:30
}
void SystickHandler(void)
{
systick_count++;
if(systick_count==1000)
{
systick_count = 0;
GPIO_PORTF_DATA_R ^= 0x2;
}
}
void Systick_Init()
{
NVIC_ST_RELOAD_R = 0x9C4;
NVIC_ST_CURRENT_R = 0x0;
//Enable Systick:
// SYST_CSR = 0x00000101 -- 0x5
NVIC_ST_CTRL_R = 0x5;
}
void GPIO_PORTF_Init(void)
{
//PF0 <-- SW2
//PF4 <-- SW1
//Need to enable interrupt on SW1
SYSCTL_RCGC2_R |= SYSCTL_RCGC2_GPIOF;
2023-09-04 12:44:36 +05:30
GPIO_PORTF_LOCK_R = 0x4C4F434B; /* unlock commit register */
GPIO_PORTF_CR_R = 0xFF; /* make PORTF0 configurable */
2023-09-04 10:37:29 +05:30
GPIO_PORTF_DEN_R = 0x1F;
GPIO_PORTF_PUR_R = 0x11;
GPIO_PORTF_DIR_R = 0x0E;
//Shut off all LEDs:
GPIO_PORTF_DATA_R=0x0;
// Enabling Interrupts
//GPIOIS -- Interrupt Sense --> 0 for edge --> 0x0
GPIO_PORTF_IS_R = 0x0;
//GPIOIBE -- Both Edges --> 0 for single edge --> 0x0
GPIO_PORTF_IBE_R = 0x0;
//GPIOIEV -- Interropt Event --> 0 for falling edge --> 0x00
GPIO_PORTF_IEV_R = 0x0;
//GPIOICR -- INterrpt clear -- must be cleared by writing 1 to corresponding bit --> 0xff
GPIO_PORTF_ICR_R = 0xff;
//GPIOIM -- Interrupt Mask --> 1 for unmasked (enabled)--> 0x01
2023-09-04 12:44:36 +05:30
GPIO_PORTF_IM_R = 0x11;
2023-09-04 10:37:29 +05:30
//GPIORIS -- Raw Int Status
//GPIOMIS -- Masked Int Status
//Interrupt Number = 30
// EN0 -- 0x40000000
NVIC_EN0_R = 0x40000000;
}