mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-10-31 18:38:10 +00:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			uci_defaul
			...
			feeds_use_
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | a54fe26076 | 
| @@ -24,6 +24,8 @@ endef | |||||||
| # | # | ||||||
|  |  | ||||||
| ALLWIFIBOARDS:= \ | ALLWIFIBOARDS:= \ | ||||||
|  | 	cig-wf186w \ | ||||||
|  | 	cig-wf186h \ | ||||||
| 	cig-wf660a \ | 	cig-wf660a \ | ||||||
| 	cig-wf194c \ | 	cig-wf194c \ | ||||||
| 	cig-wf194c4 \ | 	cig-wf194c4 \ | ||||||
| @@ -106,16 +108,6 @@ $(call Package/ath11k-wifi-default) | |||||||
|     TITLE:=cig-wf196 bdf |     TITLE:=cig-wf196 bdf | ||||||
| endef | endef | ||||||
|  |  | ||||||
| define Package/ath11k-wifi-cig-wf186w |  | ||||||
| $(call Package/ath11k-wifi-default) |  | ||||||
|     TITLE:=cig-wf186w bdf |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/ath11k-wifi-cig-wf186h |  | ||||||
| $(call Package/ath11k-wifi-default) |  | ||||||
|     TITLE:=cig-wf186h bdf |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/ath11k-wifi-gl-ax1800 | define Package/ath11k-wifi-gl-ax1800 | ||||||
| $(call Package/ath11k-wifi-default) | $(call Package/ath11k-wifi-default) | ||||||
|     TITLE:=gl-ax1800 bdf |     TITLE:=gl-ax1800 bdf | ||||||
| @@ -292,24 +284,6 @@ define Package/ath11k-wifi-cig-wf196/install | |||||||
| 	$(INSTALL_DATA) ./board-cig-wf196-us.bin.IPQ8074 $(1)/lib/firmware/ath11k/IPQ8074/hw2.0/board.bin.US | 	$(INSTALL_DATA) ./board-cig-wf196-us.bin.IPQ8074 $(1)/lib/firmware/ath11k/IPQ8074/hw2.0/board.bin.US | ||||||
| endef | endef | ||||||
|  |  | ||||||
| define Package/ath11k-wifi-cig-wf186w/install |  | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/ |  | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/qcn6122/hw1.0/ |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186w-us.bin.IPQ5018 $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/board.bin.US |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186w-ca.bin.IPQ5018 $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/board.bin.CA |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186w-us.bin.QCN6122 $(1)/lib/firmware/ath11k/qcn6122/hw1.0/board.bin.US |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186w-ca.bin.QCN6122 $(1)/lib/firmware/ath11k/qcn6122/hw1.0/board.bin.CA |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/ath11k-wifi-cig-wf186h/install |  | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/ |  | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/qcn6122/hw1.0/ |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186h-us.bin.IPQ5018 $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/board.bin.US |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186h-ca.bin.IPQ5018 $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/board.bin.CA |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186h-us.bin.QCN6122 $(1)/lib/firmware/ath11k/qcn6122/hw1.0/board.bin.US |  | ||||||
| 	$(INSTALL_DATA) ./board-cig-wf186h-ca.bin.QCN6122 $(1)/lib/firmware/ath11k/qcn6122/hw1.0/board.bin.CA |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/ath11k-wifi-optimcloud-d50/install | define Package/ath11k-wifi-optimcloud-d50/install | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/IPQ5018/hw1.0/ | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/QCN9074/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath11k/QCN9074/hw1.0/ | ||||||
| @@ -419,6 +393,8 @@ define Package/ath11k-wifi-cig-wf188n/install | |||||||
| 	$(INSTALL_DATA) ./board-cig-wf188n-us.bin.IPQ6018 $(1)/lib/firmware/ath11k/IPQ6018/hw1.0/board.bin.US | 	$(INSTALL_DATA) ./board-cig-wf188n-us.bin.IPQ6018 $(1)/lib/firmware/ath11k/IPQ6018/hw1.0/board.bin.US | ||||||
| endef | endef | ||||||
|  |  | ||||||
|  | $(eval $(call generate-ath11k-wifi-package,cig-wf186w,Cigtech WF186w)) | ||||||
|  | $(eval $(call generate-ath11k-wifi-package,cig-wf186h,Cigtech WF186h)) | ||||||
| $(eval $(call generate-ath11k-wifi-package,cig-wf660a,Cigtech WF660a)) | $(eval $(call generate-ath11k-wifi-package,cig-wf660a,Cigtech WF660a)) | ||||||
| $(eval $(call generate-ath11k-wifi-package,cig-wf194c,Cigtech WF194c)) | $(eval $(call generate-ath11k-wifi-package,cig-wf194c,Cigtech WF194c)) | ||||||
| $(eval $(call generate-ath11k-wifi-package,cig-wf194c4,Cigtech WF194c4)) | $(eval $(call generate-ath11k-wifi-package,cig-wf194c4,Cigtech WF194c4)) | ||||||
| @@ -464,8 +440,6 @@ $(eval $(call BuildPackage,ath11k-wifi-qcom-ipq8074)) | |||||||
| $(eval $(call BuildPackage,ath11k-wifi-qcom-ipq6018)) | $(eval $(call BuildPackage,ath11k-wifi-qcom-ipq6018)) | ||||||
| $(eval $(call BuildPackage,ath11k-wifi-qcom-qcn9000)) | $(eval $(call BuildPackage,ath11k-wifi-qcom-qcn9000)) | ||||||
| $(eval $(call BuildPackage,ath11k-wifi-cig-wf196)) | $(eval $(call BuildPackage,ath11k-wifi-cig-wf196)) | ||||||
| $(eval $(call BuildPackage,ath11k-wifi-cig-wf186w)) |  | ||||||
| $(eval $(call BuildPackage,ath11k-wifi-cig-wf186h)) |  | ||||||
| $(eval $(call BuildPackage,ath11k-wifi-motorola-q14)) | $(eval $(call BuildPackage,ath11k-wifi-motorola-q14)) | ||||||
| $(eval $(call BuildPackage,ath11k-wifi-optimcloud-d50)) | $(eval $(call BuildPackage,ath11k-wifi-optimcloud-d50)) | ||||||
| $(eval $(call BuildPackage,ath11k-wifi-optimcloud-d60)) | $(eval $(call BuildPackage,ath11k-wifi-optimcloud-d60)) | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -4,19 +4,19 @@ let fs = require("fs"); | |||||||
| let ubus = require('ubus').connect(); | let ubus = require('ubus').connect(); | ||||||
|  |  | ||||||
| let gps_info = ubus.call('gps', 'info'); | let gps_info = ubus.call('gps', 'info'); | ||||||
| let latitude = gps_info.latitude || 0; | let latitude = gps_info.latitude ?? 0; | ||||||
| let longitude = gps_info.longitude || 0; | let longitude = gps_info.longitude ?? 0; | ||||||
|  |  | ||||||
| // afc-location.json file content | // afc-location.json file content | ||||||
| let afc_location = {}; | let afc_location = {}; | ||||||
| afc_location.location_type = "ellipse"; | afc_location.location_type = "ellipse"; | ||||||
| afc_location.location = longitude + ":" + latitude ; | afc_location.location = longitude + ":" + latitude ; | ||||||
| afc_location.height = gps_info.elevation || 0; | afc_location.height = gps_info.elevation ?? 0; | ||||||
| afc_location.height_type = "AMSL"; | afc_location.height_type = "AMSL"; | ||||||
| afc_location.major_axis = int(gps_info.major_axis) || 1; | afc_location.major_axis = gps_info.major_axis ?? 0; | ||||||
| afc_location.minor_axis = int(gps_info.minor_axis) || 1; | afc_location.minor_axis = gps_info.minor_axis ?? 0; | ||||||
| afc_location.orientation = gps_info.major_orientation || 0; | afc_location.orientation = gps_info.major_orientation ?? 0; | ||||||
| afc_location.vertical_tolerance = int(gps_info.vdop) || 1; | afc_location.vertical_tolerance = gps_info.vdop ?? 0; | ||||||
|  |  | ||||||
| let afc_location_json = fs.open("/etc/ucentral/afc-location.json", "w"); | let afc_location_json = fs.open("/etc/ucentral/afc-location.json", "w"); | ||||||
| afc_location_json.write(afc_location); | afc_location_json.write(afc_location); | ||||||
|   | |||||||
| @@ -1,8 +1,7 @@ | |||||||
| let libubus = require("ubus"); | let libubus = require("ubus"); | ||||||
| import { open, readfile, writefile } from "fs"; | import { open, readfile } from "fs"; | ||||||
| import { wdev_create, wdev_remove, is_equal, vlist_new, phy_is_fullmac, phy_open } from "common"; | import { wdev_create, wdev_remove, is_equal, vlist_new, phy_is_fullmac, phy_open } from "common"; | ||||||
|  |  | ||||||
| let uci = require('uci').cursor(); |  | ||||||
| let ubus = libubus.connect(null, 60); | let ubus = libubus.connect(null, 60); | ||||||
|  |  | ||||||
| hostapd.data.config = {}; | hostapd.data.config = {}; | ||||||
| @@ -894,24 +893,10 @@ return { | |||||||
| 		hostapd.ubus.disconnect(); | 		hostapd.ubus.disconnect(); | ||||||
| 	}, | 	}, | ||||||
| 	afc_request: function(iface, data) { | 	afc_request: function(iface, data) { | ||||||
| 		let wireless_config = uci.get_all('wireless'); | 		let ret = ubus.call("afc", "request", { data }); | ||||||
| 		for (let l, afc_server in wireless_config) { | 		if (type(ret) != "object") | ||||||
| 			if (afc_server['.type'] == 'afc-server' && afc_server.url && data) { | 			return; | ||||||
| 				hostapd.printf(`Sending AFC request: ${data}`); | 		return ret.data; | ||||||
| 				writefile("/tmp/afc-request.json", data); |  | ||||||
|  |  | ||||||
| 				if (afc_server.access_token) |  | ||||||
| 					system(`curl -s -X POST ${afc_server.url} -H \'accept: \*\/\*\' -H \'Authorization: Bearer ${afc_server.access_token}\' -H \'Content-Type: application/json\' -d \'${data}\' --output /tmp/afc-response.json`); |  | ||||||
| 				else if (afc_server.cert) |  | ||||||
| 					system(`curl -s -X POST ${afc_server.url} -H \'accept: \*\/\*\' --cert \'${afc_server.cert}\' -H \'Content-Type: application/json\' -d \'${data}\' --output /tmp/afc-response.json`); |  | ||||||
|  |  | ||||||
| 				let afc_response = (readfile("/tmp/afc-response.json")); |  | ||||||
| 				if (afc_response) |  | ||||||
| 					return afc_response; |  | ||||||
| 				else |  | ||||||
| 					return; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	}, | 	}, | ||||||
| 	bss_add: function(name, obj) { | 	bss_add: function(name, obj) { | ||||||
| 		bss_event("add", name); | 		bss_event("add", name); | ||||||
|   | |||||||
| @@ -251,32 +251,6 @@ ath11k-macs) | |||||||
| 		;; | 		;; | ||||||
| 	esac | 	esac | ||||||
| 	;; | 	;; | ||||||
| ath11k/IPQ5018/hw1.0/board.bin) |  | ||||||
| 	case "$board" in |  | ||||||
| 	cig,wf186w|\ |  | ||||||
| 	cig,wf186h) |  | ||||||
|                 country=`cat /etc/ucentral/country` |  | ||||||
|                 if [ "$country" == "CA" ]; then |  | ||||||
|                         ln -s /lib/firmware/ath11k/IPQ5018/hw1.0/board.bin.CA /lib/firmware/ath11k/IPQ5018/hw1.0/board.bin |  | ||||||
|                 else |  | ||||||
|                         ln -s /lib/firmware/ath11k/IPQ5018/hw1.0/board.bin.US /lib/firmware/ath11k/IPQ5018/hw1.0/board.bin |  | ||||||
|                 fi |  | ||||||
|                 ;; |  | ||||||
| 	esac |  | ||||||
| 	;; |  | ||||||
| ath11k/qcn6122/hw1.0/board.bin) |  | ||||||
| 	case "$board" in |  | ||||||
| 	cig,wf186w|\ |  | ||||||
| 	cig,wf186h) |  | ||||||
|                 country=`cat /etc/ucentral/country` |  | ||||||
|                 if [ "$country" == "CA" ]; then |  | ||||||
|                         ln -s /lib/firmware/ath11k/qcn6122/hw1.0/board.bin.CA /lib/firmware/ath11k/qcn6122/hw1.0/board.bin |  | ||||||
|                 else |  | ||||||
|                         ln -s /lib/firmware/ath11k/qcn6122/hw1.0/board.bin.US /lib/firmware/ath11k/qcn6122/hw1.0/board.bin |  | ||||||
|                 fi |  | ||||||
|                 ;; |  | ||||||
| 	esac |  | ||||||
| 	;; |  | ||||||
| *) | *) | ||||||
| 	exit 1 | 	exit 1 | ||||||
| 	;; | 	;; | ||||||
|   | |||||||
| @@ -107,42 +107,29 @@ platform_do_upgrade() { | |||||||
|  |  | ||||||
| 	board=$(board_name) | 	board=$(board_name) | ||||||
| 	case $board in | 	case $board in | ||||||
|  | 	glinet,b3000|\ | ||||||
| 	edgecore,oap101|\ | 	edgecore,oap101|\ | ||||||
| 	edgecore,oap101-6e|\ | 	edgecore,oap101-6e|\ | ||||||
| 	edgecore,oap101e|\ | 	edgecore,oap101e|\ | ||||||
| 	edgecore,oap101e-6e|\ | 	edgecore,oap101e-6e|\ | ||||||
| 	edgecore,eap104) | 	edgecore,eap104) | ||||||
| 		if [ "$(find_mtd_chardev rootfs)" ]; then |  | ||||||
| 			CI_UBIPART="rootfs" |  | ||||||
| 		else |  | ||||||
| 			if grep -q rootfs1 /proc/cmdline; then |  | ||||||
| 				CI_UBIPART="rootfs2" |  | ||||||
| 				CI_FWSETENV="active 2" |  | ||||||
| 			else |  | ||||||
| 				CI_UBIPART="rootfs1" |  | ||||||
| 				CI_FWSETENV="active 1" |  | ||||||
| 			fi |  | ||||||
| 		fi |  | ||||||
| 		nand_upgrade_tar "$1" |  | ||||||
| 		;; |  | ||||||
| 	glinet,b3000) |  | ||||||
| 		CI_UBIPART="rootfs1" | 		CI_UBIPART="rootfs1" | ||||||
| 		[ "$(find_mtd_chardev rootfs)" ] && CI_UBIPART="rootfs" | 		[ "$(find_mtd_chardev rootfs)" ] && CI_UBIPART="rootfs" | ||||||
| 		nand_upgrade_tar "$1" | 		nand_upgrade_tar "$1" | ||||||
| 		;; | 		;; | ||||||
| 	hfcl,ion4x_w|\ |         hfcl,ion4x_w|\ | ||||||
| 	hfcl,ion4xi_w) | 	hfcl,ion4xi_w) | ||||||
| 		wp_part=$(fw_printenv primary | cut  -d = -f2) |                 wp_part=$(fw_printenv primary | cut  -d = -f2) | ||||||
| 		echo "Current Primary is $wp_part" |                 echo "Current Primary is $wp_part" | ||||||
| 		if [[ $wp_part == 1 ]]; then |                 if [[ $wp_part == 1 ]]; then | ||||||
| 				CI_UBIPART="rootfs" |                         CI_UBIPART="rootfs" | ||||||
| 				CI_FWSETENV="primary 0" |                         CI_FWSETENV="primary 0" | ||||||
| 		else |                 else | ||||||
| 				CI_UBIPART="rootfs_1" |                         CI_UBIPART="rootfs_1" | ||||||
| 				CI_FWSETENV="primary 1" |                         CI_FWSETENV="primary 1" | ||||||
| 		fi |                 fi | ||||||
| 		nand_upgrade_tar "$1" |                 nand_upgrade_tar "$1" | ||||||
| 		;; |                 ;; | ||||||
| 	cig,wf186w|\ | 	cig,wf186w|\ | ||||||
| 	cig,wf186h|\ | 	cig,wf186h|\ | ||||||
| 	emplus,wap385c|\ | 	emplus,wap385c|\ | ||||||
|   | |||||||
| @@ -34,11 +34,13 @@ case "$board" in | |||||||
|  |  | ||||||
|         if [ -f "$phy0_file" ]; then |         if [ -f "$phy0_file" ]; then | ||||||
|             check_phy0=$(cat $phy0_file) |             check_phy0=$(cat $phy0_file) | ||||||
|  |             echo "check_phy0 = $check_phy0" | ||||||
|             [ "$check_phy0" == 0 ] && echo 1 > $phy0_file |             [ "$check_phy0" == 0 ] && echo 1 > $phy0_file | ||||||
|         fi |         fi | ||||||
|  |  | ||||||
|         if [ -f "$phy1_file" ]; then |         if [ -f "$phy1_file" ]; then | ||||||
|             check_phy1=$(cat $phy1_file) |             check_phy1=$(cat $phy1_file) | ||||||
|  |             echo "check_phy1 = $check_phy1" | ||||||
|             [ "$check_phy1" == 0 ] && echo 1 > $phy1_file |             [ "$check_phy1" == 0 ] && echo 1 > $phy1_file | ||||||
|         fi |         fi | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,107 @@ | |||||||
|  | # Description: The Mesh11sd daemon expects the mesh interface name to follow the format 'mesh<index>'.  | ||||||
|  | # If it doesn't find this format, it attempts to set it in the UCI wireless configuration.  | ||||||
|  | # However, when operating in other modes such as AP, STA, or Ad-Hoc, the script was patched to remove  | ||||||
|  | # the mesh interface name from UCI. This process can lead to a race condition between the UI and Mesh11sd, | ||||||
|  | # resulting in stale interface name values. | ||||||
|  | # This patch resolves the issue by removing the setting of the interface name from the script, as it is  | ||||||
|  | # now managed through the UI, ensuring consistency and eliminating the race condition. | ||||||
|  |  | ||||||
|  | --- a/src/mesh11sd | ||||||
|  | +++ b/src/mesh11sd | ||||||
|  | @@ -387,45 +387,45 @@ elif [ "$1" = "daemon" ]; then | ||||||
|  |   | ||||||
|  |  		if [ $mode -eq 5 ]; then | ||||||
|  |  			# startup=4, statusmode=0, enabled=1 | ||||||
|  | +			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" | ||||||
|  |  			startup=0 | ||||||
|  |  			statusmode=0 | ||||||
|  |  			mode=1 | ||||||
|  | -			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" | ||||||
|  |   | ||||||
|  |  		elif [ $mode -eq 4 ]; then | ||||||
|  |  			# startup=4, statusmode=0, enabled=0 | ||||||
|  | +			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" | ||||||
|  |  			startup=0 | ||||||
|  |  			statusmode=2 | ||||||
|  |  			mode=0 | ||||||
|  | -			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" | ||||||
|  |   | ||||||
|  |  		elif [ $mode -eq 3 ]; then | ||||||
|  |  			# startup=0, statusmode=2, enabled=1 | ||||||
|  | +			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" | ||||||
|  |  			startup=0 | ||||||
|  |  			statusmode=0 | ||||||
|  |  			mode=1 | ||||||
|  | -			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" | ||||||
|  |   | ||||||
|  |  		elif [ $mode -eq 2 ]; then | ||||||
|  |  			# startup=0, statusmode=2, enabled=0 | ||||||
|  | +			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" | ||||||
|  |  			startup=0 | ||||||
|  |  			statusmode=2 | ||||||
|  |  			mode=0 | ||||||
|  | -			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" | ||||||
|  |   | ||||||
|  |  		elif [ $mode -eq 1 ]; then | ||||||
|  |  			# startup=0, statusmode=0, enabled=1 | ||||||
|  | +			syslogmessage="mesh11sd v$version has started, mesh management mode $mode" | ||||||
|  |  			startup=0 | ||||||
|  |  			statusmode=0 | ||||||
|  |  			mode=1 | ||||||
|  | -			syslogmessage="mesh11sd v$version has started, mesh management mode $mode" | ||||||
|  |   | ||||||
|  |  		elif [ $mode -eq 0 ]; then | ||||||
|  |  			# startup=0, statusmode=0, enabled=0 | ||||||
|  | +			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" | ||||||
|  |  			startup=0 | ||||||
|  |  			statusmode=2 | ||||||
|  |  			mode=0 | ||||||
|  | -			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" | ||||||
|  |  		fi | ||||||
|  |   | ||||||
|  |  		if [ $mode -ne $lastmode ]; then | ||||||
|  | @@ -441,26 +441,6 @@ elif [ "$1" = "daemon" ]; then | ||||||
|  |  			meshconfigs=$(uci show wireless 2> /dev/null | grep "mode='mesh'" | awk -F ".mode='mesh'" '{printf "%s " $1}') | ||||||
|  |   | ||||||
|  |  			if [ ! -z "$meshconfigs" ]; then | ||||||
|  | -				for meshconfig in $meshconfigs; do | ||||||
|  | -					ifname=$(uci get $meshconfig.ifname 2> /dev/null) | ||||||
|  | - | ||||||
|  | -					if [ -z "$ifname" ] || [ "$ifname" != "mesh$meshindex" ]; then | ||||||
|  | -						# No interface name in config, so add one | ||||||
|  | -						ucibatch="set $meshconfig.ifname='mesh$meshindex'" | ||||||
|  | -						echo "$ucibatch" | uci batch | ||||||
|  | -						changed=1 | ||||||
|  | -						syslogmessage="Setting mesh interface name to [ mesh$meshindex ]" | ||||||
|  | -						write_to_syslog | ||||||
|  | -					fi | ||||||
|  | -					meshindex=$(($meshindex+1)) | ||||||
|  | -				done | ||||||
|  | - | ||||||
|  | -				if [ "$changed" -eq 1 ]; then | ||||||
|  | -					changed=0 | ||||||
|  | -					restart_mesh | ||||||
|  | -					continue | ||||||
|  | -				fi | ||||||
|  | - | ||||||
|  |  				# get a list of interfaces | ||||||
|  |  				get_mesh_iflist | ||||||
|  |   | ||||||
|  | @@ -482,13 +462,13 @@ elif [ "$1" = "daemon" ]; then | ||||||
|  |  						# this is not a mesh interface | ||||||
|  |  						continue | ||||||
|  |  					else | ||||||
|  | -						# Check if this interface has a uci ifname | ||||||
|  | -						uciname=$(uci show wireless | grep "ifname='$iface'" | awk -F "." '{printf "wireless.%s" $2}') | ||||||
|  | +						# Check if this interface mode is 'mesh' | ||||||
|  | +						uciname=$(uci show wireless | grep "mode='mesh'" | awk -F "." '{printf "wireless.%s" $2}') | ||||||
|  |   | ||||||
|  |  						if [ -z "$uciname" ]; then | ||||||
|  | -							# Error - No interface name in config, we should have added one | ||||||
|  | +							# Error - No interface with mode as mesh | ||||||
|  |  							debugtype="err" | ||||||
|  | -							syslogmessage="Error getting mesh interface name" | ||||||
|  | +							syslogmessage="Error getting mesh interface section" | ||||||
|  |  							write_to_syslog | ||||||
|  |  							continue | ||||||
|  |  						fi | ||||||
| @@ -1,63 +0,0 @@ | |||||||
| # Description: The Mesh11sd daemon sets the interface name 'mesh<index>' to the mesh interface. |  | ||||||
| # However, even after disabling the mesh mode, this interface name persists, leading to confusion |  | ||||||
| # when operating in other modes like AP/STA/Ad-Hoc, where the interface name continues to display as 'mesh<idx>'. |  | ||||||
| # This patch addresses the issue by removing the 'mesh<idx>' interface name from the configuration when the device |  | ||||||
| # is no longer in mesh mode. As this modification is not present in the upstream version, it is necessary to apply |  | ||||||
| # this local patch to resolve the inconsistency |  | ||||||
|  |  | ||||||
| diff --git a/src/mesh11sd b/src/mesh11sd |  | ||||||
| index 85041d3..5f50e97 100755 |  | ||||||
| --- a/src/mesh11sd |  | ||||||
| +++ b/src/mesh11sd |  | ||||||
| @@ -387,45 +387,45 @@ elif [ "$1" = "daemon" ]; then |  | ||||||
|   |  | ||||||
|  		if [ $mode -eq 5 ]; then |  | ||||||
|  			# startup=4, statusmode=0, enabled=1 |  | ||||||
| +			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" |  | ||||||
|  			startup=0 |  | ||||||
|  			statusmode=0 |  | ||||||
|  			mode=1 |  | ||||||
| -			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" |  | ||||||
|   |  | ||||||
|  		elif [ $mode -eq 4 ]; then |  | ||||||
|  			# startup=4, statusmode=0, enabled=0 |  | ||||||
| +			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" |  | ||||||
|  			startup=0 |  | ||||||
|  			statusmode=2 |  | ||||||
|  			mode=0 |  | ||||||
| -			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" |  | ||||||
|   |  | ||||||
|  		elif [ $mode -eq 3 ]; then |  | ||||||
|  			# startup=0, statusmode=2, enabled=1 |  | ||||||
| +			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" |  | ||||||
|  			startup=0 |  | ||||||
|  			statusmode=0 |  | ||||||
|  			mode=1 |  | ||||||
| -			syslogmessage="mesh11sd v$version has started: mesh management mode $mode" |  | ||||||
|   |  | ||||||
|  		elif [ $mode -eq 2 ]; then |  | ||||||
|  			# startup=0, statusmode=2, enabled=0 |  | ||||||
| +			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" |  | ||||||
|  			startup=0 |  | ||||||
|  			statusmode=2 |  | ||||||
|  			mode=0 |  | ||||||
| -			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" |  | ||||||
|   |  | ||||||
|  		elif [ $mode -eq 1 ]; then |  | ||||||
|  			# startup=0, statusmode=0, enabled=1 |  | ||||||
| +			syslogmessage="mesh11sd v$version has started, mesh management mode $mode" |  | ||||||
|  			startup=0 |  | ||||||
|  			statusmode=0 |  | ||||||
|  			mode=1 |  | ||||||
| -			syslogmessage="mesh11sd v$version has started, mesh management mode $mode" |  | ||||||
|   |  | ||||||
|  		elif [ $mode -eq 0 ]; then |  | ||||||
|  			# startup=0, statusmode=0, enabled=0 |  | ||||||
| +			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" |  | ||||||
|  			startup=0 |  | ||||||
|  			statusmode=2 |  | ||||||
|  			mode=0 |  | ||||||
| -			syslogmessage="mesh11sd v$version has started: mesh status mode $mode" |  | ||||||
|  		fi |  | ||||||
|   |  | ||||||
|  		if [ $mode -ne $lastmode ]; then |  | ||||||
| @@ -1,39 +0,0 @@ | |||||||
| --- a/src/mesh11sd	2024-09-06 17:13:52.075070001 +0800 |  | ||||||
| +++ b/src/mesh11sd	2024-09-06 17:47:36.326914438 +0800 |  | ||||||
| @@ -434,7 +434,6 @@ |  | ||||||
|  		fi |  | ||||||
|   |  | ||||||
|  		lastmode=$mode |  | ||||||
| -		meshindex=0 |  | ||||||
|   |  | ||||||
|  		if [ "$enabled" = 1 ]; then |  | ||||||
|  			#get list of mesh configs |  | ||||||
| @@ -443,16 +442,19 @@ |  | ||||||
|  			if [ ! -z "$meshconfigs" ]; then |  | ||||||
|  				for meshconfig in $meshconfigs; do |  | ||||||
|  					ifname=$(uci get $meshconfig.ifname 2> /dev/null) |  | ||||||
| - |  | ||||||
| -					if [ -z "$ifname" ] || [ "$ifname" != "mesh$meshindex" ]; then |  | ||||||
| -						# No interface name in config, so add one |  | ||||||
| -						ucibatch="set $meshconfig.ifname='mesh$meshindex'" |  | ||||||
| -						echo "$ucibatch" | uci batch |  | ||||||
| -						changed=1 |  | ||||||
| -						syslogmessage="Setting mesh interface name to [ mesh$meshindex ]" |  | ||||||
| -						write_to_syslog |  | ||||||
| +					device=$(uci -q get $meshconfig.device) |  | ||||||
| +					device_type=$(uci -q get wireless.$device.type) |  | ||||||
| +					new_ifname="halow_mesh" |  | ||||||
| +					if [ "$device_type" == "morse" ]; then |  | ||||||
| +						if [ -z "$ifname" ] || [ "$ifname" != "$new_ifname" ]; then |  | ||||||
| +							# No interface name in config, so add one |  | ||||||
| +							ucibatch="set $meshconfig.ifname='$new_ifname'" |  | ||||||
| +							echo "$ucibatch" | uci batch |  | ||||||
| +							changed=1 |  | ||||||
| +							syslogmessage="Setting mesh interface name to [ $new_ifname ]" |  | ||||||
| +							write_to_syslog |  | ||||||
| +						fi |  | ||||||
|  					fi |  | ||||||
| -					meshindex=$(($meshindex+1)) |  | ||||||
|  				done |  | ||||||
|   |  | ||||||
|  				if [ "$changed" -eq 1 ]; then |  | ||||||
| @@ -2,7 +2,7 @@ if PACKAGE_wpa_supplicant_s1g | |||||||
|  |  | ||||||
| 	config MORSE_WPA_SUPPLICANT_S1G_MESH_NETWORKING | 	config MORSE_WPA_SUPPLICANT_S1G_MESH_NETWORKING | ||||||
| 		bool | 		bool | ||||||
| 		default y | 		default n | ||||||
| 		prompt "Enable mesh networking support" | 		prompt "Enable mesh networking support" | ||||||
|  |  | ||||||
| 	config MORSE_WPA_SUPPLICANT_S1G_EAP | 	config MORSE_WPA_SUPPLICANT_S1G_EAP | ||||||
|   | |||||||
| @@ -43,11 +43,6 @@ $(call Package/ath12k-wifi-default) | |||||||
|     TITLE:=board-2.bin for EAP105 |     TITLE:=board-2.bin for EAP105 | ||||||
| endef | endef | ||||||
|  |  | ||||||
| define Package/ath12k-wifi-emplus-wap7635 |  | ||||||
| $(call Package/ath12k-wifi-default) |  | ||||||
|     TITLE:=board-2.bin for WAP7635 |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/ath12k-wifi-sonicfi-rap7110c-341x | define Package/ath12k-wifi-sonicfi-rap7110c-341x | ||||||
| $(call Package/ath12k-wifi-default) | $(call Package/ath12k-wifi-default) | ||||||
|     TITLE:=board-2.bin for RAP7710c_341x |     TITLE:=board-2.bin for RAP7710c_341x | ||||||
| @@ -101,8 +96,8 @@ endef | |||||||
| define Package/ath12k-wifi-cig-wf189/install | define Package/ath12k-wifi-cig-wf189/install | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/ | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.wf189-us.QCN92XX $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.wf189.QCN92XX $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.wf189-us.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.wf189.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin | ||||||
| endef | endef | ||||||
|  |  | ||||||
| define Package/ath12k-wifi-edgecore-eap105/install | define Package/ath12k-wifi-edgecore-eap105/install | ||||||
| @@ -112,13 +107,6 @@ define Package/ath12k-wifi-edgecore-eap105/install | |||||||
| 	$(INSTALL_DATA) ./board-2.bin.eap105.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin | 	$(INSTALL_DATA) ./board-2.bin.eap105.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin | ||||||
| endef | endef | ||||||
|  |  | ||||||
| define Package/ath12k-wifi-emplus-wap7635/install |  | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ |  | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/ |  | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.wap7635.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin |  | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.wap7635.QCN6274 $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/ath12k-wifi-sonicfi-rap7110c-341x/install | define Package/ath12k-wifi-sonicfi-rap7110c-341x/install | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/ | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | ||||||
| @@ -156,8 +144,8 @@ endef | |||||||
| define Package/ath12k-wifi-cig-wf189w/install | define Package/ath12k-wifi-cig-wf189w/install | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN6432/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN6432/hw1.0/ | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.189w-us.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.189w.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.189w-us.QCN6432 $(1)/lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.189w.QCN6432 $(1)/lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin | ||||||
| 	$(INSTALL_DATA) ./ipq5332_qcn6432.regdb $(1)/lib/firmware/ath12k/QCN6432/hw1.0/regdb.bin | 	$(INSTALL_DATA) ./ipq5332_qcn6432.regdb $(1)/lib/firmware/ath12k/QCN6432/hw1.0/regdb.bin | ||||||
| endef | endef | ||||||
|  |  | ||||||
| @@ -165,8 +153,8 @@ endef | |||||||
| define Package/ath12k-wifi-cig-wf189h/install | define Package/ath12k-wifi-cig-wf189h/install | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN6432/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN6432/hw1.0/ | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.189h-us.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.189h.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.189h-us.QCN6432 $(1)/lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.189h.QCN6432 $(1)/lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin | ||||||
| 	$(INSTALL_DATA) ./ipq5332_qcn6432.regdb $(1)/lib/firmware/ath12k/QCN6432/hw1.0/regdb.bin | 	$(INSTALL_DATA) ./ipq5332_qcn6432.regdb $(1)/lib/firmware/ath12k/QCN6432/hw1.0/regdb.bin | ||||||
| endef | endef | ||||||
|  |  | ||||||
| @@ -194,13 +182,12 @@ endef | |||||||
| define Package/ath12k-wifi-cig-wf672/install | define Package/ath12k-wifi-cig-wf672/install | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/ | ||||||
| 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | 	$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/ | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.wf672-us.QCN92XX $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.wf672.QCN92XX $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin | ||||||
| 	$(INSTALL_DATA) ./board-2.bin.wf672-us.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.US | 	$(INSTALL_DATA) ./board-2.bin.wf672.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin | ||||||
| endef | endef | ||||||
|  |  | ||||||
| $(eval $(call BuildPackage,ath12k-wifi-cig-wf189)) | $(eval $(call BuildPackage,ath12k-wifi-cig-wf189)) | ||||||
| $(eval $(call BuildPackage,ath12k-wifi-edgecore-eap105)) | $(eval $(call BuildPackage,ath12k-wifi-edgecore-eap105)) | ||||||
| $(eval $(call BuildPackage,ath12k-wifi-emplus-wap7635)) |  | ||||||
| $(eval $(call BuildPackage,ath12k-wifi-sonicfi-rap7110c-341x)) | $(eval $(call BuildPackage,ath12k-wifi-sonicfi-rap7110c-341x)) | ||||||
| $(eval $(call BuildPackage,ath12k-wifi-sonicfi-rap750e-h)) | $(eval $(call BuildPackage,ath12k-wifi-sonicfi-rap750e-h)) | ||||||
| $(eval $(call BuildPackage,ath12k-wifi-sonicfi-rap750e-s)) | $(eval $(call BuildPackage,ath12k-wifi-sonicfi-rap750e-s)) | ||||||
|   | |||||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -4,19 +4,19 @@ let fs = require("fs"); | |||||||
| let ubus = require('ubus').connect(); | let ubus = require('ubus').connect(); | ||||||
|  |  | ||||||
| let gps_info = ubus.call('gps', 'info'); | let gps_info = ubus.call('gps', 'info'); | ||||||
| let latitude = gps_info.latitude || 0; | let latitude = gps_info.latitude ?? 0; | ||||||
| let longitude = gps_info.longitude || 0; | let longitude = gps_info.longitude ?? 0; | ||||||
|  |  | ||||||
| // afc-location.json file content | // afc-location.json file content | ||||||
| let afc_location = {}; | let afc_location = {}; | ||||||
| afc_location.location_type = "ellipse"; | afc_location.location_type = "ellipse"; | ||||||
| afc_location.location = longitude + ":" + latitude ; | afc_location.location = longitude + ":" + latitude ; | ||||||
| afc_location.height = gps_info.elevation || 0; | afc_location.height = gps_info.elevation ?? 0; | ||||||
| afc_location.height_type = "AMSL"; | afc_location.height_type = "AMSL"; | ||||||
| afc_location.major_axis = int(gps_info.major_axis) || 1; | afc_location.major_axis = gps_info.major_axis ?? 0; | ||||||
| afc_location.minor_axis = int(gps_info.minor_axis) || 1; | afc_location.minor_axis = gps_info.minor_axis ?? 0; | ||||||
| afc_location.orientation = gps_info.major_orientation || 0; | afc_location.orientation = gps_info.major_orientation ?? 0; | ||||||
| afc_location.vertical_tolerance = int(gps_info.vdop) || 1; | afc_location.vertical_tolerance = gps_info.vdop ?? 0; | ||||||
|  |  | ||||||
| let afc_location_json = fs.open("/etc/ucentral/afc-location.json", "w"); | let afc_location_json = fs.open("/etc/ucentral/afc-location.json", "w"); | ||||||
| afc_location_json.write(afc_location); | afc_location_json.write(afc_location); | ||||||
|   | |||||||
| @@ -1,8 +1,7 @@ | |||||||
| let libubus = require("ubus"); | let libubus = require("ubus"); | ||||||
| import { open, readfile, writefile } from "fs"; | import { open, readfile } from "fs"; | ||||||
| import { wdev_remove, is_equal, vlist_new, phy_is_fullmac, phy_open, wdev_set_radio_mask } from "common"; | import { wdev_remove, is_equal, vlist_new, phy_is_fullmac, phy_open, wdev_set_radio_mask } from "common"; | ||||||
|  |  | ||||||
| let uci = require('uci').cursor(); |  | ||||||
| let ubus = libubus.connect(null, 60); | let ubus = libubus.connect(null, 60); | ||||||
|  |  | ||||||
| hostapd.data.config = {}; | hostapd.data.config = {}; | ||||||
| @@ -1007,6 +1006,7 @@ let main_obj = { | |||||||
| hostapd.data.ubus = ubus; | hostapd.data.ubus = ubus; | ||||||
| hostapd.data.obj = ubus.publish("hostapd", main_obj); | hostapd.data.obj = ubus.publish("hostapd", main_obj); | ||||||
|  |  | ||||||
|  |  | ||||||
| let auth_obj = {}; | let auth_obj = {}; | ||||||
| hostapd.data.auth_obj = ubus.publish("hostapd-auth", auth_obj); | hostapd.data.auth_obj = ubus.publish("hostapd-auth", auth_obj); | ||||||
|  |  | ||||||
| @@ -1026,24 +1026,10 @@ return { | |||||||
| 		hostapd.ubus.disconnect(); | 		hostapd.ubus.disconnect(); | ||||||
| 	}, | 	}, | ||||||
| 	afc_request: function(iface, data) { | 	afc_request: function(iface, data) { | ||||||
| 		let wireless_config = uci.get_all('wireless'); | 		let ret = ubus.call("afc", "request", { data }); | ||||||
| 		for (let l, afc_server in wireless_config) { | 		if (type(ret) != "object") | ||||||
| 			if (afc_server['.type'] == 'afc-server' && afc_server.url && data) { | 			return; | ||||||
| 				hostapd.printf(`Sending AFC request: ${data}`); | 		return ret.data; | ||||||
| 				writefile("/tmp/afc-request.json", data); |  | ||||||
|  |  | ||||||
| 				if (afc_server.access_token) |  | ||||||
| 					system(`curl -s -X POST ${afc_server.url} -H \'accept: \*\/\*\' -H \'Authorization: Bearer ${afc_server.access_token}\' -H \'Content-Type: application/json\' -d \'${data}\' --output /tmp/afc-response.json`); |  | ||||||
| 				else if (afc_server.cert) |  | ||||||
| 					system(`curl -s -X POST ${afc_server.url} -H \'accept: \*\/\*\' --cert \'${afc_server.cert}\' -H \'Content-Type: application/json\' -d \'${data}\' --output /tmp/afc-response.json`); |  | ||||||
|  |  | ||||||
| 				let afc_response = (readfile("/tmp/afc-response.json")); |  | ||||||
| 				if (afc_response) |  | ||||||
| 					return afc_response; |  | ||||||
| 				else |  | ||||||
| 					return; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	}, | 	}, | ||||||
| 	bss_create: function(phy, name, obj) { | 	bss_create: function(phy, name, obj) { | ||||||
| 		phy = hostapd.data.config[phy]; | 		phy = hostapd.data.config[phy]; | ||||||
|   | |||||||
| @@ -7,11 +7,6 @@ board_config_update | |||||||
| board=$(board_name) | board=$(board_name) | ||||||
|  |  | ||||||
| case "$board" in | case "$board" in | ||||||
| emplus,wap7635) |  | ||||||
| 	ucidef_set_led_default "ledb" "LEDB" "sys:blue" "on" |  | ||||||
| 	ucidef_set_led_default "ledg" "LEDG" "sys:green" "off" |  | ||||||
| 	ucidef_set_led_default "ledr" "LEDR" "sys:red" "off" |  | ||||||
| 	;; |  | ||||||
| sercomm,ap72tip-v4|\ | sercomm,ap72tip-v4|\ | ||||||
| sercomm,ap72tip) | sercomm,ap72tip) | ||||||
| 	ucidef_set_led_default "power" "POWER" "blue:status" "on" | 	ucidef_set_led_default "power" "POWER" "blue:status" "on" | ||||||
|   | |||||||
| @@ -13,6 +13,7 @@ ipq53xx_setup_interfaces() | |||||||
| 		ucidef_set_interfaces_lan_wan "eth1 eth2 eth3 eth4 eth5" "eth0" | 		ucidef_set_interfaces_lan_wan "eth1 eth2 eth3 eth4 eth5" "eth0" | ||||||
| 		;; | 		;; | ||||||
| 	cig,wf189|\ | 	cig,wf189|\ | ||||||
|  | 	cig,wf672|\ | ||||||
| 	edgecore,eap105|\ | 	edgecore,eap105|\ | ||||||
| 	sercomm,ap72tip|\ | 	sercomm,ap72tip|\ | ||||||
| 	sonicfi,rap750w-311a) | 	sonicfi,rap750w-311a) | ||||||
| @@ -31,10 +32,6 @@ ipq53xx_setup_interfaces() | |||||||
| 		ucidef_set_interfaces_lan_wan "eth1" "eth0" | 		ucidef_set_interfaces_lan_wan "eth1" "eth0" | ||||||
| 		ucidef_add_switch "switch1" "0u@eth1" "3:lan" "2:lan" | 		ucidef_add_switch "switch1" "0u@eth1" "3:lan" "2:lan" | ||||||
| 		;; | 		;; | ||||||
| 	cig,wf672) |  | ||||||
| 		ucidef_set_interface_wan "eth0 eth1" |  | ||||||
| 		;; |  | ||||||
| 	emplus,wap7635|\ |  | ||||||
| 	sercomm,ap72tip-v4) | 	sercomm,ap72tip-v4) | ||||||
| 		ucidef_set_interface_wan "eth0" | 		ucidef_set_interface_wan "eth0" | ||||||
| 		;;	 | 		;;	 | ||||||
| @@ -107,7 +104,6 @@ qcom_setup_macs() | |||||||
|                 ucidef_set_wireless_macaddr_base 2g $(macaddr_add "$wan_mac" 2) |                 ucidef_set_wireless_macaddr_base 2g $(macaddr_add "$wan_mac" 2) | ||||||
|                 ucidef_set_wireless_macaddr_base 5g $(macaddr_add "$wan_mac" 3) |                 ucidef_set_wireless_macaddr_base 5g $(macaddr_add "$wan_mac" 3) | ||||||
|                 ;; |                 ;; | ||||||
|         emplus,wap7635|\ |  | ||||||
|         sercomm,ap72tip-v4) |         sercomm,ap72tip-v4) | ||||||
|                 wan_mac=$(cat /sys/class/net/eth0/address) |                 wan_mac=$(cat /sys/class/net/eth0/address) | ||||||
|                 ucidef_set_wireless_macaddr_base 2g $(macaddr_add "$wan_mac" 1) |                 ucidef_set_wireless_macaddr_base 2g $(macaddr_add "$wan_mac" 1) | ||||||
|   | |||||||
| @@ -64,7 +64,6 @@ ath12k/IPQ5332/hw1.0/caldata.bin) | |||||||
| 	cig,wf189h|\ | 	cig,wf189h|\ | ||||||
| 	cig,wf189|\ | 	cig,wf189|\ | ||||||
| 	edgecore,eap105|\ | 	edgecore,eap105|\ | ||||||
| 	emplus,wap7635|\ |  | ||||||
| 	sercomm,ap72tip-v4|\ | 	sercomm,ap72tip-v4|\ | ||||||
| 	sercomm,ap72tip|\ | 	sercomm,ap72tip|\ | ||||||
| 	zyxel,nwa130be) | 	zyxel,nwa130be) | ||||||
| @@ -87,7 +86,6 @@ ath12k/QCN92XX/hw1.0/cal-pci-0001:01:00.0.bin) | |||||||
| 	case "$board" in | 	case "$board" in | ||||||
| 	cig,wf189|\ | 	cig,wf189|\ | ||||||
| 	edgecore,eap105|\ | 	edgecore,eap105|\ | ||||||
| 	emplus,wap7635|\ |  | ||||||
| 	sercomm,ap72tip-v4|\ | 	sercomm,ap72tip-v4|\ | ||||||
| 	sercomm,ap72tip|\ | 	sercomm,ap72tip|\ | ||||||
| 	zyxel,nwa130be) | 	zyxel,nwa130be) | ||||||
| @@ -126,47 +124,6 @@ ath12k/QCN6432/hw1.0/cal-ahb-soc@0:wifi2@c0000000.bin) | |||||||
| 		;; | 		;; | ||||||
| 	esac | 	esac | ||||||
| 	;; | 	;; | ||||||
| ath12k/IPQ5332/hw1.0/board-2.bin) |  | ||||||
| 	case "$board" in |  | ||||||
| 	cig,wf189|\ |  | ||||||
| 	cig,wf189h|\ |  | ||||||
| 	cig,wf189w|\ |  | ||||||
| 	cig,wf672) |  | ||||||
|                 country=`cat /etc/ucentral/country` |  | ||||||
|                 if [ "$country" == "CA" ]; then |  | ||||||
|                         ln -s /lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.CA /lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin |  | ||||||
|                 else |  | ||||||
|                         ln -s /lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.US /lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin |  | ||||||
|                 fi |  | ||||||
|                 ;; |  | ||||||
| 	esac |  | ||||||
| 	;; |  | ||||||
| ath12k/QCN6432/hw1.0/board-2.bin) |  | ||||||
| 	case "$board" in |  | ||||||
| 	cig,wf189h|\ |  | ||||||
| 	cig,wf189w) |  | ||||||
|                 country=`cat /etc/ucentral/country` |  | ||||||
|                 if [ "$country" == "CA" ]; then |  | ||||||
|                         ln -s /lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin.CA /lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin |  | ||||||
|                 else |  | ||||||
|                         ln -s /lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin.US /lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin |  | ||||||
|                 fi |  | ||||||
|                 ;; |  | ||||||
| 	esac |  | ||||||
| 	;; |  | ||||||
| ath12k/QCN92XX/hw1.0/board-2.bin) |  | ||||||
| 	case "$board" in |  | ||||||
| 	cig,wf189|\ |  | ||||||
| 	cig,wf672) |  | ||||||
|                 country=`cat /etc/ucentral/country` |  | ||||||
|                 if [ "$country" == "CA" ]; then |  | ||||||
|                         ln -s /lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin.CA /lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin |  | ||||||
|                 else |  | ||||||
|                         ln -s /lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin.US /lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin |  | ||||||
|                 fi |  | ||||||
|                 ;; |  | ||||||
| 	esac |  | ||||||
| 	;; |  | ||||||
| *) | *) | ||||||
| 	exit 1 | 	exit 1 | ||||||
| 	;; | 	;; | ||||||
|   | |||||||
| @@ -136,8 +136,7 @@ platform_do_upgrade() { | |||||||
| 	sercomm,ap72tip|\ | 	sercomm,ap72tip|\ | ||||||
| 	cig,wf189w|\ | 	cig,wf189w|\ | ||||||
| 	cig,wf189h|\ | 	cig,wf189h|\ | ||||||
| 	cig,wf189|\ | 	cig,wf189) | ||||||
| 	emplus,wap7635) |  | ||||||
| 		if [ -f /proc/boot_info/bootconfig0/rootfs/upgradepartition ]; then | 		if [ -f /proc/boot_info/bootconfig0/rootfs/upgradepartition ]; then | ||||||
| 			CI_UBIPART="$(cat /proc/boot_info/bootconfig0/rootfs/upgradepartition)" | 			CI_UBIPART="$(cat /proc/boot_info/bootconfig0/rootfs/upgradepartition)" | ||||||
| 			CI_BOOTCFG=1 | 			CI_BOOTCFG=1 | ||||||
|   | |||||||
| @@ -1,413 +0,0 @@ | |||||||
| // SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause) |  | ||||||
| /* |  | ||||||
|  * IPQ5332 RDP468 board device tree source |  | ||||||
|  * |  | ||||||
|  * Copyright (c) 2020-2021 The Linux Foundation. All rights reserved. |  | ||||||
|  * Copyright (c) 2022-2023 Qualcomm Innovation Center, Inc. All rights reserved. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| /dts-v1/; |  | ||||||
|  |  | ||||||
| #include <dt-bindings/gpio/gpio.h> |  | ||||||
| #include <dt-bindings/input/input.h> |  | ||||||
| #include <dt-bindings/leds/common.h> |  | ||||||
| #include "ipq5332.dtsi" |  | ||||||
| #include "ipq5332-default-memory.dtsi" |  | ||||||
|  |  | ||||||
| / { |  | ||||||
| 	model = "Emplus WAP7635"; |  | ||||||
| 	compatible = "emplus,wap7635", "qcom,ipq5332-ap-mi01.6", "qcom,ipq5332"; |  | ||||||
|  |  | ||||||
| 	aliases { |  | ||||||
| 		serial0 = &blsp1_uart0; /*console*/ |  | ||||||
| 		ethernet0 = "/soc/dp1"; |  | ||||||
|  |  | ||||||
|         led-boot = &led_power_green; |  | ||||||
|         led-failsafe = &led_power_red; |  | ||||||
|         led-running = &led_power_green; |  | ||||||
|         led-upgrade = &led_power_green; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	chosen { |  | ||||||
| 		stdout-path = "serial0"; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	soc@0 { |  | ||||||
| 		mdio:mdio@90000 { |  | ||||||
| 			pinctrl-0 = <&mdio1_pins>; |  | ||||||
| 			pinctrl-names = "default"; |  | ||||||
| 			phy-reset-gpio = <&tlmm 51 GPIO_ACTIVE_LOW>; |  | ||||||
| 			phyaddr_fixup = <0xC90F018>; |  | ||||||
| 			uniphyaddr_fixup = <0xC90F014>; |  | ||||||
| 			mdio_clk_fixup; /* MDIO clock sequence fix up flag */ |  | ||||||
| 			status = "okay"; |  | ||||||
|  |  | ||||||
| 			phy0: ethernet-phy@0 { |  | ||||||
| 				reg = <24>; |  | ||||||
| 			}; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		ess-instance { |  | ||||||
| 			/*num_devices = <0x1>;*/ |  | ||||||
| 			ess-switch@3a000000 { |  | ||||||
| 				switch_cpu_bmp = <0x1>;  /* cpu port bitmap */ |  | ||||||
| 				switch_lan_bmp = <0x2>; /* lan port bitmap */ |  | ||||||
| 				switch_wan_bmp = <0>; /* wan port bitmap */ |  | ||||||
| 				switch_mac_mode = <0xf>; /* mac mode for uniphy instance0*/ |  | ||||||
| 				switch_mac_mode1 = <0xd>; /* mac mode for uniphy instance1*/ |  | ||||||
| 				switch_mac_mode2 = <0xff>; /* mac mode for uniphy instance2*/ |  | ||||||
|  |  | ||||||
| 				qcom,port_phyinfo { |  | ||||||
| 					port@0 { |  | ||||||
| 						port_id = <1>; |  | ||||||
| 						phy_address = <24>; |  | ||||||
| 						mdiobus = <&mdio>; |  | ||||||
| 						ethernet-phy-ieee802.3-c45; |  | ||||||
| 					}; |  | ||||||
| 				}; |  | ||||||
| 			}; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		dp1 { |  | ||||||
| 			device_type = "network"; |  | ||||||
| 			compatible = "qcom,nss-dp"; |  | ||||||
| 			qcom,id = <1>; |  | ||||||
| 			reg = <0x3a500000 0x4000>; |  | ||||||
| 			qcom,mactype = <1>; |  | ||||||
| 			local-mac-address = [000000000000]; |  | ||||||
| 			mdio-bus = <&mdio>; |  | ||||||
| 			qcom,phy-mdio-addr = <24>; |  | ||||||
| 			qcom,link-poll = <1>; |  | ||||||
| 			phy-mode = "sgmii"; |  | ||||||
| 			/* phy-mode = "usxgmii"; */ |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		/* EDMA host driver configuration for the board */ |  | ||||||
| 		edma@3ab00000 { |  | ||||||
| 			qcom,txdesc-ring-start = <4>;		/* Tx desc ring start ID */ |  | ||||||
| 			qcom,txdesc-rings = <12>;			/* Total number of Tx desc rings to be provisioned */ |  | ||||||
| 			qcom,mht-txdesc-rings = <8>;		/* Extra Tx desc rings to be provisioned for MHT SW ports */ |  | ||||||
| 			qcom,txcmpl-ring-start = <4>;		/* Tx complete ring start ID */ |  | ||||||
| 			qcom,txcmpl-rings = <12>;			/* Total number of Tx complete rings to be provisioned */ |  | ||||||
| 			qcom,mht-txcmpl-rings = <8>;		/* Extra Tx complete rings to be provisioned for mht sw ports. */ |  | ||||||
| 			qcom,rxfill-ring-start = <4>;		/* Rx fill ring start ID */ |  | ||||||
| 			qcom,rxfill-rings = <4>;			/* Total number of Rx fill rings to be provisioned */ |  | ||||||
| 			qcom,rxdesc-ring-start = <12>;		/* Rx desc ring start ID */ |  | ||||||
| 			qcom,rxdesc-rings = <4>;			/* Total number of Rx desc rings to be provisioned */ |  | ||||||
| 			qcom,rx-page-mode = <0>;			/* Rx fill ring page mode */ |  | ||||||
| 			qcom,tx-map-priority-level = <1>;	/* Tx priority level per port */ |  | ||||||
| 			qcom,rx-map-priority-level = <1>;	/* Rx priority level per core */ |  | ||||||
| 			qcom,ppeds-num = <2>;				/* Number of PPEDS nodes */ |  | ||||||
|  |  | ||||||
| 			/* PPE-DS node format: <Rx-fill Tx-cmpl Rx Tx Queue-base Queue-count> */ |  | ||||||
| 			qcom,ppeds-map = <1 1 1 1 32 8>,		/* PPEDS Node#0 ring and queue map */ |  | ||||||
| 							 <2 2 2 2 40 8>;		/* PPEDS Node#1 ring and queue map */ |  | ||||||
| 			qcom,txdesc-map = <8 9 10 11>,			/* Port0 per-core Tx ring map */ |  | ||||||
| 							  <12 13 14 15>,		/* MHT-Port1 per-core Tx ring map */ |  | ||||||
| 							  <4 5 6 7>,			/* MHT-Port2 per-core Tx ring map/packets from  vp*/ |  | ||||||
| 							  <16 17 18 19>,		/* MHT-Port3 per-core Tx ring map */ |  | ||||||
| 							  <20 21 22 23>;		/* MHT-Port4 per-core Tx ring map */ |  | ||||||
| 			qcom,txdesc-fc-grp-map = <1 2 3 4 5>;	/* Per GMAC flow control group map */ |  | ||||||
| 			qcom,rxfill-map = <4 5 6 7>;			/* Per-core Rx fill ring map */ |  | ||||||
| 			qcom,rxdesc-map = <12 13 14 15>;		/* Per-core Rx desc ring map */ |  | ||||||
| 			qcom,rx-queue-start = <0>;				/* Rx queue start */ |  | ||||||
| 			qcom,rx-ring-queue-map = <0 8 16 24>,	/* Priority 0 queues per-core Rx ring map */ |  | ||||||
| 									 <1 9 17 25>,	/* Priority 1 queues per-core Rx ring map */ |  | ||||||
| 									 <2 10 18 26>,	/* Priority 2 queues per-core Rx ring map */ |  | ||||||
| 									 <3 11 19 27>,	/* Priority 3 queues per-core Rx ring map */ |  | ||||||
| 									 <4 12 20 28>,	/* Priority 4 queues per-core Rx ring map */ |  | ||||||
| 									 <5 13 21 29>,	/* Priority 5 queues per-core Rx ring map */ |  | ||||||
| 									 <6 14 22 30>,	/* Priority 6 queues per-core Rx ring map */ |  | ||||||
| 									 <7 15 23 31>;	/* Priority 7 queues per-core Rx ring map */ |  | ||||||
| 			interrupts = <0 163 4>,					/* Tx complete ring id #4 IRQ info */ |  | ||||||
| 						 <0 164 4>,					/* Tx complete ring id #5 IRQ info */ |  | ||||||
| 						 <0 165 4>,					/* Tx complete ring id #6 IRQ info */ |  | ||||||
| 						 <0 166 4>,					/* Tx complete ring id #7 IRQ info */ |  | ||||||
| 						 <0 167 4>,					/* Tx complete ring id #8 IRQ info */ |  | ||||||
| 						 <0 168 4>,					/* Tx complete ring id #9 IRQ info */ |  | ||||||
| 						 <0 169 4>,					/* Tx complete ring id #10 IRQ info */ |  | ||||||
| 						 <0 170 4>,					/* Tx complete ring id #11 IRQ info */ |  | ||||||
| 						 <0 171 4>,					/* Tx complete ring id #12 IRQ info */ |  | ||||||
| 						 <0 172 4>,					/* Tx complete ring id #13 IRQ info */ |  | ||||||
| 						 <0 173 4>,					/* Tx complete ring id #14 IRQ info */ |  | ||||||
| 						 <0 174 4>,					/* Tx complete ring id #15 IRQ info */ |  | ||||||
| 						 <0 139 4>,					/* Rx desc ring id #12 IRQ info */ |  | ||||||
| 						 <0 140 4>,					/* Rx desc ring id #13 IRQ info */ |  | ||||||
| 						 <0 141 4>,					/* Rx desc ring id #14 IRQ info */ |  | ||||||
| 						 <0 142 4>,					/* Rx desc ring id #15 IRQ info */ |  | ||||||
| 						 <0 191 4>,					/* Misc error IRQ info */ |  | ||||||
| 						 <0 155 4>,					/* RxFill ring id #4 IRQ info */ |  | ||||||
| 						 <0 156 4>,					/* RxFill ring id #5 IRQ info */ |  | ||||||
| 						 <0 157 4>,					/* RxFill ring id #6 IRQ info */ |  | ||||||
| 						 <0 158 4>,					/* RxFill ring id #7 IRQ info */ |  | ||||||
| 						 <0 160 4>,					/* PPEDS Node #1(TxComp ring id #1) TxComplete IRQ info */ |  | ||||||
| 						 <0 128 4>,					/* PPEDS Node #1(Rx Desc ring id #1) Rx Desc IRQ info */ |  | ||||||
| 						 <0 152 4>,					/* PPEDS Node #1(RxFill Desc ring id #1) Rx Fill IRQ info */ |  | ||||||
| 						 <0 161 4>,					/* PPEDS Node #2(TxComp ring id #2) TxComplete IRQ info */ |  | ||||||
| 						 <0 129 4>,					/* PPEDS Node #2(Rx Desc ring id #2) Rx Desc IRQ info */ |  | ||||||
| 						 <0 153 4>,					/* PPEDS Node #2(RxFill Desc ring id #2) Rx Fill IRQ info */ |  | ||||||
| 						 <0 175 4>,					/* MHT port Tx complete ring id #16 IRQ info */ |  | ||||||
| 						 <0 176 4>,					/* MHT port Tx complete ring id #17 IRQ info */ |  | ||||||
| 						 <0 177 4>,					/* MHT port Tx complete ring id #18 IRQ info */ |  | ||||||
| 						 <0 178 4>,					/* MHT port Tx complete ring id #19 IRQ info */ |  | ||||||
| 						 <0 179 4>,					/* MHT port Tx complete ring id #20 IRQ info */ |  | ||||||
| 						 <0 180 4>,					/* MHT port Tx complete ring id #21 IRQ info */ |  | ||||||
| 						 <0 181 4>,					/* MHT port Tx complete ring id #22 IRQ info */ |  | ||||||
| 						 <0 182 4>;					/* MHT port Tx complete ring id #23 IRQ info */ |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		leds { |  | ||||||
| 			compatible = "gpio-leds"; |  | ||||||
|  |  | ||||||
| 			led_power_blue: led@34 { |  | ||||||
| 				label = "sys:blue"; |  | ||||||
| 				gpios = <&tlmm 34 GPIO_ACTIVE_HIGH>; |  | ||||||
| 				default-state = "off"; |  | ||||||
| 			}; |  | ||||||
| 			led_power_green: led@35 { |  | ||||||
| 				label = "sys:green"; |  | ||||||
| 				gpios = <&tlmm 35 GPIO_ACTIVE_HIGH>; |  | ||||||
| 				default-state = "off"; |  | ||||||
| 			}; |  | ||||||
| 			led_power_red: led@37 { |  | ||||||
| 				label = "sys:red"; |  | ||||||
| 				gpios = <&tlmm 37 GPIO_ACTIVE_HIGH>; |  | ||||||
| 				default-state = "off"; |  | ||||||
| 			}; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		gpio_keys { |  | ||||||
| 			compatible = "gpio-keys"; |  | ||||||
| 			pinctrl-0 = <&button_pins>; |  | ||||||
| 			pinctrl-names = "default"; |  | ||||||
| 			button@1 { |  | ||||||
| 				label = "reset"; |  | ||||||
| 				linux,code = <KEY_RESTART>; |  | ||||||
| 				gpios = <&tlmm 24 GPIO_ACTIVE_LOW>; |  | ||||||
| 				linux,input-type = <1>; |  | ||||||
| 				debounce-interval = <60>; |  | ||||||
| 			}; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		wsi: wsi { |  | ||||||
| 			id = <0>; |  | ||||||
| 			num_chip = <2>; |  | ||||||
| 			status = "okay"; |  | ||||||
| 			chip_info = <0 1 1>, |  | ||||||
| 						<1 1 0>; |  | ||||||
| 		}; |  | ||||||
| 	}; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &wifi0 { |  | ||||||
| 	led-gpio = <&tlmm 36 GPIO_ACTIVE_HIGH>; |  | ||||||
| 	qcom,rproc = <&q6_wcss_pd1>; |  | ||||||
| 	qcom,rproc_rpd = <&q6v5_wcss>; |  | ||||||
| 	qcom,multipd_arch; |  | ||||||
| 	qcom,userpd-subsys-name = "q6v5_wcss_userpd1"; |  | ||||||
| 	memory-region = <&q6_region>; |  | ||||||
| 	qcom,wsi = <&wsi>; |  | ||||||
| 	qcom,wsi_index = <0>; |  | ||||||
| 	qcom,board_id = <0x16>; |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &mhi_region1 { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &qcn9224_pcie1 { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| /* QCN9224 5G+6G */ |  | ||||||
| &wifi4 { |  | ||||||
| 	hremote_node = <&qcn9224_pcie1>; |  | ||||||
| 	board_id = <0x1019>; |  | ||||||
| 	node_id = <0x1>; |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &blsp1_uart0 { |  | ||||||
| 	pinctrl-0 = <&serial_0_pins>; |  | ||||||
| 	pinctrl-names = "default"; |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &blsp1_uart1 { |  | ||||||
| 	pinctrl-0 = <&serial_1_pins>; |  | ||||||
| 	pinctrl-names = "default"; |  | ||||||
| 	status = "disabled"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &sdhc { |  | ||||||
| 	bus-width = <4>; |  | ||||||
| 	max-frequency = <192000000>; |  | ||||||
| 	mmc-ddr-1_8v; |  | ||||||
| 	mmc-hs200-1_8v; |  | ||||||
| 	non-removable; |  | ||||||
| 	pinctrl-0 = <&sdc_default_state>; |  | ||||||
| 	pinctrl-names = "default"; |  | ||||||
| 	status = "disabled"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &sleep_clk { |  | ||||||
| 	clock-frequency = <32000>; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &xo { |  | ||||||
| 	clock-frequency = <24000000>; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &qpic_bam { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &qpic_nand { |  | ||||||
| 	pinctrl-0 = <&qspi_default_state>; |  | ||||||
| 	pinctrl-names = "default"; |  | ||||||
| 	status = "okay"; |  | ||||||
|  |  | ||||||
| 	nandcs@0 { |  | ||||||
| 		reg = <0>; |  | ||||||
| 		#address-cells = <1>; |  | ||||||
| 		#size-cells = <1>; |  | ||||||
|  |  | ||||||
| 		nand-ecc-strength = <8>; |  | ||||||
| 		nand-ecc-step-size = <512>; |  | ||||||
| 		nand-bus-width = <8>; |  | ||||||
| 	}; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &pcie1_phy_x2 { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &pcie1 { |  | ||||||
| 	pinctrl-0 = <&pcie1_default_state>; |  | ||||||
| 	pinctrl-names = "default"; |  | ||||||
| 	perst-gpios = <&tlmm 45 GPIO_ACTIVE_LOW>; |  | ||||||
| 	status = "okay"; |  | ||||||
|  |  | ||||||
| 	pcie1_rp { |  | ||||||
| 		reg = <0 0 0 0 0>; |  | ||||||
|  |  | ||||||
| 		qcom,mhi@1 { |  | ||||||
| 			reg = <0 0 0 0 0>; |  | ||||||
| 			boot-args = <0x2 0x4 0x34 0x3 0x0 0x0     /* MX Rail, GPIO52, Drive strength 0x3 */ |  | ||||||
| 						 0x4 0x4 0x18 0x3 0x0 0x0     /* RFA1p2 Rail, GPIO24, Drive strength 0x3 */ |  | ||||||
| 						 0x0 0x4 0x0 0x0 0x0 0x0>;    /* End of arguments */ |  | ||||||
| 			memory-region = <&qcn9224_pcie1>; |  | ||||||
| 			qcom,wsi = <&wsi>; |  | ||||||
| 			qcom,wsi_index = <1>; |  | ||||||
| 			qcom,board_id = <0x1019>; |  | ||||||
| 		}; |  | ||||||
| 	}; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| /* PINCTRL */ |  | ||||||
|  |  | ||||||
| &tlmm { |  | ||||||
| 	sdc_default_state: sdc-default-state { |  | ||||||
| 		clk-pins { |  | ||||||
| 			pins = "gpio13"; |  | ||||||
| 			function = "sdc_clk"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-disable; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		cmd-pins { |  | ||||||
| 			pins = "gpio12"; |  | ||||||
| 			function = "sdc_cmd"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-pull-up; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		data-pins { |  | ||||||
| 			pins = "gpio8", "gpio9", "gpio10", "gpio11"; |  | ||||||
| 			function = "sdc_data"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-pull-up; |  | ||||||
| 		}; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	spi_0_data_clk_pins: spi-0-data-clk-state { |  | ||||||
| 		pins = "gpio14", "gpio15", "gpio16"; |  | ||||||
| 		function = "blsp0_spi"; |  | ||||||
| 		drive-strength = <2>; |  | ||||||
| 		bias-pull-down; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	spi_0_cs_pins: spi-0-cs-state { |  | ||||||
| 		pins = "gpio17"; |  | ||||||
| 		function = "blsp0_spi"; |  | ||||||
| 		drive-strength = <2>; |  | ||||||
| 		bias-pull-up; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	qspi_default_state: qspi-default-state { |  | ||||||
| 		qspi_clock { |  | ||||||
| 			pins = "gpio13"; |  | ||||||
| 			function = "qspi_clk"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-pull-down; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		qspi_cs { |  | ||||||
| 			pins = "gpio12"; |  | ||||||
| 			function = "qspi_cs"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-pull-up; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		qspi_data { |  | ||||||
| 			pins = "gpio8", "gpio9", "gpio10", "gpio11"; |  | ||||||
| 			function = "qspi_data"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-pull-down; |  | ||||||
| 		}; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	serial_1_pins: serial1-pinmux { /*ble*/ |  | ||||||
| 		pins = "gpio33", "gpio35"; |  | ||||||
| 		function = "blsp1_uart2"; |  | ||||||
| 		drive-strength = <8>; |  | ||||||
| 		bias-pull-up; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	button_pins: button-state { |  | ||||||
| 		pins = "gpio24"; |  | ||||||
| 		function = "gpio"; |  | ||||||
| 		drive-strength = <8>; |  | ||||||
| 		bias-pull-up; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	pcie1_default_state: pcie1-default-state { |  | ||||||
| 		pins = "gpio45"; |  | ||||||
| 		function = "gpio"; |  | ||||||
| 		drive-strength = <8>; |  | ||||||
| 		bias-pull-up; |  | ||||||
| 		output-low; |  | ||||||
| 	}; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &license_manager { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &usb3 { |  | ||||||
| 	qcom,multiplexed-phy; |  | ||||||
| 	status = "disabled"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &hs_m31phy_0 { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &hs_m31phy_0 { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| &ssuniphy_0 { |  | ||||||
| 	status = "okay"; |  | ||||||
| }; |  | ||||||
| @@ -31,20 +31,6 @@ | |||||||
| 		stdout-path = "serial0"; | 		stdout-path = "serial0"; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	reserved-memory { |  | ||||||
| 		#address-cells = <2>; |  | ||||||
| 		#size-cells = <2>; |  | ||||||
| 		ranges; |  | ||||||
|  |  | ||||||
| 		ramoops@49c00000 { |  | ||||||
| 			compatible = "ramoops"; |  | ||||||
| 			reg = <0x0 0x49c00000 0x0 0x100000>; |  | ||||||
| 			record-size = <0x20000>; |  | ||||||
| 			console-size = <0x20000>; |  | ||||||
| 			pmsg-size = <0x20000>; |  | ||||||
| 		}; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	soc@0 { | 	soc@0 { | ||||||
| 		mdio:mdio@90000 { | 		mdio:mdio@90000 { | ||||||
| 			pinctrl-0 = <&mdio1_pins>; | 			pinctrl-0 = <&mdio1_pins>; | ||||||
|   | |||||||
| @@ -190,14 +190,6 @@ | |||||||
| 		/delete-node/ wcnss@4a900000; | 		/delete-node/ wcnss@4a900000; | ||||||
| 		/delete-node/ q6_caldb_region@4ce00000; | 		/delete-node/ q6_caldb_region@4ce00000; | ||||||
|  |  | ||||||
| 		ramoops@49c00000 { |  | ||||||
| 			compatible = "ramoops"; |  | ||||||
| 			reg = <0x0 0x49c00000 0x0 0x100000>; |  | ||||||
| 			record-size = <0x20000>; |  | ||||||
| 			console-size = <0x20000>; |  | ||||||
| 			pmsg-size = <0x20000>; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		q6_mem_regions: q6_mem_regions@4A900000  { | 		q6_mem_regions: q6_mem_regions@4A900000  { | ||||||
| 		        no-map; | 		        no-map; | ||||||
| 		        reg = <0x0 0x4A900000 0x0 0x5100000>; | 		        reg = <0x0 0x4A900000 0x0 0x5100000>; | ||||||
|   | |||||||
| @@ -190,14 +190,6 @@ | |||||||
| 		/delete-node/ wcnss@4a900000; | 		/delete-node/ wcnss@4a900000; | ||||||
| 		/delete-node/ q6_caldb_region@4ce00000; | 		/delete-node/ q6_caldb_region@4ce00000; | ||||||
|  |  | ||||||
| 		ramoops@49c00000 { |  | ||||||
| 			compatible = "ramoops"; |  | ||||||
| 			reg = <0x0 0x49c00000 0x0 0x100000>; |  | ||||||
| 			record-size = <0x20000>; |  | ||||||
| 			console-size = <0x20000>; |  | ||||||
| 			pmsg-size = <0x20000>; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		q6_mem_regions: q6_mem_regions@4A900000  { | 		q6_mem_regions: q6_mem_regions@4A900000  { | ||||||
| 		        no-map; | 		        no-map; | ||||||
| 		        reg = <0x0 0x4A900000 0x0 0x5100000>; | 		        reg = <0x0 0x4A900000 0x0 0x5100000>; | ||||||
|   | |||||||
| @@ -190,14 +190,6 @@ | |||||||
| 		/delete-node/ wcnss@4a900000; | 		/delete-node/ wcnss@4a900000; | ||||||
| 		/delete-node/ q6_caldb_region@4ce00000; | 		/delete-node/ q6_caldb_region@4ce00000; | ||||||
|  |  | ||||||
| 		ramoops@49c00000 { |  | ||||||
| 			compatible = "ramoops"; |  | ||||||
| 			reg = <0x0 0x49c00000 0x0 0x100000>; |  | ||||||
| 			record-size = <0x20000>; |  | ||||||
| 			console-size = <0x20000>; |  | ||||||
| 			pmsg-size = <0x20000>; |  | ||||||
| 		}; |  | ||||||
|  |  | ||||||
| 		q6_mem_regions: q6_mem_regions@4A900000  { | 		q6_mem_regions: q6_mem_regions@4A900000  { | ||||||
| 		        no-map; | 		        no-map; | ||||||
| 		        reg = <0x0 0x4A900000 0x0 0x5100000>; | 		        reg = <0x0 0x4A900000 0x0 0x5100000>; | ||||||
|   | |||||||
| @@ -52,19 +52,6 @@ define Device/edgecore_eap105 | |||||||
| endef | endef | ||||||
| TARGET_DEVICES += edgecore_eap105 | TARGET_DEVICES += edgecore_eap105 | ||||||
|  |  | ||||||
| define Device/emplus_wap7635 |  | ||||||
|   DEVICE_TITLE := EMPLUS WAP7635 |  | ||||||
|   DEVICE_DTS := ipq5332-emplus-wap7635 |  | ||||||
|   DEVICE_DTS_DIR := ../dts |  | ||||||
|   DEVICE_DTS_CONFIG := config@mi01.6 |  | ||||||
|   IMAGES := sysupgrade.tar nand-factory.bin nand-factory.ubi |  | ||||||
|   IMAGE/sysupgrade.tar := sysupgrade-tar | append-metadata |  | ||||||
|   IMAGE/nand-factory.bin := append-ubi | qsdk-ipq-factory-nand |  | ||||||
|   IMAGE/nand-factory.ubi := append-ubi |  | ||||||
|   DEVICE_PACKAGES := ath12k-wifi-emplus-wap7635 ath12k-firmware-qcn92xx ath12k-firmware-ipq5332 |  | ||||||
| endef |  | ||||||
| TARGET_DEVICES += emplus_wap7635 |  | ||||||
|  |  | ||||||
| define Device/sonicfi_rap7110c_341x | define Device/sonicfi_rap7110c_341x | ||||||
|   DEVICE_TITLE := SONICFI RAP7110C-341X |   DEVICE_TITLE := SONICFI RAP7110C-341X | ||||||
|   DEVICE_DTS := ipq5332-sonicfi-rap7110c-341x |   DEVICE_DTS := ipq5332-sonicfi-rap7110c-341x | ||||||
|   | |||||||
| @@ -100,7 +100,6 @@ endif | |||||||
| ifdef CONFIG_TARGET_PROFILE | ifdef CONFIG_TARGET_PROFILE | ||||||
| TARGET_PROFILE=$(subst ",,$(CONFIG_TARGET_PROFILE)) | TARGET_PROFILE=$(subst ",,$(CONFIG_TARGET_PROFILE)) | ||||||
| PATCH_PROFILE_NAME=patches-$(subst DEVICE_,,$(TARGET_PROFILE)) | PATCH_PROFILE_NAME=patches-$(subst DEVICE_,,$(TARGET_PROFILE)) | ||||||
| FILES_PROFILE_NAME=files-$(subst DEVICE_,,$(TARGET_PROFILE)) |  | ||||||
| endif | endif | ||||||
|  |  | ||||||
| QCASSDK_CONFIG_OPTS+= TOOL_PATH=$(TOOLCHAIN_BIN_PATH) \ | QCASSDK_CONFIG_OPTS+= TOOL_PATH=$(TOOLCHAIN_BIN_PATH) \ | ||||||
| @@ -203,15 +202,6 @@ define patch_profile | |||||||
| 	$(call PatchDir/Default,$(PKG_BUILD_DIR),./$(PATCH_PROFILE_NAME)) | 	$(call PatchDir/Default,$(PKG_BUILD_DIR),./$(PATCH_PROFILE_NAME)) | ||||||
| endef | endef | ||||||
|  |  | ||||||
| define files_profile |  | ||||||
|  |  | ||||||
| 	if [ -d "./$(FILES_PROFILE_NAME)" ]; then \ |  | ||||||
| 		$(CP) ./$(FILES_PROFILE_NAME)/* ./files/ ; \ |  | ||||||
| 	fi |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| Hooks/Prepare/Post += patch_profile | Hooks/Prepare/Post += patch_profile | ||||||
| Hooks/Prepare/Post += files_profile |  | ||||||
|  |  | ||||||
| $(eval $(call KernelPackage,qca-ssdk-qca-nohnat)) | $(eval $(call KernelPackage,qca-ssdk-qca-nohnat)) | ||||||
| $(eval $(call KernelPackage,qca-ssdk-qca-hnat)) | $(eval $(call KernelPackage,qca-ssdk-qca-hnat)) | ||||||
|   | |||||||
| @@ -1,317 +0,0 @@ | |||||||
| #!/bin/sh /etc/rc.common |  | ||||||
| # Copyright (c) 2018, 2021, The Linux Foundation. All rights reserved. |  | ||||||
| # Copyright (c) 2022-2024, Qualcomm Innovation Center, Inc. All rights reserved. |  | ||||||
| # |  | ||||||
| # Permission to use, copy, modify, and/or distribute this software for any |  | ||||||
| # purpose with or without fee is hereby granted, provided that the above |  | ||||||
| # copyright notice and this permission notice appear in all copies. |  | ||||||
| # |  | ||||||
| # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |  | ||||||
| # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |  | ||||||
| # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |  | ||||||
| # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |  | ||||||
| # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |  | ||||||
| # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |  | ||||||
| # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |  | ||||||
| # |  | ||||||
|  |  | ||||||
| START=16 |  | ||||||
|  |  | ||||||
| #!/bin/sh |  | ||||||
| ruletype="ip4 ip6" |  | ||||||
| side="wan lan" |  | ||||||
| qwan="1 3 2 0 5 7 6 4" |  | ||||||
| qlan="0 1 2 3 4 5 6 7" |  | ||||||
|  |  | ||||||
| function create_war_acl_rules(){ |  | ||||||
| 	for lw in $side |  | ||||||
| 	do |  | ||||||
| 		#echo $lw |  | ||||||
| 		if [ "$lw" == "wan" ];then |  | ||||||
| 			listid=254 |  | ||||||
| 			queue=$qwan |  | ||||||
| 			portmap=0x20 |  | ||||||
| 		else |  | ||||||
| 			listid=255 |  | ||||||
| 			queue=$qlan |  | ||||||
| 			portmap=0x1e |  | ||||||
| 		fi |  | ||||||
| 		#echo $queue |  | ||||||
| 		#echo "creating list $listid" |  | ||||||
| 		ssdk_sh acl list create $listid 255 |  | ||||||
| 		ruleid=0 |  | ||||||
| 		for rt in $ruletype |  | ||||||
| 		do |  | ||||||
| 			for qid in $queue |  | ||||||
| 			do |  | ||||||
| 				cmd="ssdk_sh acl rule add $listid $ruleid  1 n 0 0" |  | ||||||
| 				#echo $cmd |  | ||||||
| 				if [ "$rt" == "ip4" ];then |  | ||||||
| 					cmd="$cmd ip4 n n n n n n n n n n n n n n n n n n n n n n n n n n n n n" |  | ||||||
| 					#echo $cmd |  | ||||||
| 				else |  | ||||||
| 					cmd="$cmd ip6 n n n n n n n n n n n n n n n n n n n n n n n n n n n n n n n" |  | ||||||
| 					#echo $cmd |  | ||||||
| 				fi |  | ||||||
| 				if [ $ruleid -le 3 ];then |  | ||||||
| 					#non-zero dscp |  | ||||||
| 					cmd="$cmd y 0x0 0xff" |  | ||||||
| 				elif [ $ruleid -le 7 ];then |  | ||||||
| 					#zero dscp |  | ||||||
| 					cmd="$cmd n" |  | ||||||
| 				elif [ $ruleid -le 11 ];then |  | ||||||
| 					#non-zero dscp |  | ||||||
| 					cmd="$cmd y 0x0 0xff" |  | ||||||
| 				else |  | ||||||
| 					#zero dscp |  | ||||||
| 					cmd="$cmd n" |  | ||||||
| 				fi |  | ||||||
| 				p=$((ruleid/2)) |  | ||||||
| 				cmd="$cmd y mask $((ruleid%2)) 0x1 y mask $((p%2)) 0x1 n n n n n n n n n n n n n n n y n n n n n n n y $qid n n 0 0 n n n n n n n n n n n n n n n n n n n n 0" |  | ||||||
| 				#echo $cmd |  | ||||||
| 				$cmd |  | ||||||
| 				ruleid=`expr $ruleid + 1` |  | ||||||
| 			done |  | ||||||
| 		done |  | ||||||
| 		ssdk_sh acl list bind $listid 0 1 $portmap |  | ||||||
| 	done |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function create_war_cosmap(){ |  | ||||||
| 	ssdk_sh cosmap pri2q set 0 0 |  | ||||||
| 	ssdk_sh cosmap pri2q set 1 0 |  | ||||||
| 	ssdk_sh cosmap pri2q set 2 0 |  | ||||||
| 	ssdk_sh cosmap pri2q set 3 0 |  | ||||||
| 	ssdk_sh cosmap pri2q set 4 1 |  | ||||||
| 	ssdk_sh cosmap pri2q set 5 1 |  | ||||||
| 	ssdk_sh cosmap pri2q set 6 1 |  | ||||||
| 	ssdk_sh cosmap pri2q set 7 1 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 0 0 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 1 0 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 2 0 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 3 0 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 4 1 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 5 1 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 6 1 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 7 1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function create_acl_byp_egstp_rules(){ |  | ||||||
| 	chip_ver=$1 |  | ||||||
| 	cmd="ssdk_sh servcode config set 1 n 0 0xfffefc7f 0xffbdff 0 0 0 0 0 0" |  | ||||||
| 	if [ "$chip_ver" == "0x2000" ] || [ "$chip_ver" = "0x2001" ] || [ "$chip_ver" = "0x2100" ]; then |  | ||||||
| 		cmd="$cmd 0" |  | ||||||
| 	fi |  | ||||||
| 	#echo $cmd |  | ||||||
| 	$cmd |  | ||||||
|  |  | ||||||
| 	ssdk_sh acl list create 56 48 |  | ||||||
| 	#action bypass eg stp check |  | ||||||
| 	action="y n n n n n n n n n n 0 0 n n n n n n n n n n n n n y n n n n n n n n n n n n y n n n n n n n n n n n n n n n n n n" |  | ||||||
| 	if [ "$chip_ver" == "0x2000" ]; then |  | ||||||
| 		action="$action n n 0" |  | ||||||
| 	elif [ "$chip_ver" = "0x2001" ] || [ "$chip_ver" = "0x2100" ]; then |  | ||||||
| 		action="$action n n n 0" |  | ||||||
| 	else |  | ||||||
| 		action="$action 0" |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	for ruleid in $( seq 0 2 ) |  | ||||||
| 	do |  | ||||||
| 		if [ "$ruleid" == "0" ];then |  | ||||||
| 			cmd="ssdk_sh acl rule add 56 0 1 n 0 0 mac n n n n n y 01-80-c2-00-00-00 ff-ff-ff-ff-ff-ff n n n n n n n n n n n n n n n n n n n n n n n" |  | ||||||
| 		elif [ "$ruleid" == "1" ];then |  | ||||||
| 			cmd="ssdk_sh acl rule add 56 1 1 n 0 0 mac n n n n n n n yes 0x8809 0xffff n n n n n n n n n n n n n n n n n n n n n" |  | ||||||
| 		else |  | ||||||
| 			cmd="ssdk_sh acl rule add 56 2 1 n 0 0 mac n n n n n n n yes 0x888e 0xffff n n n n n n n n n n n n n n n n n n n n n" |  | ||||||
| 		fi |  | ||||||
| 		if [ "$chip_ver" == "0x2000" ] || [ "$chip_ver" = "0x2001" ] || [ "$chip_ver" = "0x2100" ]; then |  | ||||||
| 			cmd="$cmd n $action" |  | ||||||
| 		else |  | ||||||
| 			cmd="$cmd $action" |  | ||||||
| 		fi |  | ||||||
| 		#echo $cmd |  | ||||||
| 		$cmd |  | ||||||
| 	done |  | ||||||
| 	ssdk_sh acl list bind 56 0 2 1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function delete_war_acl_rules(){ |  | ||||||
| 	for lw in $side |  | ||||||
| 	do |  | ||||||
| 		#echo $lw |  | ||||||
| 		if [ "$lw" == "wan" ];then |  | ||||||
| 			listid=254 |  | ||||||
| 			queue=$qwan |  | ||||||
| 			portmap=0x20 |  | ||||||
| 		else |  | ||||||
| 			listid=255 |  | ||||||
| 			queue=$qlan |  | ||||||
| 			portmap=0x1e |  | ||||||
| 		fi |  | ||||||
| 		ssdk_sh acl list unbind $listid 0 1 $portmap |  | ||||||
| 		for rt in $ruletype |  | ||||||
| 		do |  | ||||||
| 			for qid in $queue |  | ||||||
| 			do |  | ||||||
| 				cmd="ssdk_sh acl rule del $listid 0 1" |  | ||||||
| 				echo $cmd |  | ||||||
| 				$cmd |  | ||||||
| 			done |  | ||||||
| 		done |  | ||||||
| 		#echo "deleting list $listid" |  | ||||||
| 		ssdk_sh acl list destroy $listid |  | ||||||
| 	done |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function delete_war_cosmap(){ |  | ||||||
| 	ssdk_sh cosmap pri2q set 0 0 |  | ||||||
| 	ssdk_sh cosmap pri2q set 1 0 |  | ||||||
| 	ssdk_sh cosmap pri2q set 2 1 |  | ||||||
| 	ssdk_sh cosmap pri2q set 3 1 |  | ||||||
| 	ssdk_sh cosmap pri2q set 4 2 |  | ||||||
| 	ssdk_sh cosmap pri2q set 5 2 |  | ||||||
| 	ssdk_sh cosmap pri2q set 6 3 |  | ||||||
| 	ssdk_sh cosmap pri2q set 7 3 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 0 1 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 1 0 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 2 2 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 3 2 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 4 3 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 5 3 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 6 4 |  | ||||||
| 	ssdk_sh cosmap pri2ehq set 7 5 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function delete_acl_byp_egstp_rules(){ |  | ||||||
| 	chip_ver=$1 |  | ||||||
| 	cmd="ssdk_sh servcode config set 1 n 0 0xfffefcff 0xffbfff 0 0 0 0 0 0" |  | ||||||
| 	if [ "$chip_ver" == "0x2000" ] || [ "$chip_ver" = "0x2001" ] || [ "$chip_ver" = "0x2100" ]; then |  | ||||||
| 		cmd="$cmd 0" |  | ||||||
| 	fi |  | ||||||
| 	#echo $cmd |  | ||||||
| 	$cmd |  | ||||||
| 	ssdk_sh acl list unbind 56 0 2 1 |  | ||||||
| 	ssdk_sh acl rule del 56 0 1 |  | ||||||
| 	ssdk_sh acl rule del 56 1 1 |  | ||||||
| 	ssdk_sh acl rule del 56 2 1 |  | ||||||
| 	ssdk_sh acl list destroy 56 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function edma_war_config_add(){ |  | ||||||
| 	create_war_cosmap |  | ||||||
| 	ssdk_sh acl status set enable |  | ||||||
| 	create_war_acl_rules |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function edma_war_config_del(){ |  | ||||||
| 	delete_war_acl_rules |  | ||||||
| 	delete_war_cosmap |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function ipq50xx_serdes_monitor () { |  | ||||||
| 	#if qca808x phy exist, need to monitor the serdes to avoid the effect for WIFI |  | ||||||
| 	port_id=2 |  | ||||||
| 	old_linkstatus="DISABLE" |  | ||||||
| 	phy_id_info=`ssdk_sh port phyid get $port_id | grep Org | awk -F '!' '{print $2}'` |  | ||||||
| 	if [ "$phy_id_info" = "[Org ID]:0x004d[Rev ID]:0xd101" ]; then |  | ||||||
| 		ssdk_sh debug phy set 29 0xb 0x300d |  | ||||||
| 		ssdk_sh debug uniphy set 0 0x7ac 0x300d 4 |  | ||||||
|  |  | ||||||
| 		while true |  | ||||||
| 		do |  | ||||||
| 			cur_linkstatus=`ssdk_sh port linkstatus get $port_id | grep Status | awk -F ':' '{print $2}'` |  | ||||||
| 			#when qca808x phy link status is from down to up, serdes tx would be enabled |  | ||||||
| 			if [ "$cur_linkstatus" = "ENABLE" ] && [ "$old_linkstatus" = "DISABLE" ]; then |  | ||||||
| 				ssdk_sh debug phy set 29 0xb 0xb00d |  | ||||||
| 				ssdk_sh debug uniphy set 0 0x7ac 0xb00d 4 |  | ||||||
| 			fi |  | ||||||
| 			#when qca808x phy link status is from up to down, serdes tx would be disabled |  | ||||||
| 			if [ "$cur_linkstatus" = "DISABLE" ] && [ "$old_linkstatus" = "ENABLE" ]; then |  | ||||||
| 				ssdk_sh debug phy set 29 0xb 0x300d |  | ||||||
| 				ssdk_sh debug uniphy set 0 0x7ac 0x300d 4 |  | ||||||
| 			fi |  | ||||||
| 			old_linkstatus=$cur_linkstatus |  | ||||||
| 		done |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function ipq53xx_phy_amplitude_set () { |  | ||||||
| 	#for qca808x phy sgmii, set half amplitude with src_half_swing register |  | ||||||
| 	port_id=2 |  | ||||||
| 	phy_id_info=`ssdk_sh port phyid get $port_id | grep Org | awk -F '!' '{print $2}'` |  | ||||||
| 	if [ "$phy_id_info" = "[Org ID]:0x004d[Rev ID]:0xd180" ]; then |  | ||||||
| 		ssdk_sh debug phy set 5 0x40010087 0x208a |  | ||||||
| 		ssdk_sh debug phy set 6 0x40010087 0x208a |  | ||||||
| 		#Set the Reg0x67 bits[7:5]=3’b000 and bit4=1’b1 |  | ||||||
| 		ampl_val=$(eval "ssdk_sh debug phy get 5 0x40010067 | grep SSDK | grep -oE '0x[0-9a-fA-F]+' | sed 's/\(0x..\)./\11/'") |  | ||||||
| 		ssdk_sh debug phy set 5 0x40010067 $ampl_val |  | ||||||
| 		ampl_val=$(eval "ssdk_sh debug phy get 6 0x40010067 | grep SSDK | grep -oE '0x[0-9a-fA-F]+' | sed 's/\(0x..\)./\11/'") |  | ||||||
| 		ssdk_sh debug phy set 6 0x40010067 $ampl_val |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function ipq53xx_uniphy_amplitude_set () { |  | ||||||
| 	#for ipq50xx sgmii, set half amplitude with tx_emp_lvl/margin_index and tx_margin |  | ||||||
| 	ssdk_sh debug uniphy set 0 0x7ac 0xb10d 4 |  | ||||||
| 	ssdk_sh debug uniphy set 0 0x24 0 4 |  | ||||||
| 	ssdk_sh debug uniphy set 1 0x7ac 0xb10d 4 |  | ||||||
| 	ssdk_sh debug uniphy set 1 0x24 0 4 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ssdk_dependency() { |  | ||||||
| 	counter=0 |  | ||||||
| 	[ -e /lib/modules/$(uname -r)/qca-ssdk.ko ] && [ ! -d /sys/module/qca_ssdk ] && { |  | ||||||
| 		insmod qca-ssdk.ko |  | ||||||
| 	} |  | ||||||
| 	while [ ! -d /sys/ssdk ] && [ "$counter" -le 5 ] |  | ||||||
| 	do |  | ||||||
| 		sleep 1 |  | ||||||
| 		counter=$((counter+1)) |  | ||||||
| 	done |  | ||||||
| } |  | ||||||
|  |  | ||||||
| start() { |  | ||||||
| 	ssdk_dependency |  | ||||||
| 	chip_ver=`ssdk_sh debug reg get 0 4 | grep Data | tr -d 'SSDK Init OK![Data]:'` |  | ||||||
| 	#The following commands should be uncommented to enable EDMA WAR |  | ||||||
| 	if [ "$chip_ver" = "0x1401" ]; then |  | ||||||
| 		#edma_war_config_add |  | ||||||
| 		echo '' |  | ||||||
| 	fi |  | ||||||
| 	#The following commands should be uncommented to add acl egress stp bypass rules |  | ||||||
| 	if [ "$chip_ver" = "0x1500" ] || [ "$chip_ver" = "0x1501" ] || [ "$chip_ver" = "0x2000" ] || [ "$chip_ver" = "0x2001" ] || [ "$chip_ver" = "0x2100" ]; then |  | ||||||
| 		#create_acl_byp_egstp_rules $chip_ver |  | ||||||
| 		echo '' |  | ||||||
| 	fi |  | ||||||
| 	#The following commands should be uncommented to enable WAR for ipq50xx |  | ||||||
| 	chip_type_info=`cat tmp/sysinfo/model` |  | ||||||
| 	result=$(echo $chip_type_info | grep "IPQ5018") |  | ||||||
| 	if [ "$result" != "" ]; then |  | ||||||
| 		#ipq50xx_serdes_monitor & |  | ||||||
| 		#ipq50xx_uniphy_amplitude_set |  | ||||||
| 		#ipq50xx_phy_amplitude_set |  | ||||||
| 		echo '' |  | ||||||
| 	fi |  | ||||||
| 	if [ "$chip_ver" = "0x2001" ]; then |  | ||||||
| 		ipq53xx_uniphy_amplitude_set |  | ||||||
| 		ipq53xx_phy_amplitude_set |  | ||||||
| 		echo '' |  | ||||||
| 	fi |  | ||||||
| 	echo starting |  | ||||||
| } |  | ||||||
|  |  | ||||||
| stop() { |  | ||||||
| 	chip_ver=`ssdk_sh debug reg get 0 4 | grep Data | tr -d 'SSDK Init OK![Data]:'` |  | ||||||
| 	#The following commands should be uncommented to disable EDMA WAR |  | ||||||
| 	if [ "$chip_ver" = "0x1401" ]; then |  | ||||||
| 		#edma_war_config_del |  | ||||||
| 		echo '' |  | ||||||
| 	fi |  | ||||||
| 	#The following commands should be uncommented to delete acl egress stp bypass rules |  | ||||||
| 	if [ "$chip_ver" = "0x1500" ] || [ "$chip_ver" = "0x1501" ] || [ "$chip_ver" = "0x2000" ] || [ "$chip_ver" = "0x2001" ] || [ "$chip_ver" = "0x2100" ]; then |  | ||||||
| 		#delete_acl_byp_egstp_rules $chip_ver |  | ||||||
| 		echo '' |  | ||||||
| 	fi |  | ||||||
| 	echo stoping |  | ||||||
| } |  | ||||||
| @@ -20,7 +20,6 @@ copy_certificates() { | |||||||
| 	[ -z "$country" ] && country=US | 	[ -z "$country" ] && country=US | ||||||
| 	echo "options cfg80211 ieee80211_regdom="$country > /etc/modules.conf  | 	echo "options cfg80211 ieee80211_regdom="$country > /etc/modules.conf  | ||||||
| 	echo -n $country > /etc/ucentral/country | 	echo -n $country > /etc/ucentral/country | ||||||
| 	sync |  | ||||||
| 	exit 0 | 	exit 0 | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -6,16 +6,13 @@ check_certificates() { | |||||||
|  |  | ||||||
| check_certificates | check_certificates | ||||||
|  |  | ||||||
| tar_part_lookup() { | bootconfig_lookup() { | ||||||
| 	part="$(fw_printenv -n cert_part)" | 	case "$(fw_printenv -n cert_part)" in | ||||||
| 	if [ "$part" -eq 0 ]; then | 	0)	echo "0:BOOTCONFIG" | ||||||
| 		echo "$2" | 		;; | ||||||
| 		part=1 | 	1)	echo "0:BOOTCONFIG1" | ||||||
| 	else | 		;; | ||||||
| 		echo "$1" | 	esac | ||||||
| 		part=0 |  | ||||||
| 	fi |  | ||||||
| 	fw_setenv cert_part $part |  | ||||||
| } | } | ||||||
|  |  | ||||||
| . /lib/functions.sh | . /lib/functions.sh | ||||||
| @@ -38,40 +35,13 @@ sonicfi,rap7*) | |||||||
| 		[ -n "$mtd" ] && mount -t ext4 /dev/mtdblock$mtd /certificates | 		[ -n "$mtd" ] && mount -t ext4 /dev/mtdblock$mtd /certificates | ||||||
| 	fi | 	fi | ||||||
| 	if [ ! -f /certificates/cert.pem ] || [ ! -f /certificates/key.pem ]; then | 	if [ ! -f /certificates/cert.pem ] || [ ! -f /certificates/key.pem ]; then | ||||||
| 		part=$(tar_part_lookup "0:BOOTCONFIG" "0:BOOTCONFIG1") | 		bootconfig=$(bootconfig_lookup) | ||||||
| 		if [ -n "part" ]; then | 		if [ -n "$bootconfig" ]; then | ||||||
| 			mmc_dev=$(echo $(find_mmc_part "$part") | sed 's/^.\{5\}//') | 			mmc_dev=$(echo $(find_mmc_part "$bootconfig") | sed 's/^.\{5\}//') | ||||||
| 			[ -n "$mmc_dev" ] && tar xf /dev/$mmc_dev -C /certificates | 			[ -n "$mmc_dev" ] && tar xf /dev/$mmc_dev -C /certificates | ||||||
| 		fi | 		fi | ||||||
| 	fi | 	fi | ||||||
| 	;; | 	;; | ||||||
| udaya,a5-id2|\ |  | ||||||
| yuncore,ax820) |  | ||||||
| 	mtd=$(find_mtd_index certificates) |  | ||||||
| 	if [ "$(head -c 4 /dev/mtd$mtd)" == "hsqs" ]; then |  | ||||||
| 		mount -t squashfs /dev/mtdblock$mtd /mnt |  | ||||||
| 		cp /mnt/* /certificates |  | ||||||
| 		umount /mnt |  | ||||||
| 	fi |  | ||||||
| 	part=$(tar_part_lookup "insta1" "insta2") |  | ||||||
| 	if [ -n "insta" ]; then |  | ||||||
| 		mtd=$(find_mtd_index $part) |  | ||||||
| 		[ -n "$mtd" ] && tar xf /dev/mtdblock$mtd -C /certificates |  | ||||||
| 	fi |  | ||||||
| 	;; |  | ||||||
| sonicfi,rap6*) |  | ||||||
| 	mtd=$(find_mtd_index certificates) |  | ||||||
| 	if [ "$(head -c 4 /dev/mtd$mtd)" == "hsqs" ]; then |  | ||||||
| 		mount -t squashfs /dev/mtdblock$mtd /mnt |  | ||||||
| 		cp /mnt/* /certificates |  | ||||||
| 		umount /mnt |  | ||||||
| 	fi |  | ||||||
| 	part=$(tar_part_lookup "devinfo" "certificates") |  | ||||||
| 	if [ -n "$part" ]; then |  | ||||||
| 		mtd=$(find_mtd_index $part) |  | ||||||
| 		[ -n "$mtd" ] && tar xf /dev/mtdblock$mtd -C /certificates |  | ||||||
| 	fi |  | ||||||
| 	;; |  | ||||||
| *) | *) | ||||||
| 	mtd=$(find_mtd_index certificates) | 	mtd=$(find_mtd_index certificates) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,44 +1,25 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
|  |  | ||||||
| tar_part_lookup() { | bootconfig_lookup() { | ||||||
| 	part="$(fw_printenv -n cert_part)" | 	bootconfig="$(fw_printenv -n cert_part)" | ||||||
| 	if [ "$part" -eq 0 ]; then | 	case "$(fw_printenv -n cert_part)" in | ||||||
| 		echo "$2" | 	0)	echo "0:BOOTCONFIG1" | ||||||
| 		part=1 | 		bootconfig=1 | ||||||
| 	else | 		;; | ||||||
| 		echo "$1" | 	*)	echo "0:BOOTCONFIG" | ||||||
| 		part=0 | 		bootconfig=0 | ||||||
| 	fi | 		;; | ||||||
| 	fw_setenv cert_part $part | 	esac | ||||||
|  | 	fw_setenv cert_part $bootconfig | ||||||
| } | } | ||||||
|  |  | ||||||
| . /lib/functions.sh | . /lib/functions.sh | ||||||
| case "$(board_name)" in | case "$(board_name)" in | ||||||
| sonicfi,rap7110c-341x) | sonicfi,rap7110c-341x) | ||||||
| 	cd /certificates | 	cd /certificates | ||||||
| 	tar cf /tmp/certs.tar . | 	tar cf /tmp/certs.tar | ||||||
| 	part=$(tar_part_lookup "0:BOOTCONFIG" "0:BOOTCONFIG1") | 	bootconfig=$(bootconfig_lookup) | ||||||
| 	mmc_dev=$(echo $(find_mmc_part $part) | sed 's/^.\{5\}//') | 	mmc_dev=$(echo $(find_mmc_part $bootconfig) | sed 's/^.\{5\}//') | ||||||
| 	dd if=/tmp/certs.tar of=/dev/$mmc_dev | 	dd if=/tmp/certs.tar of=/dev/$bootconfig | ||||||
| 	;; |  | ||||||
| udaya,a5-id2|\ |  | ||||||
| yuncore,ax820) |  | ||||||
| 	cd /certificates |  | ||||||
| 	tar cf /tmp/certs.tar . |  | ||||||
| 	part=$(tar_part_lookup "insta1" "insta2") |  | ||||||
| 	mtd=$(find_mtd_index $part) |  | ||||||
| 	dd if=/tmp/certs.tar of=/dev/mtdblock$mtd |  | ||||||
| 	;; |  | ||||||
| sonicfi,rap6*) |  | ||||||
| 	if [ "$(fw_printenv -n store_certs_disabled)" != "1" ]; then |  | ||||||
| 		cd /certificates |  | ||||||
| 		tar cf /tmp/certs.tar . |  | ||||||
| 		part=$(tar_part_lookup "devinfo" "certificates") |  | ||||||
| 		mtd=$(find_mtd_index $part) |  | ||||||
| 		block_size=$(cat /sys/class/mtd/mtd$mtd/size) |  | ||||||
| 		dd if=/tmp/certs.tar of=/tmp/certs_pad.tar bs=$block_size conv=sync |  | ||||||
| 		mtd write /tmp/certs_pad.tar /dev/mtd$mtd |  | ||||||
| 		rm -f /tmp/certs.tar /tmp/certs_pad.tar |  | ||||||
| 	fi |  | ||||||
| 	;; | 	;; | ||||||
| esac | esac | ||||||
|   | |||||||
| @@ -22,19 +22,6 @@ start_service() { | |||||||
| 	[ "$valid" == "true" ] ||  | 	[ "$valid" == "true" ] ||  | ||||||
| 		/usr/share/ucentral/ucentral.uc /etc/ucentral/ucentral.cfg.0000000001 > /dev/null | 		/usr/share/ucentral/ucentral.uc /etc/ucentral/ucentral.cfg.0000000001 > /dev/null | ||||||
|  |  | ||||||
| 	est_client check |  | ||||||
| 	[ $? -eq 1 ] && { |  | ||||||
| 		logger ERROR |  | ||||||
| 		logger ERROR |  | ||||||
| 		logger ERROR |  | ||||||
| 		logger The certificate used has a CN that does not match the serial of the device |  | ||||||
| 		echo The certificate used has a CN that does not match the serial of the device |  | ||||||
| 		logger ERROR |  | ||||||
| 		logger ERROR |  | ||||||
| 		logger ERROR |  | ||||||
| 		return |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	procd_open_instance | 	procd_open_instance | ||||||
| 	procd_set_param command "$PROG" | 	procd_set_param command "$PROG" | ||||||
| 	procd_set_param respawn | 	procd_set_param respawn | ||||||
|   | |||||||
| @@ -27,8 +27,6 @@ let timeouts = { | |||||||
| 	'validate': 120, | 	'validate': 120, | ||||||
| 	'orphan': 2 * 60 * 60, | 	'orphan': 2 * 60 * 60, | ||||||
| 	interval: 10000, | 	interval: 10000, | ||||||
| 	expiry_interval: 60 * 60 * 1000, |  | ||||||
| 	expiry_threshold: 3 * 24 * 60 * 60, |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| ulog_open(ULOG_SYSLOG | ULOG_STDIO, LOG_DAEMON, "cloud_discover"); | ulog_open(ULOG_SYSLOG | ULOG_STDIO, LOG_DAEMON, "cloud_discover"); | ||||||
| @@ -93,7 +91,6 @@ function gateway_write(data) { | |||||||
| 	} | 	} | ||||||
| 	if (changed) | 	if (changed) | ||||||
| 		fs.writefile('/etc/ucentral/gateway.json', new); | 		fs.writefile('/etc/ucentral/gateway.json', new); | ||||||
| 		system('sync'); |  | ||||||
| 	return changed; | 	return changed; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -331,27 +328,6 @@ let ubus_methods = { | |||||||
| 	}, | 	}, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| function expiry_handler() { |  | ||||||
| 	let stat = fs.stat('/etc/ucentral/operational.ca'); |  | ||||||
| 	if (!stat) |  | ||||||
| 		return; |  | ||||||
|  |  | ||||||
| 	let ret = system(`openssl x509 -checkend ${timeouts.expiry_threshold} -noout -in /certificates/operational.pem`); |  | ||||||
| 	if (!ret) { |  | ||||||
| 		ulog(LOG_INFO, 'checked certificate expiry - all ok\n'); |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	ulog(LOG_INFO, 'certificate will expire soon\n'); |  | ||||||
| 	if (system('/usr/bin/est_client reenroll')) { |  | ||||||
| 		ulog(LOG_INFO, 'reenroll failed\n'); |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
| 	ulog(LOG_INFO, 'reenroll succeeded\n'); |  | ||||||
| 	ulog(LOG_INFO, '(re)starting client\n'); |  | ||||||
| 	system('/etc/init.d/ucentral restart'); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| if (gateway_available()) { | if (gateway_available()) { | ||||||
| 	let status = ubus.call('ucentral', 'status'); | 	let status = ubus.call('ucentral', 'status'); | ||||||
| 	ulog(LOG_INFO, 'cloud is known\n'); | 	ulog(LOG_INFO, 'cloud is known\n'); | ||||||
| @@ -368,7 +344,6 @@ if (gateway_available()) { | |||||||
| timeouts_load(); | timeouts_load(); | ||||||
|  |  | ||||||
| interval = uloop.interval(timeouts.interval, interval_handler); | interval = uloop.interval(timeouts.interval, interval_handler); | ||||||
| uloop.interval(timeouts.expiry_interval, expiry_handler); |  | ||||||
|  |  | ||||||
| ubus.publish('cloud', ubus_methods); | ubus.publish('cloud', ubus_methods); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,7 +4,6 @@ | |||||||
|  |  | ||||||
| import { ulog_open, ulog, ULOG_SYSLOG, ULOG_STDIO, LOG_DAEMON, LOG_INFO } from 'log'; | import { ulog_open, ulog, ULOG_SYSLOG, ULOG_STDIO, LOG_DAEMON, LOG_INFO } from 'log'; | ||||||
| import * as fs from 'fs'; | import * as fs from 'fs'; | ||||||
| import * as libuci from 'uci'; |  | ||||||
|  |  | ||||||
| let store_operational_pem = false; | let store_operational_pem = false; | ||||||
| let store_operational_ca = false; | let store_operational_ca = false; | ||||||
| @@ -140,9 +139,6 @@ function load_operational_ca() { | |||||||
| } | } | ||||||
|  |  | ||||||
| function fwtool() { | function fwtool() { | ||||||
| 	if (!fs.stat('/etc/ucentral/cert.pem')) |  | ||||||
| 		return 0; |  | ||||||
|  |  | ||||||
| 	let pipe = fs.popen(`openssl x509 -in /etc/ucentral/cert.pem -noout -issuer`); | 	let pipe = fs.popen(`openssl x509 -in /etc/ucentral/cert.pem -noout -issuer`); | ||||||
| 	let issuer = pipe.read("all"); | 	let issuer = pipe.read("all"); | ||||||
| 	pipe.close(); | 	pipe.close(); | ||||||
| @@ -167,20 +163,6 @@ function fwtool() { | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| function check_cert() { |  | ||||||
| 	if (!fs.stat('/etc/ucentral/cert.pem')) |  | ||||||
| 		return 0; |  | ||||||
| 	let pipe = fs.popen("openssl x509 -in /etc/ucentral/cert.pem  -noout -subject -nameopt multiline | grep commonName | awk '{ print $3 }'"); |  | ||||||
| 	let cn = pipe.read("all"); |  | ||||||
| 	pipe.close(); |  | ||||||
| 	if (!cn) |  | ||||||
| 		return 0; |  | ||||||
| 	cn = lc(trim(cn)); |  | ||||||
| 	let uci = libuci.cursor(); |  | ||||||
| 	let serial = uci.get('ucentral', 'config', 'serial'); |  | ||||||
| 	return cn != serial; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| switch(ARGV[0]) { | switch(ARGV[0]) { | ||||||
| case 'enroll': | case 'enroll': | ||||||
| 	let ret = simpleenroll(); | 	let ret = simpleenroll(); | ||||||
| @@ -202,7 +184,4 @@ case 'reenroll': | |||||||
|  |  | ||||||
| case 'fwtool': | case 'fwtool': | ||||||
| 	exit(fwtool()); | 	exit(fwtool()); | ||||||
|  |  | ||||||
| case 'check': |  | ||||||
| 	exit(check_cert()); |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -350,7 +350,7 @@ function run_service() { | |||||||
| 				printf('-> reload\n'); | 				printf('-> reload\n'); | ||||||
| 				let list = uctx.list(); | 				let list = uctx.list(); | ||||||
| 				for (let obj in list) { | 				for (let obj in list) { | ||||||
| 					if (!wildcard(obj, 'hostapd.wlan*') && !wildcard(obj, 'hostapd.phy*')) | 					if (!wildcard(obj, 'hostapd.wlan*')) | ||||||
| 						continue; | 						continue; | ||||||
| 					let iface = split(obj, '.')[1]; | 					let iface = split(obj, '.')[1]; | ||||||
| 					let device = get_device(devices, req.args.device); | 					let device = get_device(devices, req.args.device); | ||||||
|   | |||||||
| @@ -6,8 +6,6 @@ STOP=01 | |||||||
| USE_PROCD=1 | USE_PROCD=1 | ||||||
|  |  | ||||||
| start_service() { | start_service() { | ||||||
| 	[ -e "/tmp/rrm_timestamp" ] && rm -rf /tmp/rrm_timestamp |  | ||||||
| 	[ -e "/tmp/rrm_chan_switch" ] && rm -rf /tmp/rrm_chan_switch |  | ||||||
| 	rm -rf /tmp/threshold_breach_count* | 	rm -rf /tmp/threshold_breach_count* | ||||||
| 	rm -rf /tmp/fixed_channel* | 	rm -rf /tmp/fixed_channel* | ||||||
| 	rm -rf /tmp/chanutil_phy* | 	rm -rf /tmp/chanutil_phy* | ||||||
|   | |||||||
| @@ -24,10 +24,6 @@ function stats_info_write(path, value) { | |||||||
| 	file.close(); | 	file.close(); | ||||||
| } | } | ||||||
|  |  | ||||||
| function record_rrm_timestamp() { |  | ||||||
|     stats_info_write("/tmp/rrm_timestamp", time()); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // total number of radios: default=2 | // total number of radios: default=2 | ||||||
| let num_radios = 2; | let num_radios = 2; | ||||||
| let phy_count; | let phy_count; | ||||||
| @@ -140,122 +136,20 @@ function channel_to_freq(band, channel) { | |||||||
|     return freq; |     return freq; | ||||||
| } | } | ||||||
|  |  | ||||||
| // using mapping to get correct center channel, especially for 6G radio | function center_freq_calc(band, freq, bandwidth) { | ||||||
| function get_center_channel(channel, band, bw) { |     if (bandwidth == 40) | ||||||
|     let center_channel = channel; |         return +freq + 10; | ||||||
|     let center_channel_map = {}; |     if (bandwidth == 80) | ||||||
|  |         return +freq + 30; | ||||||
|  |     if (bandwidth == 160) | ||||||
|  |         return +freq + 70; | ||||||
|  |     if (bandwidth == 320) | ||||||
|  |         if (freq == 6115) | ||||||
|  |             return +freq - 10; | ||||||
|  |         else | ||||||
|  |             return +freq + 150; | ||||||
|  |  | ||||||
|     switch (band) { |     return +freq; | ||||||
|     case '5g': |  | ||||||
|         if (bw == 40) { |  | ||||||
|             center_channel_map = { |  | ||||||
|                 "36": 38, "40": 38, |  | ||||||
|                 "44": 46, "48": 46, |  | ||||||
|                 "52": 54, "56": 54, |  | ||||||
|                 "60": 62, "64": 62, |  | ||||||
|                 "100": 102, "104": 102, |  | ||||||
|                 "108": 110, "112": 110, |  | ||||||
|                 "116": 118, "120": 118, |  | ||||||
|                 "124": 126, "128": 126, |  | ||||||
|                 "132": 134, "136": 134, |  | ||||||
|                 "140": 142, "144": 142, |  | ||||||
|                 "149": 151, "153": 151, |  | ||||||
|                 "157": 159, "161": 159, |  | ||||||
|                 "165": 167 |  | ||||||
|             }; |  | ||||||
|         } else if (bw == 80) { |  | ||||||
|             center_channel_map = { |  | ||||||
|                 "36": 42, "40": 42, "44": 42, "48": 42, |  | ||||||
|                 "52": 58, "56": 58, "60": 58, "64": 58, |  | ||||||
|                 "100": 106, "104": 106, "108": 106, "112": 106, |  | ||||||
|                 "116": 122, "120": 122, "124": 122, "128": 122, |  | ||||||
|                 "132": 138, "136": 138, "140": 138, "144": 138, |  | ||||||
|                 "149": 155, "153": 155, "157": 155, "161": 155, |  | ||||||
|                 "165": 171 |  | ||||||
|             }; |  | ||||||
|         } else if (bw == 160) { |  | ||||||
|             center_channel_map = { |  | ||||||
|                 "36": 50, "40": 50, "44": 50, "48": 50, |  | ||||||
|                 "52": 50, "56": 50, "60": 50, "64": 50, |  | ||||||
|                 "100": 114, "104": 114, "108": 114, "112": 114, |  | ||||||
|                 "116": 114, "120": 114, "124": 114, "128": 114 |  | ||||||
|             }; |  | ||||||
|         } |  | ||||||
|         break; |  | ||||||
|     case '6g': |  | ||||||
|         if (bw == 40) { |  | ||||||
|             center_channel_map = { |  | ||||||
|                 "1": 3, "5": 3, "9": 11, "13": 11, |  | ||||||
|                 "17": 19, "21": 19, "25": 27, "29": 27, |  | ||||||
|                 "33": 35, "37": 35, "41": 43, "45": 43, |  | ||||||
|                 "49": 51, "53": 51, "57": 59, "61": 59, |  | ||||||
|                 "65": 67, "69": 67, "73": 75, "77": 75, |  | ||||||
|                 "81": 83, "85": 83, "89": 91, "93": 91, |  | ||||||
|                 "97": 99, "101": 99, "105": 107, "109": 107, |  | ||||||
|                 "113": 115, "117": 115, "121": 123, "125": 123, |  | ||||||
|                 "129": 131, "133": 131, "137": 139, "141": 139, |  | ||||||
|                 "145": 147, "149": 147, "153": 155, "157": 155, |  | ||||||
|                 "161": 163, "165": 163, "169": 171, "173": 171, |  | ||||||
|                 "177": 179, "181": 179, "185": 187, "189": 187, |  | ||||||
|                 "193": 195, "197": 195, "201": 203, "205": 203, |  | ||||||
|                 "209": 211, "213": 211, "217": 219, "221": 219, |  | ||||||
|                 "225": 227 |  | ||||||
|             }; |  | ||||||
|         } else if (bw == 80) { |  | ||||||
|             center_channel_map = { |  | ||||||
|                 "1": 7, "5": 7, "9": 7, "13": 7, |  | ||||||
|                 "17": 23, "21": 23, "25": 23, "29": 23, |  | ||||||
|                 "33": 39, "37": 39, "41": 39, "45": 39, |  | ||||||
|                 "49": 55, "53": 55, "57": 55, "61": 55, |  | ||||||
|                 "65": 71, "69": 71, "73": 71, "77": 71, |  | ||||||
|                 "81": 87, "85": 87, "89": 87, "93": 87, |  | ||||||
|                 "97": 103, "101": 103, "105": 103, "109": 103, |  | ||||||
|                 "113": 119, "117": 119, "121": 119, "125": 119, |  | ||||||
|                 "129": 135, "133": 135, "137": 135, "141": 135, |  | ||||||
|                 "145": 151, "149": 151, "153": 151, "157": 151, |  | ||||||
|                 "161": 167, "165": 167, "169": 167, "173": 167, |  | ||||||
|                 "177": 183, "181": 183, "185": 183, "189": 183, |  | ||||||
|                 "193": 199, "197": 199, "201": 199, "205": 199, |  | ||||||
|                 "209": 215 |  | ||||||
|             }; |  | ||||||
|         } else if (bw == 160) { |  | ||||||
|             center_channel_map = { |  | ||||||
|                 "1": 15, "5": 15, "9": 15, "13": 15, |  | ||||||
|                 "17": 15, "21": 15, "25": 15, "29": 15, |  | ||||||
|                 "33": 47, "37": 47, "41": 47, "45": 47, |  | ||||||
|                 "49": 47, "53": 47, "57": 47, "61": 47, |  | ||||||
|                 "65": 79, "69": 79, "73": 79, "77": 79, |  | ||||||
|                 "81": 79, "85": 79, "89": 79, "93": 79, |  | ||||||
|                 "97": 111, "101": 111, "105": 111, "109": 111, |  | ||||||
|                 "113": 111, "117": 111, "121": 111, "125": 111, |  | ||||||
|                 "129": 143, "133": 143, "137": 143, "141": 143, |  | ||||||
|                 "145": 143, "149": 143, "153": 143, "157": 143, |  | ||||||
|                 "161": 175, "165": 175, "169": 175, "173": 175, |  | ||||||
|                 "177": 175, "181": 175, "185": 175, "189": 175, |  | ||||||
|                 "193": 207 |  | ||||||
|             }; |  | ||||||
|         } else if (bw == 320) { |  | ||||||
|             center_channel_map = { |  | ||||||
|                 "1": 31, "5": 31, "9": 31, "13": 31, |  | ||||||
|                 "17": 31, "21": 31, "25": 31, "29": 31, |  | ||||||
|                 "33": 63, "37": 63, "41": 63, "45": 63, |  | ||||||
|                 "49": 63, "53": 63, "57": 63, "61": 63, |  | ||||||
|                 "65": 63, "69": 63, "73": 63, "77": 63, |  | ||||||
|                 "81": 63, "85": 63, "89": 63, "93": 63, |  | ||||||
|                 "97": 127, "101": 127, "105": 127, "109": 127, |  | ||||||
|                 "113": 127, "117": 127, "121": 127, "125": 127, |  | ||||||
|                 "129": 127, "133": 127, "137": 127, "141": 127, |  | ||||||
|                 "145": 127, "149": 127, "153": 127, "157": 127, |  | ||||||
|                 "161": 191 |  | ||||||
|             }; |  | ||||||
|         } |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (center_channel_map[channel]) |  | ||||||
|         center_channel = center_channel_map[channel]; |  | ||||||
|  |  | ||||||
|     return center_channel; |  | ||||||
| } | } | ||||||
|  |  | ||||||
| function interface_status_check(iface) { | function interface_status_check(iface) { | ||||||
| @@ -307,9 +201,6 @@ function check_current_channel(iface) { | |||||||
| function hostapd_switch_channel(msg) { | function hostapd_switch_channel(msg) { | ||||||
|     ulog_info(`[%s] Start switch channel to %d \n`, msg.iface, msg.channel); |     ulog_info(`[%s] Start switch channel to %d \n`, msg.iface, msg.channel); | ||||||
|  |  | ||||||
|     // Channel switch in progress, set flag = 1 |  | ||||||
|     stats_info_write("/tmp/rrm_chan_switch", 1); |  | ||||||
|  |  | ||||||
|     let chan_switch_status = 0; |     let chan_switch_status = 0; | ||||||
|     let sec_channel_offset = null; |     let sec_channel_offset = null; | ||||||
|  |  | ||||||
| @@ -317,8 +208,7 @@ function hostapd_switch_channel(msg) { | |||||||
|     let bandwidth = replace(msg.htmode, /[^0-9]/g, ''); |     let bandwidth = replace(msg.htmode, /[^0-9]/g, ''); | ||||||
|  |  | ||||||
|     let target_freq = channel_to_freq(msg.band, msg.channel); |     let target_freq = channel_to_freq(msg.band, msg.channel); | ||||||
|     let center_channel = get_center_channel(msg.channel, msg.band, bandwidth); |     let center_freq = center_freq_calc(msg.band, target_freq, bandwidth); | ||||||
|     let center_freq = channel_to_freq(msg.band, center_channel); |  | ||||||
|     if (bandwidth > 20) |     if (bandwidth > 20) | ||||||
|         sec_channel_offset = 1; |         sec_channel_offset = 1; | ||||||
|  |  | ||||||
| @@ -355,20 +245,9 @@ function switch_status_check(iface, dfs_enabled_5g_flag) { | |||||||
|         ulog_info(`[%s] 5G radio might need some time to be UP (DFS enabled) \n`, iface); |         ulog_info(`[%s] 5G radio might need some time to be UP (DFS enabled) \n`, iface); | ||||||
|  |  | ||||||
|         let p = 0; |         let p = 0; | ||||||
|         // Default max 70 seconds wait for the DFS enabled interface to be UP |         // Max 65 seconds wait for the DFS enabled interface to be UP | ||||||
|         let timer = 70; |         let timer = 70; | ||||||
|  |  | ||||||
|         // get real timer from hostapd_cli command |  | ||||||
|         let check_cac_time = sprintf('hostapd_cli -i %s status | grep \"cac_time_left_seconds\" | awk -F "=" \'{print $2}\'', iface); |  | ||||||
|         let _cac_time = fs.popen(check_cac_time); |  | ||||||
|         let cac_time = trim(_cac_time.read('all')); |  | ||||||
|         _cac_time.close(); |  | ||||||
|  |  | ||||||
|         // if cac_time is a valid number, set timer to cac_time + 5 seconds |  | ||||||
|         if (cac_time > 0 && match(cac_time, /^[0-9]+$/)) { |  | ||||||
|             timer = int(cac_time) + 5; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         while (p < timer) { |         while (p < timer) { | ||||||
|             ulog_info(`[%s] Check#%d \n `, iface, p); |             ulog_info(`[%s] Check#%d \n `, iface, p); | ||||||
|  |  | ||||||
| @@ -388,9 +267,6 @@ function switch_status_check(iface, dfs_enabled_5g_flag) { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // Channel switch done, set flag = 0 |  | ||||||
|     stats_info_write("/tmp/rrm_chan_switch", 0); |  | ||||||
|  |  | ||||||
|     let current_chan = check_current_channel(iface); |     let current_chan = check_current_channel(iface); | ||||||
|     return current_chan; |     return current_chan; | ||||||
| } | } | ||||||
| @@ -560,7 +436,7 @@ function random_channel_selection(iface, band, htmode, chan_list_valid) { | |||||||
|     ulog_info(`[%s] Selected channel list from config (default channel list shall be used in case channels haven't been selected) = %s \n`, iface, (chan_list_valid || '[]')); |     ulog_info(`[%s] Selected channel list from config (default channel list shall be used in case channels haven't been selected) = %s \n`, iface, (chan_list_valid || '[]')); | ||||||
|  |  | ||||||
|     if (band == '2g' && bw >= 40) { |     if (band == '2g' && bw >= 40) { | ||||||
|         ulog_info(`[%s] It is highly recommended to NOT use %dMHz bandwidth for 2.4G radio (RRM will not work properly) \n`, iface, bw); |         ulog_info(`[%s] It is highly recommended to NOT use %dMHz bandwidth for 2.4G radio \n`, iface, bw); | ||||||
|     } else if (band == '5g' && bw > 160) { |     } else if (band == '5g' && bw > 160) { | ||||||
|         ulog_info(`[%s] %dMHz bandwidth not supported for 5G radio. Please use a bandwidth of 160MHz or lower\n`, iface, bw); |         ulog_info(`[%s] %dMHz bandwidth not supported for 5G radio. Please use a bandwidth of 160MHz or lower\n`, iface, bw); | ||||||
|     } |     } | ||||||
| @@ -692,28 +568,9 @@ function random_channel_selection(iface, band, htmode, chan_list_valid) { | |||||||
|     return random_channel; |     return random_channel; | ||||||
| } | } | ||||||
|  |  | ||||||
| function check_center_channel(chosen_random_channel, current_channel, band, htmode) { |  | ||||||
|     let ret = false; |  | ||||||
|     let bw = replace(htmode, /[^0-9]/g, ''); |  | ||||||
|  |  | ||||||
|     if (band != '2g' || bw != 20) { |  | ||||||
|         // for 2G band or 20MHz bandwidth, center channel is the same as the channel |  | ||||||
|         let chosen_random_channel_center = get_center_channel(chosen_random_channel, band, bw); |  | ||||||
|         let current_channel_center = get_center_channel(current_channel, band, bw); |  | ||||||
|  |  | ||||||
|         ulog_info(`Center channel of the chosen random channel (%d) = %d; Center channel of the current channel (%d) = %d \n`, chosen_random_channel, chosen_random_channel_center, current_channel, current_channel_center); |  | ||||||
|  |  | ||||||
|         if (chosen_random_channel_center == current_channel_center) |  | ||||||
|             ret = true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return ret; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function algo_rcs(iface, current_channel, band, htmode, selected_channels) { | function algo_rcs(iface, current_channel, band, htmode, selected_channels) { | ||||||
|     let chosen_random_channel = 0; |     let chosen_random_channel = 0; | ||||||
|     let res = 0; |     let res = 0; | ||||||
|     let same_center_channel = false; |  | ||||||
|  |  | ||||||
|     // random_channel_selection script will help to select random channel |     // random_channel_selection script will help to select random channel | ||||||
|     chosen_random_channel = random_channel_selection(iface, band, htmode, selected_channels); |     chosen_random_channel = random_channel_selection(iface, band, htmode, selected_channels); | ||||||
| @@ -723,15 +580,8 @@ function algo_rcs(iface, current_channel, band, htmode, selected_channels) { | |||||||
|         ulog_info(`[%s] RCS assigned the same channel = %d; Skip channel switch \n`, iface, chosen_random_channel); |         ulog_info(`[%s] RCS assigned the same channel = %d; Skip channel switch \n`, iface, chosen_random_channel); | ||||||
|         res = 0; |         res = 0; | ||||||
|     } else if (chosen_random_channel > 0) { |     } else if (chosen_random_channel > 0) { | ||||||
|         // check if the random channel has the same center channel as the current channel |         ulog_info(`[%s] RCS done ... random channel found = %d\n`, iface, chosen_random_channel); | ||||||
|         same_center_channel = check_center_channel(chosen_random_channel, current_channel, band, htmode); |         res = 1; | ||||||
|         if (same_center_channel) { |  | ||||||
|             ulog_info(`[%s] RCS found channel %d with the same center channel as current channel %d; Skip channel switch \n`, iface, chosen_random_channel, current_channel); |  | ||||||
|             res = 0; |  | ||||||
|         } else { |  | ||||||
|             ulog_info(`[%s] RCS done ... random channel found = %d\n`, iface, chosen_random_channel); |  | ||||||
|             res = 1; |  | ||||||
|         } |  | ||||||
|     } else { |     } else { | ||||||
|         ulog_info(`[%s] RCS scan FAIL. Retry Channel optimization at next cycle \n`, iface); |         ulog_info(`[%s] RCS scan FAIL. Retry Channel optimization at next cycle \n`, iface); | ||||||
|         res = 0; |         res = 0; | ||||||
| @@ -761,8 +611,6 @@ function channel_optimize() { | |||||||
|         return config.interval; |         return config.interval; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     record_rrm_timestamp(); |  | ||||||
|  |  | ||||||
|     let current_rf_down = {}; |     let current_rf_down = {}; | ||||||
| 	let cool_down_f = {}; | 	let cool_down_f = {}; | ||||||
|     let check_all_cool_down = 0; |     let check_all_cool_down = 0; | ||||||
| @@ -1076,7 +924,7 @@ function channel_optimize() { | |||||||
|                             } |                             } | ||||||
|                         } else { |                         } else { | ||||||
|                             // revert back to the original channel |                             // revert back to the original channel | ||||||
|                             ulog_info(`[%s] Channel %d may have a cac_time longer than 60 seconds, RRM failed for this interval (you might want to avoid selecting this channel) \n`, radio_iface[l], init_payload.channel); |                             ulog_info(`[%s] Channel %d has a cac_time longer than 60 seconds, RRM failed for this interval (you might want to avoid selecting this channel) \n`, radio_iface[l], init_payload.channel); | ||||||
|                         } |                         } | ||||||
|                     } else if (selected_algo == "ACS") { |                     } else if (selected_algo == "ACS") { | ||||||
|                         let random_wait_time = random_time_calc(); |                         let random_wait_time = random_time_calc(); | ||||||
| @@ -1092,9 +940,6 @@ function channel_optimize() { | |||||||
|                             check_all_threshold_breach >= 1: threshold breach count exceeded for one or more interfaces |                             check_all_threshold_breach >= 1: threshold breach count exceeded for one or more interfaces | ||||||
|                         */ |                         */ | ||||||
|  |  | ||||||
|                         // Channel switch in progress, set flag = 1 |  | ||||||
|                         stats_info_write("/tmp/rrm_chan_switch", 1); |  | ||||||
|  |  | ||||||
|                         // flag to check if 5G radio was restarted |                         // flag to check if 5G radio was restarted | ||||||
|                         let radio_5g_restarted = 0; |                         let radio_5g_restarted = 0; | ||||||
|  |  | ||||||
| @@ -1158,10 +1003,6 @@ function channel_optimize() { | |||||||
|                             sleep(30000); |                             sleep(30000); | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|  |  | ||||||
|                     sleep(5000); |  | ||||||
|                     // Channel switch done, set flag = 0 |  | ||||||
|                     stats_info_write("/tmp/rrm_chan_switch", 0); |  | ||||||
|                 } else { |                 } else { | ||||||
|                     if (threshold_breach_f[l] != 1) { |                     if (threshold_breach_f[l] != 1) { | ||||||
|                         ulog_info(`[%s] Threshold breach count (=%d) < Allowed consecutive Channel Utilization threshold breach count (=%d), will be checked again in the next interval \n`, radio_iface[l], threshold_breach_count[l], config.consecutive_threshold_breach); |                         ulog_info(`[%s] Threshold breach count (=%d) < Allowed consecutive Channel Utilization threshold breach count (=%d), will be checked again in the next interval \n`, radio_iface[l], threshold_breach_count[l], config.consecutive_threshold_breach); | ||||||
| @@ -1175,7 +1016,6 @@ function channel_optimize() { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     ulog_info(`RRM with channel optimization finished; next RRM round starts in %d seconds \n`, config.interval/1000); |     ulog_info(`RRM with channel optimization finished; next RRM round starts in %d seconds \n`, config.interval/1000); | ||||||
|     record_rrm_timestamp(); |  | ||||||
|  |  | ||||||
|     return config.interval; |     return config.interval; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -51,7 +51,7 @@ start_rtty() { | |||||||
| 	procd_set_param command $BIN -h $host -I "$id" -a | 	procd_set_param command $BIN -h $host -I "$id" -a | ||||||
| 	[ -n "$port" ] && procd_append_param command -p "$port" | 	[ -n "$port" ] && procd_append_param command -p "$port" | ||||||
| 	[ -n "$description" ] && procd_append_param command -d "$description" | 	[ -n "$description" ] && procd_append_param command -d "$description" | ||||||
| 	[ "$ssl" = "1" ] && procd_append_param command -s -c /etc/ucentral/operational.pem -k /etc/ucentral/key.pem | 	[ "$ssl" = "1" ] && procd_append_param command -s -c /etc/ucentral/cert.pem -k /etc/ucentral/key.pem | ||||||
| 	[ -n "$token" ] && procd_append_param command -t "$token" | 	[ -n "$token" ] && procd_append_param command -t "$token" | ||||||
| 	[ "$verbose" = "1" ] && procd_append_param command -v | 	[ "$verbose" = "1" ] && procd_append_param command -v | ||||||
| 	[ "$timeout" -eq "0" ] || procd_append_param command -e $timeout | 	[ "$timeout" -eq "0" ] || procd_append_param command -e $timeout | ||||||
|   | |||||||
| @@ -4,10 +4,10 @@ PKG_NAME:=ucentral-client | |||||||
| PKG_RELEASE:=1 | PKG_RELEASE:=1 | ||||||
|  |  | ||||||
| PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-client.git | PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-client.git | ||||||
| PKG_MIRROR_HASH:=34c912efa9c0dcdbc6122296e236993484b24b3bc4de51608356304afc8df1c3 | PKG_MIRROR_HASH:=2e28e0aa61b74851c7daf3634ec34d303a603e881e6c5d1fd76c837dea527582 | ||||||
| PKG_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_DATE:=2025-07-27 | PKG_SOURCE_DATE:=2025-07-08 | ||||||
| PKG_SOURCE_VERSION:=c536f6957bd96e57301f9d540b75460119d2a69a | PKG_SOURCE_VERSION:=69829f63ea172ce9bd19b7b02073746fe9cf6a52 | ||||||
|  |  | ||||||
| PKG_LICENSE:=BSD-3-Clause | PKG_LICENSE:=BSD-3-Clause | ||||||
| PKG_MAINTAINER:=John Crispin <john@phrozen.org> | PKG_MAINTAINER:=John Crispin <john@phrozen.org> | ||||||
|   | |||||||
| @@ -6,9 +6,9 @@ config ucentral config | |||||||
| 	option reporting	10 | 	option reporting	10 | ||||||
|  |  | ||||||
| config timeouts timeouts | config timeouts timeouts | ||||||
| 	option offline		14400 | 	option offline		120 | ||||||
| 	option validate		120 | 	option validate		120 | ||||||
| 	option orphan		7200 | 	option orphan		120 | ||||||
|  |  | ||||||
| #config event | #config event | ||||||
| #	option type  dhcp | #	option type  dhcp | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ PKG_NAME:=ucentral-schema | |||||||
| PKG_RELEASE:=1 | PKG_RELEASE:=1 | ||||||
|  |  | ||||||
| PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-schema.git | PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-schema.git | ||||||
|  | PKG_MIRROR_HASH:=1ad9f7b5d5d1145e3aed14937eef60d6794d821e0244cc8fa824400d3da47f5a | ||||||
| PKG_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_DATE:=2025-08-04 | PKG_SOURCE_DATE:=2025-07-11 | ||||||
| PKG_SOURCE_VERSION:=1c6b3095cb9e398fcbfcb2bf995365066eb76b21 | PKG_SOURCE_VERSION:=5276d0b8b6e83ab57354b0bcbb820de83a91ab88 | ||||||
| PKG_MAINTAINER:=John Crispin <john@phrozen.org> | PKG_MAINTAINER:=John Crispin <john@phrozen.org> | ||||||
| PKG_LICENSE:=BSD-3-Clause | PKG_LICENSE:=BSD-3-Clause | ||||||
|  |  | ||||||
|   | |||||||
| @@ -22,65 +22,7 @@ let current_state; | |||||||
| let online = false; | let online = false; | ||||||
|  |  | ||||||
| function self_healing() { | function self_healing() { | ||||||
| 	let heal_wifi = false; |  | ||||||
| 	let health_stat = json(fs.readfile('/tmp/ucentral.health')); |  | ||||||
| 	let last_nw_restart_ts = int(fs.readfile('/tmp/ucentral.nw_restart_ts')) || 0; |  | ||||||
| 	let time_passed_since_nw_restart = time() - last_nw_restart_ts; |  | ||||||
|  |  | ||||||
| 	if (health_stat) { |  | ||||||
| 		if (health_stat.data.rrm_chanutil == false) { |  | ||||||
| 			// RRM with Channel utilization abnormal, restart rrmd |  | ||||||
| 			ulog(LOG_INFO, 'RRM with Channel utilization abnormal, restarting rrmd\n'); |  | ||||||
| 			system('/etc/init.d/rrmd restart'); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if (health_stat.sanity != 100) { |  | ||||||
| 			for (let iface in health_stat.data.interfaces) { |  | ||||||
| 				let iface_data = health_stat.data.interfaces[iface]; |  | ||||||
| 				if (iface_data.ssids) { |  | ||||||
| 					// one of the VAPs have an issue: flag up! |  | ||||||
| 					heal_wifi = true; |  | ||||||
| 					ulog(LOG_INFO, 'Time passed since last network restart = %d seconds\n', time_passed_since_nw_restart); |  | ||||||
| 					break; |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} else { |  | ||||||
| 			// all VAPs are healthy, no need to heal anything |  | ||||||
| 			return; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if (fs.stat('/tmp/rrm_timestamp')) { |  | ||||||
| 		let rrm_chan_switch_flag = int(fs.readfile('/tmp/rrm_chan_switch')) || 0; |  | ||||||
| 		let last_rrm_timestamp = int(fs.readfile('/tmp/rrm_timestamp')); |  | ||||||
| 		let time_passed_since_rrm = time() - last_rrm_timestamp; |  | ||||||
|  |  | ||||||
| 		if (rrm_chan_switch_flag == 1) { |  | ||||||
| 			// RRM chan switch in progress, do not restart network! |  | ||||||
| 			ulog(LOG_INFO, 'RRM channel switch in progress, cannot restart network \n'); |  | ||||||
| 			heal_wifi = false; |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		if (time_passed_since_rrm < 180) { |  | ||||||
| 			// RRM in progress, do not restart network! |  | ||||||
| 			ulog(LOG_INFO, 'RRM with Channel utilization may still be in progress, cannot restart network \n'); |  | ||||||
| 			heal_wifi = false; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	// keep a gap of at least 5 minutes between network restarts |  | ||||||
| 	if (heal_wifi && time_passed_since_nw_restart > 300) { |  | ||||||
| 		ulog(LOG_INFO, 'Restarting network \n'); |  | ||||||
| 		// update network restart timestamp |  | ||||||
| 		let f = fs.open("/tmp/ucentral.nw_restart_ts", "w"); |  | ||||||
| 		if (f) { |  | ||||||
| 			f.write(time()); |  | ||||||
| 			f.close(); |  | ||||||
| 		} |  | ||||||
|  |  | ||||||
| 		// restart network |  | ||||||
| 		system('/etc/init.d/network restart'); |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
| let healthcheck; | let healthcheck; | ||||||
| @@ -100,7 +42,7 @@ healthcheck = { | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	spawn: function() { | 	spawn: function() { | ||||||
| 		ulog(LOG_INFO, 'healthcheck execute\n'); | 		ulog(LOG_INFO, 'healtcheck execute\n'); | ||||||
| 		healthcheck.pid = uloop.process('/usr/share/ucentral/health.uc', [], {}, healthcheck.complete); | 		healthcheck.pid = uloop.process('/usr/share/ucentral/health.uc', [], {}, healthcheck.complete); | ||||||
| 	}, | 	}, | ||||||
| }; | }; | ||||||
| @@ -265,7 +207,7 @@ let ubus_methods = { | |||||||
| 			current_state = req.args.state; | 			current_state = req.args.state; | ||||||
| 			blink_timeout(); | 			blink_timeout(); | ||||||
| 			ulog(LOG_INFO, 'set state -> ' + req.args.state + '\n'); | 			ulog(LOG_INFO, 'set state -> ' + req.args.state + '\n'); | ||||||
|  | 			 | ||||||
| 			return state_handler[req.args.state](req.args); | 			return state_handler[req.args.state](req.args); | ||||||
| 		}, | 		}, | ||||||
| 		args: { | 		args: { | ||||||
|   | |||||||
| @@ -1,68 +0,0 @@ | |||||||
| From a2a7cdf9e292bac5b146738276a593d8e119fe8f Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Marek Kwaczynski <marek@shasta.cloud> |  | ||||||
| Date: Thu, 3 Jul 2025 15:55:43 +0000 |  | ||||||
| Subject: [PATCH] netifd: add gcmp-256 as a cipher suite when SAE is enabled on |  | ||||||
|  HE/EHT |  | ||||||
|  |  | ||||||
| Enabling gcmp-256 only on 6GHz radio. |  | ||||||
|  |  | ||||||
| Fixes: WIFI-14594 |  | ||||||
|  |  | ||||||
| Signed-off-by: Marek Kwaczynski <marek@shasta.cloud> |  | ||||||
| --- |  | ||||||
|  .../config/netifd/patches/200-gcmp-256.patch  | 43 +++++++++++++++++++ |  | ||||||
|  1 file changed, 43 insertions(+) |  | ||||||
|  create mode 100644 package/network/config/netifd/patches/200-gcmp-256.patch |  | ||||||
|  |  | ||||||
| diff --git a/package/network/config/netifd/patches/200-gcmp-256.patch b/package/network/config/netifd/patches/200-gcmp-256.patch |  | ||||||
| new file mode 100644 |  | ||||||
| index 0000000000..7ac6262e7f |  | ||||||
| --- /dev/null |  | ||||||
| +++ b/package/network/config/netifd/patches/200-gcmp-256.patch |  | ||||||
| @@ -0,0 +1,43 @@ |  | ||||||
| +Index: netifd-2023-09-19-8587c074/scripts/netifd-wireless.sh |  | ||||||
| +=================================================================== |  | ||||||
| +--- netifd-2023-09-19-8587c074.orig/scripts/netifd-wireless.sh |  | ||||||
| ++++ netifd-2023-09-19-8587c074/scripts/netifd-wireless.sh |  | ||||||
| +@@ -39,11 +39,10 @@ prepare_key_wep() { |  | ||||||
| + } |  | ||||||
| +  |  | ||||||
| + _wdev_prepare_channel() { |  | ||||||
| +-	json_get_vars channel band hwmode |  | ||||||
| ++	json_get_vars channel band hwmode htmode |  | ||||||
| +  |  | ||||||
| + 	auto_channel=0 |  | ||||||
| + 	enable_ht=0 |  | ||||||
| +-	htmode= |  | ||||||
| + 	hwmode="${hwmode##11}" |  | ||||||
| +  |  | ||||||
| + 	case "$channel" in |  | ||||||
| +@@ -70,7 +69,14 @@ _wdev_prepare_channel() { |  | ||||||
| +  |  | ||||||
| + 	case "$band" in |  | ||||||
| + 		2g) hwmode=g;; |  | ||||||
| +-		5g|6g) hwmode=a;; |  | ||||||
| ++		5g) hwmode=a;; |  | ||||||
| ++		6g) |  | ||||||
| ++			hwmode=a; |  | ||||||
| ++			case "$htmode" in |  | ||||||
| ++				HE*|EHT*) wpa3_cipher="GCMP-256 ";; |  | ||||||
| ++				*) wpa3_cipher="";; |  | ||||||
| ++			esac |  | ||||||
| ++		;; |  | ||||||
| + 		60g) hwmode=ad;; |  | ||||||
| + 		*) |  | ||||||
| + 			case "$hwmode" in |  | ||||||
| +@@ -216,6 +222,9 @@ wireless_vif_parse_encryption() { |  | ||||||
| + 		wpa_cipher="GCMP" |  | ||||||
| + 	else |  | ||||||
| + 		wpa_cipher="CCMP" |  | ||||||
| ++		case "$encryption" in |  | ||||||
| ++			sae*|wpa3*|psk3*|owe) wpa_cipher="${wpa3_cipher}$wpa_cipher";; |  | ||||||
| ++		esac |  | ||||||
| + 	fi |  | ||||||
| +  |  | ||||||
| + 	case "$encryption" in |  | ||||||
| --  |  | ||||||
| 2.43.0 |  | ||||||
|  |  | ||||||
| @@ -0,0 +1,27 @@ | |||||||
|  | From 0f590999ea33fb91160aec123a9a74c31623584e Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Paul White <paul@shasta.cloud> | ||||||
|  | Date: Mon, 21 Jul 2025 22:41:52 +0000 | ||||||
|  | Subject: [PATCH] feeds.default.conf: switch to using git:// instead of | ||||||
|  |  https:// | ||||||
|  |  | ||||||
|  | Signed-off-by: Paul White <paul@shasta.cloud> | ||||||
|  | --- | ||||||
|  |  feeds.conf.default | 8 ++++---- | ||||||
|  |  1 file changed, 4 insertions(+), 4 deletions(-) | ||||||
|  |  | ||||||
|  | diff --git a/feeds.conf.default b/feeds.conf.default | ||||||
|  | index d467db5627..bafcf8aa98 100644 | ||||||
|  | --- a/feeds.conf.default | ||||||
|  | +++ b/feeds.conf.default | ||||||
|  | @@ -1,4 +1,4 @@ | ||||||
|  | -src-git packages https://git.openwrt.org/feed/packages.git;openwrt-23.05 | ||||||
|  | -src-git luci https://git.openwrt.org/project/luci.git;openwrt-23.05 | ||||||
|  | -src-git routing https://git.openwrt.org/feed/routing.git;openwrt-23.05 | ||||||
|  | -src-git telephony https://git.openwrt.org/feed/telephony.git;openwrt-23.05 | ||||||
|  | +src-git packages git://git.openwrt.org/feed/packages.git;openwrt-23.05 | ||||||
|  | +src-git luci git://git.openwrt.org/project/luci.git;openwrt-23.05 | ||||||
|  | +src-git routing git://git.openwrt.org/feed/routing.git;openwrt-23.05 | ||||||
|  | +src-git telephony git://git.openwrt.org/feed/telephony.git;openwrt-23.05 | ||||||
|  | --  | ||||||
|  | 2.43.0 | ||||||
|  |  | ||||||
| @@ -1,37 +0,0 @@ | |||||||
| From 0b83834085bf536183b0683f4f86800dbe1e2d39 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: John Crispin <john@phrozen.org> |  | ||||||
| Date: Mon, 28 Jul 2025 07:49:07 +0200 |  | ||||||
| Subject: [PATCH] toolchain: use older gcc11 for legacy targets |  | ||||||
|  |  | ||||||
| Signed-off-by: John Crispin <john@phrozen.org> |  | ||||||
| --- |  | ||||||
|  toolchain/binutils/Config.version | 1 + |  | ||||||
|  toolchain/gcc/Config.version      | 1 + |  | ||||||
|  2 files changed, 2 insertions(+) |  | ||||||
|  |  | ||||||
| diff --git a/toolchain/binutils/Config.version b/toolchain/binutils/Config.version |  | ||||||
| index c9f8584480..5393d389a5 100644 |  | ||||||
| --- a/toolchain/binutils/Config.version |  | ||||||
| +++ b/toolchain/binutils/Config.version |  | ||||||
| @@ -1,6 +1,7 @@ |  | ||||||
|   |  | ||||||
|  config BINUTILS_VERSION_2_37 |  | ||||||
|  	bool |  | ||||||
| +	default y if TARGET_ipq40xx |  | ||||||
|   |  | ||||||
|  config BINUTILS_VERSION_2_38 |  | ||||||
|  	bool |  | ||||||
| diff --git a/toolchain/gcc/Config.version b/toolchain/gcc/Config.version |  | ||||||
| index 7126a0c883..b7de3d00e3 100644 |  | ||||||
| --- a/toolchain/gcc/Config.version |  | ||||||
| +++ b/toolchain/gcc/Config.version |  | ||||||
| @@ -1,5 +1,6 @@ |  | ||||||
|  config GCC_VERSION_11 |  | ||||||
|  	default y if GCC_USE_VERSION_11 |  | ||||||
| +	default y if TARGET_ipq40xx |  | ||||||
|  	bool |  | ||||||
|   |  | ||||||
|  config GCC_VERSION_13 |  | ||||||
| --  |  | ||||||
| 2.34.1 |  | ||||||
|  |  | ||||||
| @@ -1,33 +0,0 @@ | |||||||
| From 309a419087da906a2f3b0f39763f021e9729dd85 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Paul White <paul@shasta.cloud> |  | ||||||
| Date: Mon, 4 Aug 2025 04:14:23 +0000 |  | ||||||
| Subject: [PATCH] base-files: boot: add sync after uci-defaults |  | ||||||
|  |  | ||||||
| A scenario was seen where UCI config was not flushed to disk before |  | ||||||
| an AP power-cycle after uci-defaults was completed.  Since these |  | ||||||
| scripts are deleted after being ran once, there is no way to recover |  | ||||||
| without a factory reset. |  | ||||||
|  |  | ||||||
| Adding this sync operation proved to help avoid this situation from |  | ||||||
| happening |  | ||||||
|  |  | ||||||
| Signed-off-by: Paul White <paul@shasta.cloud> |  | ||||||
| --- |  | ||||||
|  package/base-files/files/etc/init.d/boot | 1 + |  | ||||||
|  1 file changed, 1 insertion(+) |  | ||||||
|  |  | ||||||
| diff --git a/package/base-files/files/etc/init.d/boot b/package/base-files/files/etc/init.d/boot |  | ||||||
| index 15756669a9..c8a803e32c 100755 |  | ||||||
| --- a/package/base-files/files/etc/init.d/boot |  | ||||||
| +++ b/package/base-files/files/etc/init.d/boot |  | ||||||
| @@ -15,6 +15,7 @@ uci_apply_defaults() { |  | ||||||
|  		( . "./$(basename $file)" ) && rm -f "$file" |  | ||||||
|  	done |  | ||||||
|  	uci commit |  | ||||||
| +	sync |  | ||||||
|  } |  | ||||||
|   |  | ||||||
|  boot() { |  | ||||||
| --  |  | ||||||
| 2.43.0 |  | ||||||
|  |  | ||||||
| @@ -1,25 +0,0 @@ | |||||||
| From d366477af72e725524b47f2fffe8a8c1d500060d Mon Sep 17 00:00:00 2001 |  | ||||||
| From: John Crispin <john@phrozen.org> |  | ||||||
| Date: Thu, 31 Jul 2025 14:45:12 +0200 |  | ||||||
| Subject: [PATCH] uboot-envtools: add udaya-id5 |  | ||||||
|  |  | ||||||
| Signed-off-by: John Crispin <john@phrozen.org> |  | ||||||
| --- |  | ||||||
|  package/boot/uboot-envtools/files/ipq40xx | 1 + |  | ||||||
|  1 file changed, 1 insertion(+) |  | ||||||
|  |  | ||||||
| diff --git a/package/boot/uboot-envtools/files/ipq40xx b/package/boot/uboot-envtools/files/ipq40xx |  | ||||||
| index 8d993fae36..78299195bd 100644 |  | ||||||
| --- a/package/boot/uboot-envtools/files/ipq40xx |  | ||||||
| +++ b/package/boot/uboot-envtools/files/ipq40xx |  | ||||||
| @@ -42,6 +42,7 @@ luma,wrtq-329acn|\ |  | ||||||
|  netgear,wac510|\ |  | ||||||
|  openmesh,a42|\ |  | ||||||
|  openmesh,a62|\ |  | ||||||
| +udaya,a5-id2|\ |  | ||||||
|  pakedge,wr-1|\ |  | ||||||
|  plasmacloud,pa1200|\ |  | ||||||
|  plasmacloud,pa2200) |  | ||||||
| --  |  | ||||||
| 2.34.1 |  | ||||||
|  |  | ||||||
| @@ -1,36 +0,0 @@ | |||||||
| From 3ceb72aaffa13375c049d161702e9d9f55da38c8 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: John Crispin <john@phrozen.org> |  | ||||||
| Date: Mon, 4 Aug 2025 08:34:50 +0200 |  | ||||||
| Subject: [PATCH] yuncore_ax820: add insta1/2 partitions |  | ||||||
|  |  | ||||||
| Signed-off-by: John Crispin <john@phrozen.org> |  | ||||||
| --- |  | ||||||
|  target/linux/ramips/dts/mt7621_yuncore_ax820.dts | 12 +++++++++++- |  | ||||||
|  1 file changed, 11 insertions(+), 1 deletion(-) |  | ||||||
|  |  | ||||||
| diff --git a/target/linux/ramips/dts/mt7621_yuncore_ax820.dts b/target/linux/ramips/dts/mt7621_yuncore_ax820.dts |  | ||||||
| index b2f55b9be0..cc1b59340b 100644 |  | ||||||
| --- a/target/linux/ramips/dts/mt7621_yuncore_ax820.dts |  | ||||||
| +++ b/target/linux/ramips/dts/mt7621_yuncore_ax820.dts |  | ||||||
| @@ -120,7 +120,17 @@ |  | ||||||
|  			partition@90000 { |  | ||||||
|  				compatible = "denx,uimage"; |  | ||||||
|  				label = "firmware"; |  | ||||||
| -				reg = <0x90000 0xf60000>; |  | ||||||
| +				reg = <0x90000 0xf40000>; |  | ||||||
| +			}; |  | ||||||
| + |  | ||||||
| +			partition@fd0000 { |  | ||||||
| +				label = "insta1"; |  | ||||||
| +				reg = <0xfd0000 0x10000>; |  | ||||||
| +			}; |  | ||||||
| + |  | ||||||
| +			partition@fe0000 { |  | ||||||
| +				label = "insta2"; |  | ||||||
| +				reg = <0xfe0000 0x10000>; |  | ||||||
|  			}; |  | ||||||
|   |  | ||||||
|  			partition@ff0000 { |  | ||||||
| --  |  | ||||||
| 2.34.1 |  | ||||||
|  |  | ||||||
| @@ -1,39 +0,0 @@ | |||||||
| From d0a0f0304f292a40f2fcdd20b320089627b0f05f Mon Sep 17 00:00:00 2001 |  | ||||||
| From: John Crispin <john@phrozen.org> |  | ||||||
| Date: Thu, 7 Aug 2025 14:50:51 +0200 |  | ||||||
| Subject: [PATCH] wireless-regdb: fix channel 14 in JP |  | ||||||
|  |  | ||||||
| Signed-off-by: John Crispin <john@phrozen.org> |  | ||||||
| --- |  | ||||||
|  .../patches/200-jp-no-channel-14.patch        | 19 +++++++++++++++++++ |  | ||||||
|  1 file changed, 19 insertions(+) |  | ||||||
|  create mode 100644 package/firmware/wireless-regdb/patches/200-jp-no-channel-14.patch |  | ||||||
|  |  | ||||||
| diff --git a/package/firmware/wireless-regdb/patches/200-jp-no-channel-14.patch b/package/firmware/wireless-regdb/patches/200-jp-no-channel-14.patch |  | ||||||
| new file mode 100644 |  | ||||||
| index 0000000000..ea1411cfdd |  | ||||||
| --- /dev/null |  | ||||||
| +++ b/package/firmware/wireless-regdb/patches/200-jp-no-channel-14.patch |  | ||||||
| @@ -0,0 +1,19 @@ |  | ||||||
| +--- a/db.txt |  | ||||||
| ++++ b/db.txt |  | ||||||
| +@@ -16,8 +16,6 @@ country 00: |  | ||||||
| + 	(2402 - 2472 @ 40), (20) |  | ||||||
| + 	# Channel 12 - 13. |  | ||||||
| + 	(2457 - 2482 @ 20), (20), NO-IR, AUTO-BW |  | ||||||
| +-	# Channel 14. Only JP enables this and for 802.11b only |  | ||||||
| +-	(2474 - 2494 @ 20), (20), NO-IR, NO-OFDM |  | ||||||
| + 	# Channel 36 - 48 |  | ||||||
| + 	(5170 - 5250 @ 80), (20), AUTO-BW |  | ||||||
| + 	# Channel 52 - 64 |  | ||||||
| +@@ -945,7 +943,6 @@ country JO: DFS-JP |  | ||||||
| + # https://www.soumu.go.jp/main_content/000833682.pdf |  | ||||||
| + country JP: DFS-JP |  | ||||||
| + 	(2402 - 2482 @ 40), (20) |  | ||||||
| +-	(2474 - 2494 @ 20), (20), NO-OFDM |  | ||||||
| + 	(4910 - 4990 @ 40), (23) |  | ||||||
| + 	(5170 - 5250 @ 80), (20), AUTO-BW |  | ||||||
| + 	(5250 - 5330 @ 80), (20), DFS, AUTO-BW |  | ||||||
| --  |  | ||||||
| 2.34.1 |  | ||||||
|  |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| --- |  | ||||||
| profile: edgecore_spw2ac1200 |  | ||||||
| target: ipq40xx |  | ||||||
| subtarget: generic |  | ||||||
| description: Build image for the Edgecore spw2ac1200 |  | ||||||
| image: bin/targets/ipq40xx/generic/openwrt-ipq40xx-generic-edgecore_spw2ac1200-squashfs-nand-sysupgrade.bin |  | ||||||
| packages: |  | ||||||
|   - ipq40xx |  | ||||||
| include: |  | ||||||
|   - ucentral-ap |  | ||||||
|   - hostapd |  | ||||||
|   - target-ipq40xx |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| --- |  | ||||||
| profile: emplus_wap7635 |  | ||||||
| target: ipq53xx |  | ||||||
| subtarget: generic |  | ||||||
| description: Build image for the EMPLUS WAP7635 |  | ||||||
| image: bin/targets/ipq53xx/generic/openwrt-ipq53xx-emplus_wap7635-squashfs-sysupgrade.tar |  | ||||||
| feeds: |  | ||||||
|   - name: qca |  | ||||||
|     path: ../../feeds/qca-wifi-7 |  | ||||||
| include: |  | ||||||
|   - ucentral-ap |  | ||||||
| packages: |  | ||||||
|   - ipq53xx |  | ||||||
|   - qca-ssdk-shell |  | ||||||
|   - iperf3 |  | ||||||
|   - jq |  | ||||||
|   - sysstat |  | ||||||
|   - tree |  | ||||||
| diffconfig: | |  | ||||||
|   CONFIG_KERNEL_IPQ_MEM_PROFILE=0 |  | ||||||
|   CONFIG_BUSYBOX_CUSTOM=y |  | ||||||
|   CONFIG_BUSYBOX_CONFIG_PSTREE=y |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| --- |  | ||||||
| profile: hfcl_ion4 |  | ||||||
| target: ipq40xx |  | ||||||
| subtarget: generic |  | ||||||
| description: Build image for the HFCL ION4 |  | ||||||
| image: bin/targets/ipq40xx/generic/openwrt-ipq40xx-generic-hfcl_ion4-squashfs-nand-sysupgrade.bin |  | ||||||
| packages: |  | ||||||
|   - ipq40xx |  | ||||||
| include: |  | ||||||
|   - ucentral-ap |  | ||||||
|   - hostapd |  | ||||||
|   - target-ipq40xx |  | ||||||
		Reference in New Issue
	
	Block a user