mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-11-04 04:18:07 +00:00 
			
		
		
		
	Compare commits
	
		
			36 Commits
		
	
	
		
			feeds_use_
			...
			uci_defaul
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					b72e58b33d | ||
| 
						 | 
					68dfd58303 | ||
| 
						 | 
					6ba26cba2b | ||
| 
						 | 
					b5b276bfcc | ||
| 
						 | 
					de7dc7e01a | ||
| 
						 | 
					a967d67af3 | ||
| 
						 | 
					8a68073f4f | ||
| 
						 | 
					efd804987e | ||
| 
						 | 
					b036ba37e3 | ||
| 
						 | 
					7352de2421 | ||
| 
						 | 
					8c11eb23a3 | ||
| 
						 | 
					83874b75f3 | ||
| 
						 | 
					694cf6ded8 | ||
| 
						 | 
					0a3a207584 | ||
| 
						 | 
					b0e95e68a2 | ||
| 
						 | 
					26ed5acb60 | ||
| 
						 | 
					d1e4c48617 | ||
| 
						 | 
					3a8fc316f2 | ||
| 
						 | 
					d85dc2a819 | ||
| 
						 | 
					acca9737e4 | ||
| 
						 | 
					6d2fd1de0d | ||
| 
						 | 
					1d822a10d2 | ||
| 
						 | 
					ebdc88ee1f | ||
| 
						 | 
					778cc679a0 | ||
| 
						 | 
					088d78faa7 | ||
| 
						 | 
					5306f7db27 | ||
| 
						 | 
					c8bffdc250 | ||
| 
						 | 
					3a3de9e146 | ||
| 
						 | 
					4d5c9a2d4c | ||
| 
						 | 
					41aa4c2978 | ||
| 
						 | 
					7795c51947 | ||
| 
						 | 
					9e68fc6e66 | ||
| 
						 | 
					b60c244d93 | ||
| 
						 | 
					ae1f394e28 | ||
| 
						 | 
					d09126c674 | ||
| 
						 | 
					810bc501e1 | 
@@ -24,8 +24,6 @@ endef
 | 
				
			|||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ALLWIFIBOARDS:= \
 | 
					ALLWIFIBOARDS:= \
 | 
				
			||||||
	cig-wf186w \
 | 
					 | 
				
			||||||
	cig-wf186h \
 | 
					 | 
				
			||||||
	cig-wf660a \
 | 
						cig-wf660a \
 | 
				
			||||||
	cig-wf194c \
 | 
						cig-wf194c \
 | 
				
			||||||
	cig-wf194c4 \
 | 
						cig-wf194c4 \
 | 
				
			||||||
@@ -108,6 +106,16 @@ $(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
 | 
				
			||||||
@@ -284,6 +292,24 @@ 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/
 | 
				
			||||||
@@ -393,8 +419,6 @@ 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))
 | 
				
			||||||
@@ -440,6 +464,8 @@ $(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))
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-ca.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-ca.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-ca.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-ca.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-us.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-us.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-us.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-cig-wf186w-us.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
										
											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 = gps_info.major_axis ?? 0;
 | 
					afc_location.major_axis = int(gps_info.major_axis) || 1;
 | 
				
			||||||
afc_location.minor_axis = gps_info.minor_axis ?? 0;
 | 
					afc_location.minor_axis = int(gps_info.minor_axis) || 1;
 | 
				
			||||||
afc_location.orientation = gps_info.major_orientation ?? 0;
 | 
					afc_location.orientation = gps_info.major_orientation || 0;
 | 
				
			||||||
afc_location.vertical_tolerance = gps_info.vdop ?? 0;
 | 
					afc_location.vertical_tolerance = int(gps_info.vdop) || 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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,7 +1,8 @@
 | 
				
			|||||||
let libubus = require("ubus");
 | 
					let libubus = require("ubus");
 | 
				
			||||||
import { open, readfile } from "fs";
 | 
					import { open, readfile, writefile } 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 = {};
 | 
				
			||||||
@@ -893,10 +894,24 @@ return {
 | 
				
			|||||||
		hostapd.ubus.disconnect();
 | 
							hostapd.ubus.disconnect();
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	afc_request: function(iface, data) {
 | 
						afc_request: function(iface, data) {
 | 
				
			||||||
		let ret = ubus.call("afc", "request", { data });
 | 
							let wireless_config = uci.get_all('wireless');
 | 
				
			||||||
		if (type(ret) != "object")
 | 
							for (let l, afc_server in wireless_config) {
 | 
				
			||||||
			return;
 | 
								if (afc_server['.type'] == 'afc-server' && afc_server.url && data) {
 | 
				
			||||||
		return ret.data;
 | 
									hostapd.printf(`Sending AFC request: ${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,6 +251,32 @@ 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,29 +107,42 @@ 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,13 +34,11 @@ 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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,107 +0,0 @@
 | 
				
			|||||||
# 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
 | 
					 | 
				
			||||||
@@ -0,0 +1,63 @@
 | 
				
			|||||||
 | 
					# 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
 | 
				
			||||||
@@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					--- 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 n
 | 
							default y
 | 
				
			||||||
		prompt "Enable mesh networking support"
 | 
							prompt "Enable mesh networking support"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	config MORSE_WPA_SUPPLICANT_S1G_EAP
 | 
						config MORSE_WPA_SUPPLICANT_S1G_EAP
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -43,6 +43,11 @@ $(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
 | 
				
			||||||
@@ -96,8 +101,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.QCN92XX $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin
 | 
						$(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.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin
 | 
						$(INSTALL_DATA) ./board-2.bin.wf189-us.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.US
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Package/ath12k-wifi-edgecore-eap105/install
 | 
					define Package/ath12k-wifi-edgecore-eap105/install
 | 
				
			||||||
@@ -107,6 +112,13 @@ 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/
 | 
				
			||||||
@@ -144,8 +156,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.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin
 | 
						$(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.QCN6432 $(1)/lib/firmware/ath12k/QCN6432/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) ./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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -153,8 +165,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.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin
 | 
						$(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.QCN6432 $(1)/lib/firmware/ath12k/QCN6432/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) ./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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -182,12 +194,13 @@ 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.QCN92XX $(1)/lib/firmware/ath12k/QCN92XX/hw1.0/board-2.bin
 | 
						$(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.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin
 | 
						$(INSTALL_DATA) ./board-2.bin.wf672-us.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin.US
 | 
				
			||||||
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.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2.bin.wap7635.IPQ5332
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2.bin.wap7635.IPQ5332
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2.bin.wap7635.QCN6274
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2.bin.wap7635.QCN6274
									
									
									
									
									
										Normal file
									
								
							
										
											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 = gps_info.major_axis ?? 0;
 | 
					afc_location.major_axis = int(gps_info.major_axis) || 1;
 | 
				
			||||||
afc_location.minor_axis = gps_info.minor_axis ?? 0;
 | 
					afc_location.minor_axis = int(gps_info.minor_axis) || 1;
 | 
				
			||||||
afc_location.orientation = gps_info.major_orientation ?? 0;
 | 
					afc_location.orientation = gps_info.major_orientation || 0;
 | 
				
			||||||
afc_location.vertical_tolerance = gps_info.vdop ?? 0;
 | 
					afc_location.vertical_tolerance = int(gps_info.vdop) || 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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,7 +1,8 @@
 | 
				
			|||||||
let libubus = require("ubus");
 | 
					let libubus = require("ubus");
 | 
				
			||||||
import { open, readfile } from "fs";
 | 
					import { open, readfile, writefile } 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 = {};
 | 
				
			||||||
@@ -1006,7 +1007,6 @@ 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,10 +1026,24 @@ return {
 | 
				
			|||||||
		hostapd.ubus.disconnect();
 | 
							hostapd.ubus.disconnect();
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
	afc_request: function(iface, data) {
 | 
						afc_request: function(iface, data) {
 | 
				
			||||||
		let ret = ubus.call("afc", "request", { data });
 | 
							let wireless_config = uci.get_all('wireless');
 | 
				
			||||||
		if (type(ret) != "object")
 | 
							for (let l, afc_server in wireless_config) {
 | 
				
			||||||
			return;
 | 
								if (afc_server['.type'] == 'afc-server' && afc_server.url && data) {
 | 
				
			||||||
		return ret.data;
 | 
									hostapd.printf(`Sending AFC request: ${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,6 +7,11 @@ 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,7 +13,6 @@ 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)
 | 
				
			||||||
@@ -32,6 +31,10 @@ 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"
 | 
				
			||||||
		;;	
 | 
							;;	
 | 
				
			||||||
@@ -104,6 +107,7 @@ 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,6 +64,7 @@ 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)
 | 
				
			||||||
@@ -86,6 +87,7 @@ 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)
 | 
				
			||||||
@@ -124,6 +126,47 @@ 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,7 +136,8 @@ 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
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										413
									
								
								feeds/qca-wifi-7/ipq53xx/dts/ipq5332-emplus-wap7635.dts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										413
									
								
								feeds/qca-wifi-7/ipq53xx/dts/ipq5332-emplus-wap7635.dts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,413 @@
 | 
				
			|||||||
 | 
					// 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,6 +31,20 @@
 | 
				
			|||||||
		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,6 +190,14 @@
 | 
				
			|||||||
		/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,6 +190,14 @@
 | 
				
			|||||||
		/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,6 +190,14 @@
 | 
				
			|||||||
		/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,6 +52,19 @@ 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,6 +100,7 @@ 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) \
 | 
				
			||||||
@@ -202,6 +203,15 @@ 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))
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										317
									
								
								feeds/qca-wifi-7/qca-ssdk-qca/files-zyxel_nwa130be/qca-ssdk
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										317
									
								
								feeds/qca-wifi-7/qca-ssdk-qca/files-zyxel_nwa130be/qca-ssdk
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,317 @@
 | 
				
			|||||||
 | 
					#!/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,6 +20,7 @@ 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,13 +6,16 @@ check_certificates() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
check_certificates
 | 
					check_certificates
 | 
				
			||||||
 | 
					
 | 
				
			||||||
bootconfig_lookup() {
 | 
					tar_part_lookup() {
 | 
				
			||||||
	case "$(fw_printenv -n cert_part)" in
 | 
						part="$(fw_printenv -n cert_part)"
 | 
				
			||||||
	0)	echo "0:BOOTCONFIG"
 | 
						if [ "$part" -eq 0 ]; then
 | 
				
			||||||
		;;
 | 
							echo "$2"
 | 
				
			||||||
	1)	echo "0:BOOTCONFIG1"
 | 
							part=1
 | 
				
			||||||
		;;
 | 
						else
 | 
				
			||||||
	esac
 | 
							echo "$1"
 | 
				
			||||||
 | 
							part=0
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
 | 
						fw_setenv cert_part $part
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
. /lib/functions.sh
 | 
					. /lib/functions.sh
 | 
				
			||||||
@@ -35,13 +38,40 @@ 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
 | 
				
			||||||
		bootconfig=$(bootconfig_lookup)
 | 
							part=$(tar_part_lookup "0:BOOTCONFIG" "0:BOOTCONFIG1")
 | 
				
			||||||
		if [ -n "$bootconfig" ]; then
 | 
							if [ -n "part" ]; then
 | 
				
			||||||
			mmc_dev=$(echo $(find_mmc_part "$bootconfig") | sed 's/^.\{5\}//')
 | 
								mmc_dev=$(echo $(find_mmc_part "$part") | 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,25 +1,44 @@
 | 
				
			|||||||
#!/bin/sh
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					
 | 
				
			||||||
bootconfig_lookup() {
 | 
					tar_part_lookup() {
 | 
				
			||||||
	bootconfig="$(fw_printenv -n cert_part)"
 | 
						part="$(fw_printenv -n cert_part)"
 | 
				
			||||||
	case "$(fw_printenv -n cert_part)" in
 | 
						if [ "$part" -eq 0 ]; then
 | 
				
			||||||
	0)	echo "0:BOOTCONFIG1"
 | 
							echo "$2"
 | 
				
			||||||
		bootconfig=1
 | 
							part=1
 | 
				
			||||||
		;;
 | 
						else
 | 
				
			||||||
	*)	echo "0:BOOTCONFIG"
 | 
							echo "$1"
 | 
				
			||||||
		bootconfig=0
 | 
							part=0
 | 
				
			||||||
		;;
 | 
						fi
 | 
				
			||||||
	esac
 | 
						fw_setenv cert_part $part
 | 
				
			||||||
	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 .
 | 
				
			||||||
	bootconfig=$(bootconfig_lookup)
 | 
						part=$(tar_part_lookup "0:BOOTCONFIG" "0:BOOTCONFIG1")
 | 
				
			||||||
	mmc_dev=$(echo $(find_mmc_part $bootconfig) | sed 's/^.\{5\}//')
 | 
						mmc_dev=$(echo $(find_mmc_part $part) | sed 's/^.\{5\}//')
 | 
				
			||||||
	dd if=/tmp/certs.tar of=/dev/$bootconfig
 | 
						dd if=/tmp/certs.tar of=/dev/$mmc_dev
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
 | 
					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,6 +22,19 @@ 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,6 +27,8 @@ 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");
 | 
				
			||||||
@@ -91,6 +93,7 @@ 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;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -328,6 +331,27 @@ 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');
 | 
				
			||||||
@@ -344,6 +368,7 @@ 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,6 +4,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
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;
 | 
				
			||||||
@@ -139,6 +140,9 @@ 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();
 | 
				
			||||||
@@ -163,6 +167,20 @@ 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();
 | 
				
			||||||
@@ -184,4 +202,7 @@ 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*'))
 | 
										if (!wildcard(obj, 'hostapd.wlan*') && !wildcard(obj, 'hostapd.phy*'))
 | 
				
			||||||
						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,6 +6,8 @@ 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,6 +24,10 @@ 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;
 | 
				
			||||||
@@ -136,20 +140,122 @@ function channel_to_freq(band, channel) {
 | 
				
			|||||||
    return freq;
 | 
					    return freq;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function center_freq_calc(band, freq, bandwidth) {
 | 
					// using mapping to get correct center channel, especially for 6G radio
 | 
				
			||||||
    if (bandwidth == 40)
 | 
					function get_center_channel(channel, band, bw) {
 | 
				
			||||||
        return +freq + 10;
 | 
					    let center_channel = channel;
 | 
				
			||||||
    if (bandwidth == 80)
 | 
					    let center_channel_map = {};
 | 
				
			||||||
        return +freq + 30;
 | 
					 | 
				
			||||||
    if (bandwidth == 160)
 | 
					 | 
				
			||||||
        return +freq + 70;
 | 
					 | 
				
			||||||
    if (bandwidth == 320)
 | 
					 | 
				
			||||||
        if (freq == 6115)
 | 
					 | 
				
			||||||
            return +freq - 10;
 | 
					 | 
				
			||||||
        else
 | 
					 | 
				
			||||||
            return +freq + 150;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return +freq;
 | 
					    switch (band) {
 | 
				
			||||||
 | 
					    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) {
 | 
				
			||||||
@@ -201,6 +307,9 @@ 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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -208,7 +317,8 @@ 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_freq = center_freq_calc(msg.band, target_freq, bandwidth);
 | 
					    let center_channel = get_center_channel(msg.channel, msg.band, 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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -245,9 +355,20 @@ 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;
 | 
				
			||||||
        // Max 65 seconds wait for the DFS enabled interface to be UP
 | 
					        // Default max 70 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);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -267,6 +388,9 @@ 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;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -436,7 +560,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 \n`, iface, bw);
 | 
					        ulog_info(`[%s] It is highly recommended to NOT use %dMHz bandwidth for 2.4G radio (RRM will not work properly) \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);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -568,9 +692,28 @@ 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);
 | 
				
			||||||
@@ -580,8 +723,15 @@ 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) {
 | 
				
			||||||
        ulog_info(`[%s] RCS done ... random channel found = %d\n`, iface, chosen_random_channel);
 | 
					        // check if the random channel has the same center channel as the current channel
 | 
				
			||||||
        res = 1;
 | 
					        same_center_channel = check_center_channel(chosen_random_channel, current_channel, band, htmode);
 | 
				
			||||||
 | 
					        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;
 | 
				
			||||||
@@ -611,6 +761,8 @@ 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;
 | 
				
			||||||
@@ -924,7 +1076,7 @@ function channel_optimize() {
 | 
				
			|||||||
                            }
 | 
					                            }
 | 
				
			||||||
                        } else {
 | 
					                        } else {
 | 
				
			||||||
                            // revert back to the original channel
 | 
					                            // revert back to the original 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);
 | 
					                            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);
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    } else if (selected_algo == "ACS") {
 | 
					                    } else if (selected_algo == "ACS") {
 | 
				
			||||||
                        let random_wait_time = random_time_calc();
 | 
					                        let random_wait_time = random_time_calc();
 | 
				
			||||||
@@ -940,6 +1092,9 @@ 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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1003,6 +1158,10 @@ 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);
 | 
				
			||||||
@@ -1016,6 +1175,7 @@ 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/cert.pem -k /etc/ucentral/key.pem
 | 
						[ "$ssl" = "1" ] && procd_append_param command -s -c /etc/ucentral/operational.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:=2e28e0aa61b74851c7daf3634ec34d303a603e881e6c5d1fd76c837dea527582
 | 
					PKG_MIRROR_HASH:=34c912efa9c0dcdbc6122296e236993484b24b3bc4de51608356304afc8df1c3
 | 
				
			||||||
PKG_SOURCE_PROTO:=git
 | 
					PKG_SOURCE_PROTO:=git
 | 
				
			||||||
PKG_SOURCE_DATE:=2025-07-08
 | 
					PKG_SOURCE_DATE:=2025-07-27
 | 
				
			||||||
PKG_SOURCE_VERSION:=69829f63ea172ce9bd19b7b02073746fe9cf6a52
 | 
					PKG_SOURCE_VERSION:=c536f6957bd96e57301f9d540b75460119d2a69a
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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		120
 | 
						option offline		14400
 | 
				
			||||||
	option validate		120
 | 
						option validate		120
 | 
				
			||||||
	option orphan		120
 | 
						option orphan		7200
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#config event
 | 
					#config event
 | 
				
			||||||
#	option type  dhcp
 | 
					#	option type  dhcp
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,10 +4,9 @@ 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-07-11
 | 
					PKG_SOURCE_DATE:=2025-08-04
 | 
				
			||||||
PKG_SOURCE_VERSION:=5276d0b8b6e83ab57354b0bcbb820de83a91ab88
 | 
					PKG_SOURCE_VERSION:=1c6b3095cb9e398fcbfcb2bf995365066eb76b21
 | 
				
			||||||
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,7 +22,65 @@ 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;
 | 
				
			||||||
@@ -42,7 +100,7 @@ healthcheck = {
 | 
				
			|||||||
	},
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	spawn: function() {
 | 
						spawn: function() {
 | 
				
			||||||
		ulog(LOG_INFO, 'healtcheck execute\n');
 | 
							ulog(LOG_INFO, 'healthcheck execute\n');
 | 
				
			||||||
		healthcheck.pid = uloop.process('/usr/share/ucentral/health.uc', [], {}, healthcheck.complete);
 | 
							healthcheck.pid = uloop.process('/usr/share/ucentral/health.uc', [], {}, healthcheck.complete);
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										68
									
								
								patches/0090-netifd-add-gcmp-256-on-6GHz.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								patches/0090-netifd-add-gcmp-256-on-6GHz.patch
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,68 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -1,27 +0,0 @@
 | 
				
			|||||||
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
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@@ -0,0 +1,37 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -0,0 +1,33 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										25
									
								
								patches/0096-uboot-envtools-add-udaya-id5.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								patches/0096-uboot-envtools-add-udaya-id5.patch
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,25 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										36
									
								
								patches/0097-yuncore_ax820-add-insta1-2-partitions.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								patches/0097-yuncore_ax820-add-insta1-2-partitions.patch
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,36 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										39
									
								
								patches/0099-wireless-regdb-fix-channel-14-in-JP.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								patches/0099-wireless-regdb-fix-channel-14-in-JP.patch
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
							
								
								
									
										12
									
								
								profiles/edgecore_spw2ac1200.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								profiles/edgecore_spw2ac1200.yml
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,12 @@
 | 
				
			|||||||
 | 
					---
 | 
				
			||||||
 | 
					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
 | 
				
			||||||
							
								
								
									
										22
									
								
								profiles/emplus_wap7635.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								profiles/emplus_wap7635.yml
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,22 @@
 | 
				
			|||||||
 | 
					---
 | 
				
			||||||
 | 
					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
 | 
				
			||||||
							
								
								
									
										12
									
								
								profiles/hfcl_ion4.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								profiles/hfcl_ion4.yml
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,12 @@
 | 
				
			|||||||
 | 
					---
 | 
				
			||||||
 | 
					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