我正在为ATmega168微控制器设置一个通用异步收发器。我的第一个代码不起作用。在检查时,我发现了一个在工作程序中使用的头文件。它使用预处理器指令。
它对我来说非常混乱,所以我决定在c编译器中运行它并检查输出。
#include <stdio.h>
#define F_CPU 1000000UL
#ifndef BAUD /* if not defined in Makefile... */
#define BAUD 9600 /* set a safe default baud rate */
#endif
#define BAUD_TOL 2
#define UBRR_VALUE (((F_CPU) + 8UL * (BAUD)) / (16UL * (BAUD)) -1UL)
#if 100 * (F_CPU) > (16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) + (BAUD) * (BAUD_TOL))
#define USE_2X 1
#define TEST 1
#elif 100 * (F_CPU) < (16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) - (BAUD) * (BAUD_TOL))
#define USE_2X 1
#define TEST 11
#else
#define USE_2X 0
#define TEST 111
#endif
int main(void) {
printf("UBRR_VALUE: %ld\n", UBRR_VALUE);
printf("USE_2X: %d\n", USE_2X);
printf("%ld\n", (16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) - (BAUD) * (BAUD_TOL)));
printf("F_CPU * 100 = %ld\n", (100*F_CPU));
printf("TEST = %d\n", TEST);
return 0;
}输出:
UBRR_VALUE: 6
USE_2X: 1
105369600
F_CPU * 100 = 100000000
TEST = 11由于100 * F_CPU小于(16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) - (BAUD) * (BAUD_TOL)),因此TEST的值为11。
但如果我将F_CPU更改为16000000UL:
UBRR_VALUE: 103
USE_2X: 0
1565491200
F_CPU * 100 = 1600000000
TEST = 111这也是100 * F_CPU比(16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) - (BAUD) * (BAUD_TOL))小的原因。
但是为什么TEST是111呢?
编辑:*Here的100 * F_CPU大于(16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) - (BAUD) * (BAUD_TOL))
发布于 2018-09-06 18:36:22
这些宏被展开,如下所述:
对于第二种情况,从F_CPU到16000000UL (较大的值)
100 * (F_CPU) > (16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) + (BAUD) * (BAUD_TOL)) 计算结果为0x5f5e1000 > 0x611e8000,为false
100 * (F_CPU) < (16 * ((UBRR_VALUE) + 1)) * (100 * (BAUD) - (BAUD) * (BAUD_TOL))计算结果为0x5f5e1000 < 0x5d4f8000,也为false。
因此,以下宏是适用的:
#define USE_2X 0
#define TEST 111https://stackoverflow.com/questions/52201039
复制相似问题