openwrt源码目录下package/base-files/files/bin/config_generate脚本的作用

一、核心功能概述

​​默认配置生成​​:在系统首次启动时,根据硬件探测结果生成默认配置文件(如/etc/config/network、/etc/config/system)。
​​启动阶段执行​​:由初始化脚本/etc/rc.d/S10boot调用,属于OpenWrt启动流程的关键环节。

二、网络配置生成

​​接口类型配置​​:
生成桥接(Bridge)配置,支持物理或逻辑接口的桥接绑定。
支持VLAN划分,生成交换机端口的VLAN子接口。
​​IP协议设置​​:
静态IP分配(如默认的192.168.1.1)或DHCP客户端配置。
支持自定义网关、DNS服务器等参数。
​​DHCP服务​​:
定义DHCP服务器的IP地址池、租约时间等。

三、系统配置生成

​​基础参数​​:
设置主机名(Hostname)、时区(如Asia/Shanghai)。
配置默认DNS服务器及NTP时间同步。
​​硬件相关配置​​:
生成LED指示灯规则(如状态触发条件)。
管理GPIO开关(如复位按钮行为)。

四、硬件探测与适配

​​依赖board_detect脚本​​:
调用同目录下的board_detect脚本检测硬件型号,生成/etc/board.json描述文件。
通过/etc/board.d/目录下的可执行脚本扩展硬件支持。
​​条件判断逻辑​​:
若配置文件已存在且非空,则跳过生成步骤(避免覆盖用户自定义配置)。

五、例子

1.修改路由器默认网关
修改ipad变量的值可以修改默认网关
在这里插入图片描述
2.设置ntp服务器和时区等
generate_static_system方法可自定义设置ntp服务器和时区

# 设置ntp服务器和时区等等
generate_static_system() {
	uci -q batch <<-EOF
		delete system.@system[0]
		add system system
		set system.@system[-1].hostname='OpenWrt'
		set system.@system[-1].timezone='CST-8'
		set system.@system[-1].ttylogin='0'
		set system.@system[-1].log_size='64'
		set system.@system[-1].urandom_seed='0'

		delete system.ntp
		set system.ntp='timeserver'
		set system.ntp.enabled='1'
		set system.ntp.enable_server='0'
		add_list system.ntp.server='203.107.6.88'


	EOF

	if json_is_a system object; then
		json_select system
			local hostname
			if json_get_var hostname hostname; then
				uci -q set "system.@system[-1].hostname=$hostname"
			fi

			local compat_version
			if json_get_var compat_version compat_version; then
				uci -q set "system.@system[-1].compat_version=$compat_version"
			else
				uci -q set "system.@system[-1].compat_version=1.0"
			fi

			if json_is_a ntpserver array; then
				local keys key
				json_get_keys keys ntpserver
				json_select ntpserver
					uci -q delete "system.ntp.server"

					for key in $keys; do
						local server
						if json_get_var server "$key"; then
							uci -q add_list "system.ntp.server=$server"
						fi
					done
				json_select ..
			fi
		json_select ..
	fi
}

ps:有关其他的自定义配置文件感兴趣的可以自行去看这个脚本的代码

完整源码(未修改):

#!/bin/sh

CFG=/etc/board.json

. /usr/share/libubox/jshn.sh

[ -s $CFG ] || /bin/board_detect || exit 1
[ -s /etc/config/network -a -s /etc/config/system ] && exit 0

generate_bridge() {
	local name=$1
	local macaddr=$2
	uci -q batch <<-EOF
		set network.$name=device
		set network.$name.name=$name
		set network.$name.type=bridge
	EOF
	if [ -n "$macaddr" ]; then
		uci -q batch <<-EOF
			set network.$name.macaddr=$macaddr
		EOF
	fi
}

bridge_vlan_id=0
generate_bridge_vlan() {
	local name=$1_vlan
	local device=$2
	local ports="$3"
	local vlan="$4"
	uci -q batch <<-EOF
		set network.$name=bridge-vlan
		set network.$name.device='$device'
		set network.$name.vlan='$vlan'
		set network.$name.ports='$ports'
	EOF
}

generate_static_network() {
	uci -q batch <<-EOF
		delete network.loopback
		set network.loopback='interface'
		set network.loopback.device='lo'
		set network.loopback.proto='static'
		set network.loopback.ipaddr='127.0.0.1'
		set network.loopback.netmask='255.0.0.0'
	EOF
		[ -e /proc/sys/net/ipv6 ] && {
			uci -q batch <<-EOF
				delete network.globals
				set network.globals='globals'
				set network.globals.ula_prefix='auto'
			EOF
		}

	if json_is_a dsl object; then
		json_select dsl
			if json_is_a atmbridge object; then
				json_select atmbridge
					local vpi vci encaps payload nameprefix
					json_get_vars vpi vci encaps payload nameprefix
					uci -q batch <<-EOF
						delete network.atm
						set network.atm='atm-bridge'
						set network.atm.vpi='$vpi'
						set network.atm.vci='$vci'
						set network.atm.encaps='$encaps'
						set network.atm.payload='$payload'
						set network.atm.nameprefix='$nameprefix'
					EOF
				json_select ..
			fi

			if json_is_a modem object; then
				json_select modem
					local type annex firmware tone xfer_mode
					json_get_vars type annex firmware tone xfer_mode
					uci -q batch <<-EOF
						delete network.dsl
						set network.dsl='dsl'
						set network.dsl.annex='$annex'
						set network.dsl.firmware='$firmware'
						set network.dsl.tone='$tone'
						set network.dsl.xfer_mode='$xfer_mode'
					EOF
				json_select ..
			fi
		json_select ..
	fi
}

addr_offset=2
generate_network() {
	local ports device macaddr protocol type ipaddr netmask vlan
	local bridge=$2

	json_select network
		json_select "$1"
			json_get_vars device macaddr metric protocol ipaddr netmask vlan
			json_get_values ports ports
		json_select ..
	json_select ..

	[ -n "$device" -o -n "$ports" ] || return

	# Force bridge for "lan" as it may have other devices (e.g. wireless)
	# bridged
	[ "$1" = "lan" -a -z "$ports" ] && {
		ports="$device"
	}

	[ -n "$ports" -a -z "$bridge" ] && {
		uci -q batch <<-EOF
			add network device
			set network.@device[-1].name='br-$1'
			set network.@device[-1].type='bridge'
		EOF
		for port in $ports; do uci add_list network.@device[-1].ports="$port"; done
		[ -n "$macaddr" ] && {
			for port in $ports; do
				uci -q batch <<-EOF
					add network device
					set network.@device[-1].name='$port'
					set network.@device[-1].macaddr='$macaddr'
				EOF
			done
		}
		device=br-$1
		type=
		macaddr=""
	}

	[ -n "$bridge" ] && {
		[ -z "$ports" ] && ports="$device"
		if [ -z "$vlan" ]; then
			bridge_vlan_id=$((bridge_vlan_id + 1))
			vlan=$bridge_vlan_id
		fi
		generate_bridge_vlan $1 $bridge "$ports" $vlan
		device=$bridge.$vlan
		type=""
	}

	if [ -n "$macaddr" ]; then
		uci -q batch <<-EOF
			add network device
			set network.@device[-1].name='$device'
			set network.@device[-1].macaddr='$macaddr'
		EOF
	fi

	uci -q batch <<-EOF
		delete network.$1
		set network.$1='interface'
		set network.$1.type='$type'
		set network.$1.device='$device'
		set network.$1.metric='$metric'
		set network.$1.proto='none'
	EOF

	case "$protocol" in
		static)
			local ipad
			case "$1" in
				lan) ipad=${ipaddr:-"192.168.1.1"} ;;
				*) ipad=${ipaddr:-"192.168.$((addr_offset++)).1"} ;;
			esac

			netm=${netmask:-"255.255.255.0"}

			uci -q batch <<-EOF
				set network.$1.proto='static'
				set network.$1.ipaddr='$ipad'
				set network.$1.netmask='$netm'
			EOF
			[ -e /proc/sys/net/ipv6 ] && uci set network.$1.ip6assign='60'
		;;

		dhcp)
			# fixup IPv6 slave interface if parent is a bridge
			[ "$type" = "bridge" ] && device="br-$1"

			uci set network.$1.proto='dhcp'
			[ -e /proc/sys/net/ipv6 ] && {
				uci -q batch <<-EOF
					delete network.${1}6
					set network.${1}6='interface'
					set network.${1}6.device='$device'
					set network.${1}6.proto='dhcpv6'
				EOF
			}
		;;

		pppoe)
			uci -q batch <<-EOF
				set network.$1.proto='pppoe'
				set network.$1.username='username'
				set network.$1.password='password'
			EOF
			[ -e /proc/sys/net/ipv6 ] && {
				uci -q batch <<-EOF
					set network.$1.ipv6='1'
					delete network.${1}6
					set network.${1}6='interface'
					set network.${1}6.device='@${1}'
					set network.${1}6.proto='dhcpv6'
				EOF
			}
		;;

		ncm|\
		qmi|\
		mbim)
			uci -q batch <<-EOF
				set network.$1.proto='${protocol}'
				set network.$1.pdptype='ipv4'
			EOF
		;;
	esac
}

generate_switch_vlans_ports() {
	local switch="$1"
	local port ports role roles num attr val

	#
	# autogenerate vlans
	#

	if json_is_a roles array; then
		json_get_keys roles roles
		json_select roles

		for role in $roles; do
			json_select "$role"
				json_get_vars ports
			json_select ..

			uci -q batch <<-EOF
				add network switch_vlan
				set network.@switch_vlan[-1].device='$switch'
				set network.@switch_vlan[-1].vlan='$role'
				set network.@switch_vlan[-1].ports='$ports'
			EOF
		done

		json_select ..
	fi


	#
	# write port specific settings
	#

	if json_is_a ports array; then
		json_get_keys ports ports
		json_select ports

		for port in $ports; do
			json_select "$port"
				json_get_vars num

				if json_is_a attr object; then
					json_get_keys attr attr
					json_select attr
						uci -q batch <<-EOF
							add network switch_port
							set network.@switch_port[-1].device='$switch'
							set network.@switch_port[-1].port=$num
						EOF

						for attr in $attr; do
							json_get_var val "$attr"
							uci -q set network.@switch_port[-1].$attr="$val"
						done
					json_select ..
				fi
			json_select ..
		done

		json_select ..
	fi
}

generate_switch() {
	local key="$1"
	local vlans

	json_select switch
	json_select "$key"
	json_get_vars enable reset blinkrate cpu_port \
		ar8xxx_mib_type ar8xxx_mib_poll_interval

	uci -q batch <<-EOF
		add network switch
		set network.@switch[-1].name='$key'
		set network.@switch[-1].reset='$reset'
		set network.@switch[-1].enable_vlan='$enable'
		set network.@switch[-1].blinkrate='$blinkrate'
		set network.@switch[-1].ar8xxx_mib_type='$ar8xxx_mib_type'
		set network.@switch[-1].ar8xxx_mib_poll_interval='$ar8xxx_mib_poll_interval'
	EOF

	generate_switch_vlans_ports "$1"

	json_select ..
	json_select ..
}

generate_static_system() {
	uci -q batch <<-EOF
		delete system.@system[0]
		add system system
		set system.@system[-1].hostname='OpenWrt'
		set system.@system[-1].timezone='UTC'
		set system.@system[-1].ttylogin='0'
		set system.@system[-1].log_size='64'
		set system.@system[-1].urandom_seed='0'

		delete system.ntp
		set system.ntp='timeserver'
		set system.ntp.enabled='1'
		set system.ntp.enable_server='0'
		add_list system.ntp.server='0.openwrt.pool.ntp.org'
		add_list system.ntp.server='1.openwrt.pool.ntp.org'
		add_list system.ntp.server='2.openwrt.pool.ntp.org'
		add_list system.ntp.server='3.openwrt.pool.ntp.org'
	EOF

	if json_is_a system object; then
		json_select system
			local hostname
			if json_get_var hostname hostname; then
				uci -q set "system.@system[-1].hostname=$hostname"
			fi

			local compat_version
			if json_get_var compat_version compat_version; then
				uci -q set "system.@system[-1].compat_version=$compat_version"
			else
				uci -q set "system.@system[-1].compat_version=1.0"
			fi

			if json_is_a ntpserver array; then
				local keys key
				json_get_keys keys ntpserver
				json_select ntpserver
					uci -q delete "system.ntp.server"

					for key in $keys; do
						local server
						if json_get_var server "$key"; then
							uci -q add_list "system.ntp.server=$server"
						fi
					done
				json_select ..
			fi
		json_select ..
	fi
}

generate_rssimon() {
	local key="$1"
	local cfg="rssid_$key"
	local refresh threshold

	json_select rssimon
	json_select "$key"
	json_get_vars refresh threshold
	json_select ..
	json_select ..

	uci -q batch <<-EOF
		delete system.$cfg
		set system.$cfg='rssid'
		set system.$cfg.dev='$key'
		set system.$cfg.refresh='$refresh'
		set system.$cfg.threshold='$threshold'
	EOF
}

generate_led() {
	local key="$1"
	local cfg="led_$key"

	json_select led
	json_select "$key"
	json_get_vars name sysfs type trigger default

	uci -q batch <<-EOF
		delete system.$cfg
		set system.$cfg='led'
		set system.$cfg.name='$name'
		set system.$cfg.sysfs='$sysfs'
		set system.$cfg.trigger='$trigger'
		set system.$cfg.default='$default'
	EOF

	case "$type" in
		gpio)
			local gpio inverted
			json_get_vars gpio inverted
			uci -q batch <<-EOF
				set system.$cfg.trigger='gpio'
				set system.$cfg.gpio='$gpio'
				set system.$cfg.inverted='$inverted'
			EOF
		;;

		netdev)
			local device mode
			json_get_vars device mode
			uci -q batch <<-EOF
				set system.$cfg.trigger='netdev'
				set system.$cfg.mode='$mode'
				set system.$cfg.dev='$device'
			EOF
		;;

		usb)
			local device
			json_get_vars device
			uci -q batch <<-EOF
				set system.$cfg.trigger='usbdev'
				set system.$cfg.interval='50'
				set system.$cfg.dev='$device'
			EOF
		;;

		usbport)
			local ports port
			json_get_values ports ports
			uci set system.$cfg.trigger='usbport'
			for port in $ports; do
				uci add_list system.$cfg.port=$port
			done
		;;

		rssi)
			local iface minq maxq offset factor
			json_get_vars iface minq maxq offset factor
			uci -q batch <<-EOF
				set system.$cfg.trigger='rssi'
				set system.$cfg.iface='rssid_$iface'
				set system.$cfg.minq='$minq'
				set system.$cfg.maxq='$maxq'
				set system.$cfg.offset='$offset'
				set system.$cfg.factor='$factor'
			EOF
		;;

		switch)
			local port_mask speed_mask mode
			json_get_vars port_mask speed_mask mode
			uci -q batch <<-EOF
				set system.$cfg.port_mask='$port_mask'
				set system.$cfg.speed_mask='$speed_mask'
				set system.$cfg.mode='$mode'
			EOF
		;;

		portstate)
			local port_state
			json_get_vars port_state
			uci -q batch <<-EOF
				set system.$cfg.port_state='$port_state'
			EOF
		;;

		timer|oneshot)
			local delayon delayoff
			json_get_vars delayon delayoff
			uci -q batch <<-EOF
				set system.$cfg.trigger='$type'
				set system.$cfg.delayon='$delayon'
				set system.$cfg.delayoff='$delayoff'
			EOF
		;;
	esac

	json_select ..
	json_select ..
}

generate_gpioswitch() {
	local cfg="$1"

	json_select gpioswitch
		json_select "$cfg"
			local name pin default
			json_get_vars name pin default
			uci -q batch <<-EOF
				delete system.$cfg
				set system.$cfg='gpio_switch'
				set system.$cfg.name='$name'
				set system.$cfg.gpio_pin='$pin'
				set system.$cfg.value='$default'
			EOF
		json_select ..
	json_select ..
}

json_init
json_load "$(cat ${CFG})"

umask 077

if [ ! -s /etc/config/network ]; then
	bridge_name=""
	touch /etc/config/network
	generate_static_network

	json_get_vars bridge
	[ -n "$bridge" ] && {
		json_select bridge
		json_get_vars name macaddr
		generate_bridge "$name" "$macaddr"
		json_select ..
		bridge_name=$name
	}

	json_get_keys keys network
	for key in $keys; do generate_network $key $bridge_name; done

	json_get_keys keys switch
	for key in $keys; do generate_switch $key; done
fi

if [ ! -s /etc/config/system ]; then
	touch /etc/config/system
	generate_static_system

	json_get_keys keys rssimon
	for key in $keys; do generate_rssimon $key; done

	json_get_keys keys gpioswitch
	for key in $keys; do generate_gpioswitch $key; done

	json_get_keys keys led
	for key in $keys; do generate_led $key; done
fi
uci commit
远程服务器,openwet 下面有这样的配置{ "configurations": [ { "name": "Linux", "includePath": [ "${workspaceFolder}/include", "${workspaceFolder}/staging_dir/target-*/usr/include", "${workspaceFolder}/staging_dir/target-*/include", "${workspaceFolder}/staging_dir/toolchain-*/usr/include", "${workspaceFolder}/staging_dir/toolchain-*/include", "${workspaceFolder}/build_dir/target-*/linux-*/backports-*/include", "${workspaceFolder}/build_dir/target-*/linux-*/backports-*/backport-include", "${workspaceFolder}/package/kernel/siflower/openwrt-x2880-driver/**", "${workspaceFolder}/package/kernel/siflower/openwrt-x2880-driver/src/**", "${workspaceFolder}/sf_kernel/linux-5.10/arch/riscv/include/generated", "${workspaceFolder}/sf_kernel/linux-5.10/arch/riscv/include/uapi", "${workspaceFolder}/sf_kernel/linux-5.10/arch/riscv/include/uapi/asm", "${workspaceFolder}/sf_kernel/linux-5.10/include/generated", "${workspaceFolder}/sf_kernel/linux-5.10/include", "${workspaceFolder}/sf_kernel/linux-5.10/include/uapi", "${workspaceFolder}/sf_kernel/linux-5.10/include/net", "${workspaceFolder}/sf_kernel/linux-5.10/include/uapi/asm-generic", "${workspaceFolder}/package/kernel/siflower/easymesh/**" ], "defines": [ "__KERNEL__", "MODULE", "KBUILD_MODNAME=__FILE__", "CONFIG_64BIT=1", "CONFIG_SIWIFI_FULLMAC", "CONFIG_SIWIFI_IGMP", "__linux__", "__OpenWrt__" ], "compilerPath": "${workspaceFolder}/staging_dir/toolchain-*/bin/*-gcc", "cStandard": "gnu11", "cppStandard": "gnu++17", "intelliSenseMode": "linux-gcc-arm64" } ], "version": 4 }为什么代码里面还是有红色波浪线
03-21
<think>嗯,用户在使用远程服务器上的OpenWrt环境时,配置了VSCode的C/C++扩展,但代码中仍有红色波浪线。我需要分析可能的原因,并给出解决方案。首先,考虑配置路径是否正确。用户的includePath里有很多通配符,比如`target-*`和`toolchain-*`,这些通配符可能在VSCode中无法正确展开,导致实际路径未被识别。需要检查服务器上是否存在匹配的目录,或者是否应该用具体版本替换通配符。 其次,编译器路径`compilerPath`同样使用了通配符,可能无法正确解析。应确认实际的工具链路径,替换星号为具体版本号。例如,`toolchain-riscv64_gcc-12.3.0_musl`这样的具体名称。 第三,检查头文件是否存在。有些路径可能是在编译过程中生成的,比如`build_dir`下的内容。如果用户没有执行过编译,这些目录可能不存在,导致找不到头文件。需要用户确保先编译项目或手动生成这些目录。 第四,IntelliSense模式是否正确。用户配置的是`linux-gcc-arm64`,但OpenWrt项目可能使用不同的架构,比如RISC-V。需要确认架构是否匹配,可能需要改为`linux-gcc-riscv64`或其他合适的模式。 第五,扩展的缓存问题。有时候即使配置正确,VSCode的缓存可能导致索引未更新。建议用户重新加载窗口或清除缓存。 第六,权限问题。如果远程服务器的文件权限限制,VSCode可能无法访问某些目录,需检查权限设置。 另外,用户可能没有安装必要的C/C++扩展依赖,或者版本不兼容。建议更新扩展,或查看日志输出以获取具体错误信息。 综合以上可能因素,逐步排查,应该能解决红色波浪线的问题。需要指导用户检查路径有效性、替换通配符、确认编译步骤,调整IntelliSense配置,并处理缓存或权限问题。</think>在OpenWrt环境下出现代码红色波浪线(IntelliSense报错)的可能原因和解决方案如下,按优先级排序: 1. **通配符路径解析问题** - 问题表现:`*-gcc`和`target-*`等通配符在VSCode中可能无法正确解析 - 解决方案: ```json "compilerPath": "${workspaceFolder}/staging_dir/toolchain-riscv64_gcc-12.3.0_musl/bin/riscv64-openwrt-linux-gcc", ``` 需替换`*`为实际存在的目录名,通过命令验证路径: ```bash ls ${workspaceFolder}/staging_dir/toolchain-*/bin/*-gcc ``` 2. **头文件路径缺失** - 核心验证方法: ```bash # 在VSCode终端执行 echo ${workspaceFolder}/sf_kernel/linux-5.10/include/uapi/asm-generic [ -d "${workspaceFolder}/sf_kernel/linux-5.10/include/uapi/asm-generic" ] && echo "存在" || echo "缺失" ``` 3. **编译依赖缺失** - 关键路径生成关系: $$ \begin{cases} \text{staging\_dir} & \leftarrow \text{make toolchain/install} \\ \text{build\_dir} & \leftarrow \text{make target/compile} \\ \text{linux-headers} & \leftarrow \text{make kernel/prepare} \end{cases} $$ 必须执行`make menuconfig && make`生成头文件 4. **架构配置冲突** - 修正IntelliSense模式: ```json "intelliSenseMode": "linux-gcc-riscv64" // 根据riscv64架构调整 ``` 通过`uname -m`验证服务器架构 5. **内核宏定义冲突** - 需要检查的宏定义优先级: ```text __KERNEL__ > __USERSPACE__ CONFIG_64BIT=1 > CONFIG_32BIT ``` 建议在`c_cpp_properties.json`中显式添加: ```json "defines": [ ... "__riscv=1", "_LARGEFILE_SOURCE", "_FILE_OFFSET_BITS=64" ] ``` 6. **扩展缓存问题** 强制重建索引步骤: 1. 按`Ctrl+Shift+P`执行`C/C++: Reset IntelliSense Database` 2. 删除`${workspaceFolder}/.vscode/ipch`目录 3. 重新加载窗口 **验证方案**: 创建测试文件`test_include.c`: ```c #include <linux/kernel.h> #include <net/netlink.h> void test() { printk(KERN_INFO "IntelliSense test"); struct sk_buff *skb = NULL; } ``` 观察以下元素的智能提示状态: - `printk`参数提示 - `struct sk_buff`成员访问 - `KERN_INFO`宏定义跳转 若仍有问题,检查VSCode日志: ```bash tail -f ${workspaceFolder}/.vscode-server/logs/*/exthost*/Cpp.log ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

忘帆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值