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;
|
2023-09-04 19:38:48 +05:30
|
|
|
__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;
|
|
|
|
|
|
|
|
}
|