c - 有没有办法为 AVR gcc 中的引脚定义宏,以便我可以将它们作为变量访问



我正在尝试为 AVR C 代码编写定义,以便我可以通过模拟宏来访问引脚,例如

STATUS_LED_OUT =1; 

在 GENET_HW_DEF.h 文件中,包含在主 C 文件中。您可以通过将此文件包含在任何 C 项目中来重现此错误。我使用的是 avr studio 6.2 和 7 - 两者都给出相同的结果。我无法编译如下所示的怪异宏展开消息。(中央处理器ATMega1284p(

D:_SVNCompassAVRCompass_IO_protoCompass IO_protoGENET_HW_DEF.h(19,49): error: expected ')' before '&' token
         #define REGISTER_BIT(rg,bt) ((volatile _io_reg*)&rg)->bit##bt
                                                         ^
D:_SVNCompassAVRCompass_IO_protoCompass IO_protoGENET_HW_DEF.h(42,25): info: in expansion of macro 'REGISTER_BIT'
          #define STATUS_LED_OUT REGISTER_BIT(PORTB,7)
                                 ^
D:_SVNCompassAVRCompass_IO_protoCompass IO_protoGENET_HW_DEF.h(46,2): info: in expansion of macro 'STATUS_LED_OUT'
          STATUS_LED_OUT=1;
          ^
有趣的是,仅

使用一两个声明复制到新项目中就可以很好地编译,直到对声明进行任何更改 - 例如添加另一个宏引用。然后它又卡住了。

另外 - 如果我评论所有宏用法,例如

STATUS_LED_DIR=1;
STATUS_LED_OUT=1; 

然后我能够编译项目,然后在取消注释使用行后,它仍然可以正常编译.. 直到执行 clean。我可能正在搞砸宏观怪癖,但我不知道在哪里。

typedef struct
{
    unsigned int bit0:1;
    unsigned int bit1:1;
    unsigned int bit2:1;
    unsigned int bit3:1;
    unsigned int bit4:1;
    unsigned int bit5:1;
    unsigned int bit6:1;
    unsigned int bit7:1;
} _io_reg;
#define REGISTER_BIT(rg,bt) ((volatile _io_reg*)&rg)->bit##bt
#ifndef GENET_HW_DEF
#define GENET_HW_DEF
// define functionalities and flags - comment/uncomment apropriate lines
#define GENET_USART_0 256
#define GENET_USART_1 256
#define F_CPU 20000000UL
#define STATUS_LED 7
#define ERROR_LED 4
#define ADC_GLOBAL_ENABLE A
#define ADC_CHANNEL_0 0
#define ADC_CHANNEL_1 4
#define ADC_CHANNEL_2 2
#define ADC_CHANNEL_3 3
#define ADC_CHANNEL_4 1
#define ADC_CHANNEL_5 5
#define ADC_CHANNEL_6 6
#define ADC_CHANNEL_7 7
// actual definitions and initialization
#ifdef STATUS_LED
    #define STATUS_LED_OUT REGISTER_BIT(PORTB,STATUS_LED)
    #define STATUS_LED_DIR REGISTER_BIT(DDRB,STATUS_LED)
    #define STATUS_LED_PIN REGISTER_BIT(PINB,STATUS_LED)
    STATUS_LED_DIR=1;
    STATUS_LED_OUT=1;
#endif
#ifdef ERROR_LED
    #define ERROR_LED_OUT REGISTER_BIT(PORTC,ERROR_LED)
    #define ERROR_LED_DIR REGISTER_BIT(DDRC,ERROR_LED)
    ERROR_LED_DIR=1;
    ERROR_LED_OUT=1;
#endif
#ifdef GENET_USART_0
    #define USART0_ENABLED
    #define UART_RX0_BUFFER_SIZE GENET_USART_0
    #define UART_TX0_BUFFER_SIZE GENET_USART_0
#endif
#ifdef GENET_USART_1
    #define USART1_ENABLED
    #define UART_RX1_BUFFER_SIZE GENET_USART_1
    #define UART_TX1_BUFFER_SIZE GENET_USART_1
#endif
#endif

我重现了你的问题。不能调用STATUS_LED_DIR=1;外部代码执行流。这必须位于函数内部(例如 main() (。现在您将以其他编译错误结束,但这是主要错误。

第二次更正,您需要 2 级进行串联

#define CONCAT(bt)  bit##bt 
#define REGISTER_BIT(rg,bt) ((volatile _io_reg*)&rg)->CONCAT(bt)

相关内容

最新更新