diff options
Diffstat (limited to 'firmware/e300/battery/io.h')
-rw-r--r-- | firmware/e300/battery/io.h | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/firmware/e300/battery/io.h b/firmware/e300/battery/io.h new file mode 100644 index 000000000..81c007268 --- /dev/null +++ b/firmware/e300/battery/io.h @@ -0,0 +1,97 @@ +/* USRP E310 IO helpers + * Copyright (C) 2014 Ettus Research + * This file is part of the USRP E310 Firmware + * The USRP E310 Firmware 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 2 of the License, or + * (at your option) any later version. + * The USRP E310 Firmware 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 the USRP E310 Firmware. If not, see <http://www.gnu.org/licenses/>. + */ + +/** +* \file io.h +* \brief IO helper functions to manipulate the MCUs pins +*/ + +#ifndef IO_H +#define IO_H + +#include <stdint.h> +#include <stdbool.h> + +#define IO_PX(port, pin) ((uint8_t)(((port - 'A') << 4) + pin)) +#define IO_PA(pin) IO_PX('A', pin) +#define IO_PB(pin) IO_PX('B', pin) +#define IO_PC(pin) IO_PX('C', pin) +#define IO_PD(pin) IO_PX('D', pin) + +typedef const uint8_t io_pin_t; + +/** + * \brief Make pin an output pin + * + * \param pin The pin to modify + */ +void io_output_pin(io_pin_t pin); + +/** + * \brief Make pin an input pin + * + * \param pin The pin to modify + */ +void io_input_pin(io_pin_t pin); + +/** + * \brief Check if pin is an output + * + * \param pin The pin to query + * \return Returns true if the pin is configured as output + */ +bool io_is_output(io_pin_t pin); + +/** + * \brief Check if pin is an input + * + * \param pin The pin to query + * \return Returns true if the pin is configured as input + */ +bool io_is_input(io_pin_t pin); + +/** + * \brief If the pin is in input mode, this will enable the pull-up, + * if the pin is in output mode, this will set a logic high level + * + * \param[in] pin The pin to modify + */ +void io_set_pin(io_pin_t pin); + +/** + * \brief If the pin is in input mode this will disable the pull-up + * if the pin is in output mode, this will set a logic low level + * + * \param[in] pin The pin to modify + */ +void io_clear_pin(io_pin_t pin); + +/** + * \brief If the pin is in input mode, this returns true if the pull-up is active, + * if the pin is in output mode, this returns true if a logic high is set + * \param[in] pin The pin to query + * \return True if pin is set, False otherwise + */ +bool io_is_pin_set(io_pin_t pin); + + +/** + * \brief If the pin is in input mode, this returns the logic input value + * \param[in] pin The pin to query + * \return Returns true if a logic high is observed on the input pin + */ +bool io_test_pin(io_pin_t pin); + +#endif /* IO_H */ |