2016-01-23 14:38:51 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 Leon George
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
|
|
|
/**
|
2018-06-18 20:34:08 +02:00
|
|
|
* @ingroup cpu_cc26xx_cc13xx_definitions
|
2016-01-23 14:38:51 +01:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2018-06-18 20:34:08 +02:00
|
|
|
* @brief Driver for the cc26xx/cc13xx GPIO controller
|
2016-01-23 14:38:51 +01:00
|
|
|
*
|
|
|
|
* @author Leon George <leon@georgemail.eu>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2018-06-18 20:34:08 +02:00
|
|
|
#ifndef CC26XX_CC13XX_GPIO_H
|
|
|
|
#define CC26XX_CC13XX_GPIO_H
|
2016-01-23 14:38:51 +01:00
|
|
|
|
2018-06-18 20:34:08 +02:00
|
|
|
#include "cc26xx_cc13xx.h"
|
2016-01-23 14:38:51 +01:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @ingroup cpu_specific_peripheral_memory_map
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define GPIO_BASE (0x40022000) /**< GPIO base address */
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* GPIO registers
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
reg32_t DOUT_FRAG[8]; /**< w the first bit of each byte corresponds to one bit of DOUT */
|
|
|
|
reg32_t __reserved1[24]; /**< unused */
|
|
|
|
reg32_t DOUT; /**< r/w state of the output */
|
|
|
|
reg32_t __reserved2[3]; /**< unused */
|
|
|
|
reg32_t DOUTSET; /**< w1s set output */
|
|
|
|
reg32_t __reserved3[3]; /**< unused */
|
|
|
|
reg32_t DOUTCLR; /**< w1c clear output */
|
|
|
|
reg32_t __reserved4[3]; /**< unused */
|
|
|
|
reg32_t DOUTTGL; /**< r/w toggle output */
|
|
|
|
reg32_t __reserved5[3]; /**< unused */
|
|
|
|
reg32_t DIN; /**< r input status */
|
|
|
|
reg32_t __reserved6[3]; /**< unused */
|
|
|
|
reg32_t DOE; /**< r/w enable output */
|
|
|
|
reg32_t __reserved7[3]; /**< unused */
|
|
|
|
reg32_t EVFLAGS; /**< r/w1c indicates an input event */
|
|
|
|
} gpio_regs_t;
|
|
|
|
|
|
|
|
#define GPIO ((gpio_regs_t *) (GPIO_BASE)) /**< GPIO register bank */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* end extern "C" */
|
|
|
|
#endif
|
|
|
|
|
2018-06-18 20:34:08 +02:00
|
|
|
#endif /* CC26XX_CC13XX_GPIO_H */
|
2016-01-23 14:38:51 +01:00
|
|
|
|
|
|
|
/** @} */
|