adi 公司的嵌入式的 demo 程序,c 语言...看了这个函数,我不相信我的眼睛

21 天前
 pigdragon

是我魔怔了吧,这个函数判断条件不是无效的么?要这个 if 干嘛?

** adi_initialize.c source file generated on August 10, 2018 at 10:27:14.
**
** Copyright (C) 2000-2018 Analog Devices Inc., All Rights Reserved.
**
** This file is generated automatically. You should not modify this source file,
** as your changes will be lost if this source file is re-generated.
*/

#include <sys/platform.h>

#include "adi_initialize.h"

extern int32_t adi_initpinmux(void);

int32_t adi_initComponents(void)
{
	int32_t result = 0;


	if (result == 0) {
		result = adi_initpinmux(); /* auto-generated code (order:0) */
	}

	return result;
}
1765 次点击
所在节点    程序员
16 条回复
flytsuki
21 天前
有可能 if 之前有一堆代码,然后需求变更删掉了吧
azenk
21 天前
这不是工具自动生成的代码么?不奇怪
UIXX
21 天前
这是一种嵌入式工程中表示默认配置的写法。

对于不同的处理器,这个函数是根据情况来判断执不执行引脚复用初始化,比如在 A 芯片中 if 前面是有形如 result = xxx()的条件判断的,而 B 芯片则不需要。这种写法既满足格式统一,又方便插入调试语句,经常用。

PS. 工具生成的是引脚复用初始化那部分的内容,不是这个函数。
pigdragon
21 天前
工具要有模板的吧...按照尚未普及人工智能的情况,模板肯定是人出的
pigdragon
21 天前
@UIXX
学习了...
看来有疑惑要经常问,开口有益
Panic
21 天前
从软件层面看怎么也应该是再调用一个 result = chip_initComponents 的 chip 专用函数把, 这么写怎么看都不合理. 不过考虑到嵌入式也有全栈, 懂硬件的顺带再写个软件..
Panic
21 天前
你这个可能是 SDK 版本太老了.
https://github.com/analogdevicesinc/runtime-sharc-loader/blob/master/SharcBooter/project/sc589/SharcBooter_Core2/system/adi_initialize.c

int32_t adi_initComponents(void)
{
int32_t result = 0;

result = adi_sec_Init();


return result;
}
rrfeng
20 天前
注释写了 auto generated
也不奇怪(
leonshaw
20 天前
pigdragon
20 天前
@Panic
基本上无所谓新旧,都有时间戳的,看你贴的链接,你贴的这个代码 2019,我贴的 2018.
就是前面几位朋友说的,说来说去是软件生成的,通过兼容的模板.
thorneLiu
20 天前
实际跑起来编译器应该都能优化掉这个 if 吧
CEBBCAT
20 天前
@pigdragon #5 比开口更有益的是主动学习。看到是自动生成的代码,去找生成它的软件,找到对应的生成逻辑,看看为什么这样设计,是不是有哪里可以优化,再去提个 PR ,岂不美哉?

(虽然我从没提过)
kk2syc
20 天前
编译器能优化,但是这样写在不同硬件的时候可以很方便调整对应部分(相当于预留)
koebehshian
20 天前
统一格式 ,如果要调两个函数,第二个就需要 if 判断
flax5a98aa2
20 天前
自动生成的代码只需要保证逻辑等价效率没有折扣就行了,人手动写代码需要考虑的事情就多了
xiri
20 天前
我做嵌入式的,一般我们的代码会有大量的宏控制、嵌套以适配不同的芯片方案和机型,如果只看某个产品机型的有效代码(删除未开启宏包裹的代码),应该能找到一堆类似这样的场景。
主要还是为了同时满足多业务需求,让格式尽量统一、保证代码复用吧,说不定这个代码原先也是有宏控制的其他逻辑分支,只不过公开出来去除了不关注的部分。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1047423

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX