/** * @file gpio_helper.c * @brief General I/O helper * * @date Aug 25, 2013 * @author Andrey Belomutskiy, (c) 2012-2014 * * This file is part of rusEfi - see http://rusefi.com * * rusEfi is free software; you can redistribute it and/or modify it under the terms of * the GNU General Public License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * rusEfi is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without * even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with this program. * If not, see . */ #ifndef GPIO_HELPER_C_ #define GPIO_HELPER_C_ #include #include "pin_repository.h" #include "gpio_helper.h" /** * @brief Initialize the hardware output pin while also assigning it a logical name */ void initOutputPinExt(const char *msg, OutputPin *outputPin, GPIO_TypeDef *port, uint32_t pinNumber, iomode_t mode) { outputPin->currentLogicValue = -1; outputPin->port = port; outputPin->pin = pinNumber; mySetPadMode(msg, port, pinNumber, mode); } void initOutputPin(const char *msg, OutputPin *outputPin, GPIO_TypeDef *port, uint32_t pinNumber) { initOutputPinExt(msg, outputPin, port, pinNumber, PAL_MODE_OUTPUT_PUSHPULL); } int getLogicPinValue(OutputPin * outputPin) { return outputPin->currentLogicValue; } /** * Set's the value of the pin. On this layer the value is assigned as is, without any conversion. */ void setPinValue(OutputPin * outputPin, int electricalValue, int logicValue) { if (getLogicPinValue(outputPin) == logicValue) return; palWritePad(outputPin->port, outputPin->pin, electricalValue); outputPin->currentLogicValue = logicValue; } #endif /* GPIO_HELPER_C_ */