Changed object array to pointer array for GPIOs

This commit is contained in:
2025-09-01 02:29:03 -07:00
parent 0418e3d5c5
commit db75c06c90
4 changed files with 39 additions and 30 deletions

View File

@@ -4,6 +4,27 @@
#include "SHAL_GPIO.h"
unsigned long getPinMode(PinMode mode){
switch(mode){
case PinMode::INPUT_MODE:
return 0b00;
case PinMode::OUTPUT_MODE:
return 0b01;
case PinMode::ALTERNATE_FUNCTION_MODE:
return 0b10;
case PinMode::ANALOG_MODE:
return 0b11;
case PinMode::INVALID:
assert(false);
return 0;
}
__builtin_unreachable();
}
GPIO::GPIO(){
//Do not initialize anything
}
@@ -15,9 +36,10 @@ GPIO::GPIO(GPIO_Key key, PinMode pinMode) : m_GPIO_KEY(key),
volatile unsigned long* gpioEnable = getGPIORCCEnable(key).reg;
unsigned long gpioOffset = getGPIORCCEnable(key).offset;
*gpioEnable |= (1 << gpioOffset);
*gpioEnable |= (1 << gpioOffset); //Set enable flag
p_GPIORegister->MODER |= (getPinMode(pinMode) << (2 * m_offset));
p_GPIORegister->MODER &= ~(0b11 << (2 * m_offset)); //Clear any previous mode
p_GPIORegister->MODER |= (getPinMode(pinMode) << (2 * m_offset)); //Set mode based on pinmode bit structure
}
void GPIO::setLow() {
@@ -35,15 +57,15 @@ void GPIO::toggle() {
GPIO &GPIOManager::get(GPIO_Key key, PinMode pinMode) {
GPIO* GPIOManager::get(GPIO_Key key, PinMode pinMode) {
unsigned int gpioPort = getGPIOPortNumber(key);
unsigned long gpioPin = getGPIORegister(key).global_offset; //Use existing structs to get offset
GPIO curr = m_gpios[gpioPort][gpioPin];
GPIO curr = *m_gpios[gpioPort][gpioPin];
if(curr.m_GPIO_KEY == GPIO_Key::INVALID || curr.m_pinMode != pinMode){
m_gpios[gpioPort][gpioPin] = GPIO(key,pinMode);
*m_gpios[gpioPort][gpioPin] = GPIO(key,pinMode);
}
return m_gpios[gpioPort][gpioPin];