mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-10-31 10:28:06 +00:00 
			
		
		
		
	Compare commits
	
		
			57 Commits
		
	
	
		
			feeds_use_
			...
			v4.1.0-rc3
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 7dd139cf3b | ||
|   | 544b687f46 | ||
|   | c27b015a63 | ||
|   | 02c2e6945b | ||
|   | e7cd5038ac | ||
|   | 34e4a01e25 | ||
|   | 60e9fb2645 | ||
|   | 462ff4f813 | ||
|   | 71b738f8ee | ||
|   | b995833a03 | ||
|   | 9866d4a86e | ||
|   | 4ad04c7948 | ||
|   | 143d4e3b58 | ||
|   | 0735fd8c9a | ||
|   | c7f9061eee | ||
|   | f4a58c0989 | ||
|   | cd78a832e3 | ||
|   | 7b6fc736f6 | ||
|   | f997f8dff0 | ||
|   | c4b3eeed81 | ||
|   | b2ba9d7c1b | ||
|   | b982f3f4c2 | ||
|   | 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) { | ||||||
|  | 			if (afc_server['.type'] == 'afc-server' && afc_server.url && 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; | 					return; | ||||||
| 		return ret.data; | 			} | ||||||
|  | 		} | ||||||
| 	}, | 	}, | ||||||
| 	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,12 +107,25 @@ 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" | ||||||
|   | |||||||
| @@ -0,0 +1,61 @@ | |||||||
|  | --- a/include/init/ssdk_plat.h | ||||||
|  | +++ b/include/init/ssdk_plat.h | ||||||
|  | @@ -330,6 +330,7 @@ struct qca_phy_priv { | ||||||
|  |  	struct mii_bus *miibus; | ||||||
|  |  /*qca808x_end*/ | ||||||
|  |  	u64 *mib_counters; | ||||||
|  | +	a_uint32_t mib_loop_cnt; | ||||||
|  |  	/* dump buf */ | ||||||
|  |  	a_uint8_t  buf[2048]; | ||||||
|  |  	a_uint32_t link_polling_required; | ||||||
|  | --- a/src/ref/ref_mib.c | ||||||
|  | +++ b/src/ref/ref_mib.c | ||||||
|  | @@ -479,39 +479,37 @@ qca_ar8327_sw_get_port_mib(struct switch | ||||||
|  |  #endif | ||||||
|  |  | ||||||
|  |  int | ||||||
|  | -_qca_ar8327_sw_capture_port_tx_counter(struct qca_phy_priv *priv, int port) | ||||||
|  | +_qca_ar8327_sw_capture_port_tx_counter(a_uint32_t dev_id, int port) | ||||||
|  |  { | ||||||
|  |      fal_mib_info_t  mib_Info; | ||||||
|  |  | ||||||
|  |      memset(&mib_Info, 0, sizeof(fal_mib_info_t)); | ||||||
|  | -    fal_get_tx_mib_info(priv->device_id, port, &mib_Info); | ||||||
|  | +    fal_get_tx_mib_info(dev_id, port, &mib_Info); | ||||||
|  |  | ||||||
|  |      return 0; | ||||||
|  |  } | ||||||
|  |  | ||||||
|  |  int | ||||||
|  | -_qca_ar8327_sw_capture_port_rx_counter(struct qca_phy_priv *priv, int port) | ||||||
|  | +_qca_ar8327_sw_capture_port_rx_counter(a_uint32_t dev_id, int port) | ||||||
|  |  { | ||||||
|  |      fal_mib_info_t  mib_Info; | ||||||
|  |  | ||||||
|  |      memset(&mib_Info, 0, sizeof(fal_mib_info_t)); | ||||||
|  | -    fal_get_rx_mib_info(priv->device_id, port, &mib_Info); | ||||||
|  | +    fal_get_rx_mib_info(dev_id, port, &mib_Info); | ||||||
|  |      return 0; | ||||||
|  |  } | ||||||
|  |  | ||||||
|  |  void | ||||||
|  |  qca_ar8327_sw_mib_task(struct qca_phy_priv *priv) | ||||||
|  |  { | ||||||
|  | -	static int loop = 0; | ||||||
|  | - | ||||||
|  |  	mutex_lock(&priv->reg_mutex); | ||||||
|  | -	if ((loop % 2) == 0) | ||||||
|  | -		_qca_ar8327_sw_capture_port_rx_counter(priv, loop/2); | ||||||
|  | +	if ((priv->mib_loop_cnt % 2) == 0) | ||||||
|  | +		_qca_ar8327_sw_capture_port_rx_counter(priv->device_id, priv->mib_loop_cnt/2); | ||||||
|  |  	else | ||||||
|  | -		_qca_ar8327_sw_capture_port_tx_counter(priv, loop/2); | ||||||
|  | +		_qca_ar8327_sw_capture_port_tx_counter(priv->device_id, priv->mib_loop_cnt/2); | ||||||
|  |  | ||||||
|  | -	if(++loop == (2 * (priv->ports))) { | ||||||
|  | -		loop = 0; | ||||||
|  | +	if(++priv->mib_loop_cnt == (2 * (priv->ports))) { | ||||||
|  | +		priv->mib_loop_cnt = 0; | ||||||
|  |  	} | ||||||
|  |  | ||||||
|  |  	mutex_unlock(&priv->reg_mutex); | ||||||
| @@ -200,7 +200,7 @@ | |||||||
| 			phy-mode = "sgmii"; | 			phy-mode = "sgmii"; | ||||||
| 			full-duplex; | 			full-duplex; | ||||||
| 			pause; | 			pause; | ||||||
| 			airoha,surge = <1>; | 			airoha,surge = <0>; | ||||||
| 			airoha,polarity = <2>; | 			airoha,polarity = <2>; | ||||||
| 		}; | 		}; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -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) { | ||||||
|  | 			if (afc_server['.type'] == 'afc-server' && afc_server.url && 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; | 					return; | ||||||
| 		return ret.data; | 			} | ||||||
|  | 		} | ||||||
| 	}, | 	}, | ||||||
| 	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 | ||||||
|   | |||||||
| @@ -15,9 +15,14 @@ const ONLINE = 2; | |||||||
| const OFFLINE = 3; | const OFFLINE = 3; | ||||||
| const ORPHAN = 4; | const ORPHAN = 4; | ||||||
|  |  | ||||||
|  | const DISCOVER_DHCP = "DHCP"; | ||||||
|  | const DISCOVER_FLASH = "FLASH"; | ||||||
|  | const DISCOVER_LOOKUP = "OpenLAN"; | ||||||
|  |  | ||||||
| let ubus = libubus.connect(); | let ubus = libubus.connect(); | ||||||
| let uci = libuci.cursor(); | let uci = libuci.cursor(); | ||||||
| let state = DISCOVER; | let state = DISCOVER; | ||||||
|  | let discovery_method = ""; | ||||||
| let validate_time; | let validate_time; | ||||||
| let offline_time; | let offline_time; | ||||||
| let orphan_time; | let orphan_time; | ||||||
| @@ -27,6 +32,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: 1 * 365 * 24 * 60 * 60, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| ulog_open(ULOG_SYSLOG | ULOG_STDIO, LOG_DAEMON, "cloud_discover"); | ulog_open(ULOG_SYSLOG | ULOG_STDIO, LOG_DAEMON, "cloud_discover"); | ||||||
| @@ -35,6 +42,24 @@ ulog(LOG_INFO, 'Start\n'); | |||||||
|  |  | ||||||
| uloop.init(); | uloop.init(); | ||||||
|  |  | ||||||
|  | let cds_server = 'discovery.open-lan.org'; | ||||||
|  |  | ||||||
|  | function detect_certificate_type() { | ||||||
|  | 	let pipe = fs.popen(`openssl x509 -in /etc/ucentral/cert.pem -noout -issuer`); | ||||||
|  | 	let issuer = pipe.read("all"); | ||||||
|  | 	pipe.close(); | ||||||
|  |  | ||||||
|  | 	if (match(issuer, /OpenLAN Demo Birth CA/)) { | ||||||
|  | 		ulog(LOG_INFO, 'Certificate type is "Demo" \n'); | ||||||
|  | 		cds_server = 'discovery-qa.open-lan.org'; | ||||||
|  | 		timeouts.expiry_threshold = 3 * 24 * 60 * 60; | ||||||
|  | 	} else if (match(issuer, /OpenLAN Birth Issuing CA/)) { | ||||||
|  | 		ulog(LOG_INFO, 'Certificate type is "Production"\n'); | ||||||
|  | 	} else { | ||||||
|  | 		ulog(LOG_INFO, 'Certificate type is "TIP"\n'); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| function readjsonfile(path) { | function readjsonfile(path) { | ||||||
| 	let file = fs.readfile(path); | 	let file = fs.readfile(path); | ||||||
| 	if (file) | 	if (file) | ||||||
| @@ -76,6 +101,14 @@ function gateway_load() { | |||||||
| 	return readjsonfile('/etc/ucentral/gateway.json'); | 	return readjsonfile('/etc/ucentral/gateway.json'); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function discovery_state_write() { | ||||||
|  | 	let discovery_state = { | ||||||
|  | 		"type": discovery_method, | ||||||
|  | 		"updated": time() | ||||||
|  | 	}; | ||||||
|  | 	fs.writefile('/etc/ucentral/discovery.state.json', discovery_state); | ||||||
|  | } | ||||||
|  |  | ||||||
| function gateway_write(data) { | function gateway_write(data) { | ||||||
| 	let gateway = gateway_load(); | 	let gateway = gateway_load(); | ||||||
| 	gateway ??= {}; | 	gateway ??= {}; | ||||||
| @@ -89,8 +122,10 @@ function gateway_write(data) { | |||||||
| 		if (new[key] != gateway[key]) | 		if (new[key] != gateway[key]) | ||||||
| 			changed = true; | 			changed = true; | ||||||
| 	} | 	} | ||||||
| 	if (changed) | 	if (changed) { | ||||||
| 		fs.writefile('/etc/ucentral/gateway.json', new); | 		fs.writefile('/etc/ucentral/gateway.json', new); | ||||||
|  | 		system('sync'); | ||||||
|  | 	} | ||||||
| 	return changed; | 	return changed; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -127,6 +162,7 @@ function set_state(set) { | |||||||
| 		if (prev == VALIDATING) { | 		if (prev == VALIDATING) { | ||||||
| 			ulog(LOG_INFO, 'Setting cloud controller to validated\n'); | 			ulog(LOG_INFO, 'Setting cloud controller to validated\n'); | ||||||
| 			gateway_write({ valid: true }); | 			gateway_write({ valid: true }); | ||||||
|  | 			discovery_state_write(); | ||||||
| 		} | 		} | ||||||
| 		break; | 		break; | ||||||
|  |  | ||||||
| @@ -161,7 +197,7 @@ function redirector_lookup() { | |||||||
| 	let serial = uci.get('system', '@system[-1]', 'mac'); | 	let serial = uci.get('system', '@system[-1]', 'mac'); | ||||||
|  |  | ||||||
| 	fs.unlink(path); | 	fs.unlink(path); | ||||||
| 	system(`curl -k --cert /etc/ucentral/operational.pem --key /etc/ucentral/key.pem --cacert /etc/ucentral/operational.ca https://openlan.keys.tip.build/v1/devices/${serial} --output /tmp/ucentral.redirector`); | 	system(`curl -k --cert /etc/ucentral/operational.pem --key /etc/ucentral/key.pem --cacert /etc/ucentral/operational.ca https://${cds_server}/v1/devices/${serial} --output /tmp/ucentral.redirector`); | ||||||
| 	if (!fs.stat(path)) | 	if (!fs.stat(path)) | ||||||
| 		return; | 		return; | ||||||
| 	let redir = readjsonfile(path); | 	let redir = readjsonfile(path); | ||||||
| @@ -224,15 +260,18 @@ function interval_handler() { | |||||||
| 		if (!time_is_valid()) | 		if (!time_is_valid()) | ||||||
| 			return; | 			return; | ||||||
|  |  | ||||||
|  | 		discovery_method = DISCOVER_DHCP; | ||||||
| 		if (discover_dhcp()) | 		if (discover_dhcp()) | ||||||
| 			return; | 			return; | ||||||
|  |  | ||||||
| 		if (system('/usr/bin/est_client enroll')) | 		if (system('/usr/bin/est_client enroll')) | ||||||
| 			return; | 			return; | ||||||
|  |  | ||||||
|  | 		discovery_method = DISCOVER_FLASH; | ||||||
| 		if (!discover_flash()) | 		if (!discover_flash()) | ||||||
| 			return; | 			return; | ||||||
|  |  | ||||||
|  | 		discovery_method = DISCOVER_LOOKUP; | ||||||
| 		redirector_lookup(); | 		redirector_lookup(); | ||||||
| 		break; | 		break; | ||||||
|  |  | ||||||
| @@ -252,6 +291,36 @@ function interval_handler() { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | function trigger_reenroll() { | ||||||
|  | 	ulog(LOG_INFO, 'triggering reenroll\n'); | ||||||
|  |  | ||||||
|  | 	if (system('/usr/bin/est_client reenroll')) { | ||||||
|  | 		ulog(LOG_INFO, 'reenroll failed\n'); | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	ulog(LOG_INFO, 'reenroll succeeded\n'); | ||||||
|  | 	ulog(LOG_INFO, 'stopping client\n'); | ||||||
|  | 	 | ||||||
|  | 	system('/etc/init.d/ucentral stop'); | ||||||
|  | 	set_state(DISCOVER); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | 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'); | ||||||
|  | 	trigger_reenroll(); | ||||||
|  | } | ||||||
|  |  | ||||||
| let ubus_methods = { | let ubus_methods = { | ||||||
| 	discover: { | 	discover: { | ||||||
| 		call: function(req) { | 		call: function(req) { | ||||||
| @@ -326,8 +395,17 @@ let ubus_methods = { | |||||||
| 		}, | 		}, | ||||||
| 		args: {}, | 		args: {}, | ||||||
| 	}, | 	}, | ||||||
|  | 	reenroll: { | ||||||
|  | 		call: function(req) { | ||||||
|  | 			trigger_reenroll(); | ||||||
|  | 			return 0; | ||||||
|  | 		}, | ||||||
|  | 		args: {}, | ||||||
|  | 	}, | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | detect_certificate_type(); | ||||||
|  |  | ||||||
| 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 +422,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,12 +4,28 @@ | |||||||
|  |  | ||||||
| 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; | ||||||
| let est_server = 'qaest.certificates.open-lan.org:8001'; | let est_server = 'est.certificates.open-lan.org'; | ||||||
| let cert_prefix = 'operational'; | let cert_prefix = 'operational'; | ||||||
|  |  | ||||||
|  | function set_est_server() { | ||||||
|  | 	let pipe = fs.popen(`openssl x509 -in /etc/ucentral/cert.pem -noout -issuer`); | ||||||
|  | 	let issuer = pipe.read("all"); | ||||||
|  | 	pipe.close(); | ||||||
|  |  | ||||||
|  | 	if (match(issuer, /OpenLAN Demo Birth CA/)) { | ||||||
|  | 		ulog(LOG_INFO, 'Certificate type is "Demo" \n'); | ||||||
|  | 		est_server = 'qaest.certificates.open-lan.org:8001'; | ||||||
|  | 	} else if (match(issuer, /OpenLAN Birth Issuing CA/)) { | ||||||
|  | 		ulog(LOG_INFO, 'Certificate type is "Production"\n'); | ||||||
|  | 	} else { | ||||||
|  | 		ulog(LOG_INFO, 'Certificate type is "TIP"\n'); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  |  | ||||||
| if (getenv('EST_SERVER')) | if (getenv('EST_SERVER')) | ||||||
| 	est_server = getenv('EST_SERVER'); | 	est_server = getenv('EST_SERVER'); | ||||||
|  |  | ||||||
| @@ -78,6 +94,8 @@ function call_est_server(path, cert, target) { | |||||||
| 	if (generate_csr(cert)) | 	if (generate_csr(cert)) | ||||||
| 		return 1; | 		return 1; | ||||||
|  |  | ||||||
|  | 	set_est_server();	 | ||||||
|  |  | ||||||
| 	let ret = system('curl -m 10 -X POST https://' + est_server + '/.well-known/est/' + path + ' -d @/tmp/csr.nohdr.p10 -H "Content-Type: application/pkcs10" --cert ' + cert + ' --key /etc/ucentral/key.pem --cacert /etc/ucentral/insta.pem -o /tmp/operational.nohdr.p7'); | 	let ret = system('curl -m 10 -X POST https://' + est_server + '/.well-known/est/' + path + ' -d @/tmp/csr.nohdr.p10 -H "Content-Type: application/pkcs10" --cert ' + cert + ' --key /etc/ucentral/key.pem --cacert /etc/ucentral/insta.pem -o /tmp/operational.nohdr.p7'); | ||||||
| 	if (ret) { | 	if (ret) { | ||||||
| 		ulog(LOG_INFO, 'Failed to request operational certificate\n'); | 		ulog(LOG_INFO, 'Failed to request operational certificate\n'); | ||||||
| @@ -125,6 +143,9 @@ function load_operational_ca() { | |||||||
| 		ulog(LOG_INFO, 'Operational CA is present\n'); | 		ulog(LOG_INFO, 'Operational CA is present\n'); | ||||||
| 		return 0; | 		return 0; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	set_est_server();	 | ||||||
|  |  | ||||||
| 	let ret = system('curl -m 10 -X GET https://' + est_server + '/.well-known/est/cacerts --cert /etc/ucentral/' + cert_prefix + '.pem --key /etc/ucentral/key.pem --cacert /etc/ucentral/insta.pem -o /tmp/' + cert_prefix + '.ca.nohdr.p7'); | 	let ret = system('curl -m 10 -X GET https://' + est_server + '/.well-known/est/cacerts --cert /etc/ucentral/' + cert_prefix + '.pem --key /etc/ucentral/key.pem --cacert /etc/ucentral/insta.pem -o /tmp/' + cert_prefix + '.ca.nohdr.p7'); | ||||||
| 	if (!ret) | 	if (!ret) | ||||||
| 		ret = p7_too_pem('/tmp/' + cert_prefix + '.ca.nohdr.p7', '/etc/ucentral/' + cert_prefix + '.ca'); | 		ret = p7_too_pem('/tmp/' + cert_prefix + '.ca.nohdr.p7', '/etc/ucentral/' + cert_prefix + '.ca'); | ||||||
| @@ -139,11 +160,14 @@ 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(); | ||||||
|  |  | ||||||
| 	if (!(match(issuer, /OpenLAN/) && match(issuer, /Birth CA/))) | 	if (!(match(issuer, /OpenLAN/) && match(issuer, /Birth/))) | ||||||
| 		return 0; | 		return 0; | ||||||
|  |  | ||||||
| 	ulog(LOG_INFO, 'The issuer is insta\n'); | 	ulog(LOG_INFO, 'The issuer is insta\n'); | ||||||
| @@ -163,6 +187,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 +222,7 @@ case 'reenroll': | |||||||
|  |  | ||||||
| case 'fwtool': | case 'fwtool': | ||||||
| 	exit(fwtool()); | 	exit(fwtool()); | ||||||
|  |  | ||||||
|  | case 'check': | ||||||
|  | 	exit(check_cert()); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ import * as fs from 'fs'; | |||||||
|  |  | ||||||
| let cmd = ARGV[0]; | let cmd = ARGV[0]; | ||||||
| let ifname = getenv("interface"); | let ifname = getenv("interface"); | ||||||
| let opt224 = getenv("opt138"); | let opt138 = getenv("opt138"); | ||||||
| let opt224 = getenv("opt224"); | let opt224 = getenv("opt224"); | ||||||
|  |  | ||||||
| if (cmd != 'bound' && cmd != 'renew') | if (cmd != 'bound' && cmd != 'renew') | ||||||
|   | |||||||
| @@ -4,3 +4,6 @@ MIIFajCCA1KgAwIBAgICDnowDQYJKoZIhvcNAQELBQAwHzEdMBsGA1UEAwwUT3BlbkxBTiBEZW1vIFJv | |||||||
| -----BEGIN CERTIFICATE----- | -----BEGIN CERTIFICATE----- | ||||||
| MIIFIDCCAwigAwIBAgICDnkwDQYJKoZIhvcNAQELBQAwHzEdMBsGA1UEAwwUT3BlbkxBTiBEZW1vIFJvb3QgQ0EwHhcNMjUwMjIxMTUwMDAwWhcNMjYwMjIxMTUwMDAwWjAfMR0wGwYDVQQDDBRPcGVuTEFOIERlbW8gUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMjExylKdJWoJu9mOHPJ6yZFXKe1lE467G65acpS2FKIWnPVFjNCmATMpkMOIFzEFwyFdbQjzOidtiL+73zlE52lOJpXCfOcxDFqDYDJJ8//J1/gQWsBaKpSvgLiHU/0awkQg+yJYZpj8YZa4NkFe+zTjQScSfOsqPPb3rZ7DOQ2BKAhjVShKmVbtNil0iO0zm8vE8DNkktTNMREp2pzb8MbCAgfOkwlrby6T+rV3TvmjThGdFUb5lWDFxWtlF8W0SUII9qj7p5TdGpryeLsO0nZTBtS4HxZNdvmKOHfgcRHmSZIJigB2NzKLNrXF9JBW0WnUSwZJZAG2C1RTx6lADILPueuusyfR/hZ3koKi4PHnSiTwQghzia9K9QjNHq5z9R9ZoCnhBg1VyU4LKmp862L0sIp2vgnOYunEIi9aCYBaDwo+0FuVjZuXyDIatwVuA7TN5IWPHA6XLdOt1mmkeYy1Ldr4XHjdondhtOyeei1UFXmyyLm2+kmRYfTm91TqYmNzRgbRV2NHO50AmsnBknX4Rv3gishGe0+dV5yFcUwZud0z2rSCkuoai5tKrPT+6Y6NqkT9u9HFifIBXnLwEzVUqHRtW6SuWj2DClVQIXIUZtFnhY4GuTuf6DlzgnXO58oDVCZmCW4ULIpbqGeRsvBHR8Sw5JXP/1+TMUYhE8TAgMBAAGjZjBkMB8GA1UdIwQYMBaAFDzIg8eyTI3xc4A2R60f8HanhBZDMB0GA1UdDgQWBBQ8yIPHskyN8XOANketH/B2p4QWQzAOBgNVHQ8BAf8EBAMCAQYwEgYDVR0TAQH/BAgwBgEB/wIBATANBgkqhkiG9w0BAQsFAAOCAgEAkHZ5KR8IOrdfMFy+iOvauvZxfQ84LL6TpB2FQKDjneJUdd7c29UJJFNW/0mp4Gc6jKZab6J8Dx/pNnbH0RqFjGjeRGtJ4Sk0G7gf9zw1S7qut5WJDcisM9l/wXC+zy/KSKKPQmbt0grWOtU7+NNPh1YU76hIrInq/u2sVZyKH8SXQ957fbJk6BX6JTKyNEn05AB6rNSrbOWo8sy2MlcJ7bBsrWYI1t6GcWFh4b36bLu7/dKJWpyFNXXIkKJsgMEDpEQae56+fSSDo0KRNtYB82fNZDIQlGK81rGJWNzAahM+3GD1tgk/3ZVugfaJhcBpoHHKNOGqZAvtirLAIDocno7AzqoeIz974Rh2Olsl2/arApYPyyfi8PMYuFe/d4h+Wie8n+jh5n48lZ2Ve4PK+j+QHD6tTZS4f0bGnPL1puMxzQloltuQWgLDeVfEgrc3snLvjOg8aDzWm/es85lP8XcyW54U4t3JmrNUC2C7v+Uafx7cL7eDeunhs+BRhtGV+IUmjub2IrpqZp3zZqn+LVRdYJIy/qHhjS5+ImckXkFojOmeWhfmEmYSuNP8Oa6cGuXp829qnbxLh9Qzi3TfXV883KLse4kL5Zl7gBA/4hz2hVMyGJ8fY+VvzbaTuOXyvKJ+rGZCTcRSeotBLnIevVMiL7SqOEwN0j4Mfbznfq8= | MIIFIDCCAwigAwIBAgICDnkwDQYJKoZIhvcNAQELBQAwHzEdMBsGA1UEAwwUT3BlbkxBTiBEZW1vIFJvb3QgQ0EwHhcNMjUwMjIxMTUwMDAwWhcNMjYwMjIxMTUwMDAwWjAfMR0wGwYDVQQDDBRPcGVuTEFOIERlbW8gUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMjExylKdJWoJu9mOHPJ6yZFXKe1lE467G65acpS2FKIWnPVFjNCmATMpkMOIFzEFwyFdbQjzOidtiL+73zlE52lOJpXCfOcxDFqDYDJJ8//J1/gQWsBaKpSvgLiHU/0awkQg+yJYZpj8YZa4NkFe+zTjQScSfOsqPPb3rZ7DOQ2BKAhjVShKmVbtNil0iO0zm8vE8DNkktTNMREp2pzb8MbCAgfOkwlrby6T+rV3TvmjThGdFUb5lWDFxWtlF8W0SUII9qj7p5TdGpryeLsO0nZTBtS4HxZNdvmKOHfgcRHmSZIJigB2NzKLNrXF9JBW0WnUSwZJZAG2C1RTx6lADILPueuusyfR/hZ3koKi4PHnSiTwQghzia9K9QjNHq5z9R9ZoCnhBg1VyU4LKmp862L0sIp2vgnOYunEIi9aCYBaDwo+0FuVjZuXyDIatwVuA7TN5IWPHA6XLdOt1mmkeYy1Ldr4XHjdondhtOyeei1UFXmyyLm2+kmRYfTm91TqYmNzRgbRV2NHO50AmsnBknX4Rv3gishGe0+dV5yFcUwZud0z2rSCkuoai5tKrPT+6Y6NqkT9u9HFifIBXnLwEzVUqHRtW6SuWj2DClVQIXIUZtFnhY4GuTuf6DlzgnXO58oDVCZmCW4ULIpbqGeRsvBHR8Sw5JXP/1+TMUYhE8TAgMBAAGjZjBkMB8GA1UdIwQYMBaAFDzIg8eyTI3xc4A2R60f8HanhBZDMB0GA1UdDgQWBBQ8yIPHskyN8XOANketH/B2p4QWQzAOBgNVHQ8BAf8EBAMCAQYwEgYDVR0TAQH/BAgwBgEB/wIBATANBgkqhkiG9w0BAQsFAAOCAgEAkHZ5KR8IOrdfMFy+iOvauvZxfQ84LL6TpB2FQKDjneJUdd7c29UJJFNW/0mp4Gc6jKZab6J8Dx/pNnbH0RqFjGjeRGtJ4Sk0G7gf9zw1S7qut5WJDcisM9l/wXC+zy/KSKKPQmbt0grWOtU7+NNPh1YU76hIrInq/u2sVZyKH8SXQ957fbJk6BX6JTKyNEn05AB6rNSrbOWo8sy2MlcJ7bBsrWYI1t6GcWFh4b36bLu7/dKJWpyFNXXIkKJsgMEDpEQae56+fSSDo0KRNtYB82fNZDIQlGK81rGJWNzAahM+3GD1tgk/3ZVugfaJhcBpoHHKNOGqZAvtirLAIDocno7AzqoeIz974Rh2Olsl2/arApYPyyfi8PMYuFe/d4h+Wie8n+jh5n48lZ2Ve4PK+j+QHD6tTZS4f0bGnPL1puMxzQloltuQWgLDeVfEgrc3snLvjOg8aDzWm/es85lP8XcyW54U4t3JmrNUC2C7v+Uafx7cL7eDeunhs+BRhtGV+IUmjub2IrpqZp3zZqn+LVRdYJIy/qHhjS5+ImckXkFojOmeWhfmEmYSuNP8Oa6cGuXp829qnbxLh9Qzi3TfXV883KLse4kL5Zl7gBA/4hz2hVMyGJ8fY+VvzbaTuOXyvKJ+rGZCTcRSeotBLnIevVMiL7SqOEwN0j4Mfbznfq8= | ||||||
| -----END CERTIFICATE----- | -----END CERTIFICATE----- | ||||||
|  | -----BEGIN CERTIFICATE----- | ||||||
|  | MIIFFTCCAv2gAwIBAgICAxIwDQYJKoZIhvcNAQELBQAwGjEYMBYGA1UEAwwPT3BlbkxBTiBSb290IENBMCAXDTI1MDUxNDA4NDcxMFoYDzIwNTUwNTE0MDg0NzEwWjAaMRgwFgYDVQQDDA9PcGVuTEFOIFJvb3QgQ0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDGibJ04A55kSURTBSKgcBmLnND2I5wws1taKqqU9aaRhB7NtvMHwh2voH9b1brUiulZaZwTN/9kzd4AnXeKQ+0u5tV7Ofk0fzF2MK47n17TS30Yenqc4NuQEKdpKK/pM3VvOEppR/bqtgyLtDmbDnmFOx+zTj/+smTgouwA+Iier0P4s5OohYxn/bjOqwQbHbU79VpGBIWv6/kt55AhH7zvsqqKHkrzTxnsRBv3SBIufrjJr9PIhZBLDrqr56P6KgAi0eoutNt2ToiJbE0WfjU7GI1RSiSN5bGj1zXhjNVzQWs1H9QzRf3c9pl3+haHQZ7FZ1UqiTRewmbNrQ6I9k81au3SttUlb87MyAuDSzatkiq7CjQ8VE1J6te6ZBt2zWpUhHsR/Lg7g3eOw5dL4oZJdK5GgGu/MUajLUXifIqM13Mvg0VTzDhN69VLXLSL0gPcicsQCwJuAza1IC/VqmBGx19fAkyJhOurCXWOgisi0g1+xzPKRphUNwMPUf8vBVOM/Vc6xDIvwVGE3+eWXyhixneFlSpAI03nWWjpwWXihTBoxbfRXO3Y/ilJqrgFN+U4PJcCPA+Wo7ThH0mgX6bOTPcgXMUzT3v3FF6Bx5/PNV3kYrw2yLzribUiS6AGvVGnW4hX2Z6OQvA/aHME8KF+6y6m4pC7FkUjVaRlzWu/wIDAQABo2MwYTAfBgNVHSMEGDAWgBSUaFuoOPk4QLByZP47kj4p1IbCJjAdBgNVHQ4EFgQUlGhbqDj5OECwcmT+O5I+KdSGwiYwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQELBQADggIBAB+/RUC2X6eVoPsFNMkaXO5Iib/ub0JoWhODQm8j2Mr5dpGXESSpXjfDcqDOLuJbWWoflXBLdr8BsVCBqOA9YgCX0H8Br7dUWmCScixxLW0he592/424EvdwifxcKHZLjv9CKV5Txhqnm2djc5RY/nTH5MYVrIh/If2TNO5ydDP6+vgy9GQ4en04VK7rz+PW17O8l7k9/lOmYptZmHgSDAPj/cT3PlG+McqaI5rMSHeEHlzH+PvgWjtSeEhF4FwFBXroDl4/yb4l2JB8bqAZ3vsOXSkigFcZh5MXPe+zuSSW+G8iLr4xoi0CFsP2DaHEyxgqP4B1FtE9nFPo6cvWbwqTVT7QSzqfH+jPJuQvpFXeRF5UFegNZTFT5/uFFPamihakFslEYxeJey1y+OJdLcP6ef87ruSt8amsq56OAETYpnW4JFowlEh0C+QwLGHGGY6WrOgHY/90hJmPgXBdBVg/IoOhzbvk5A+LqZDvxV2/rLNfClw8Kr3g5e8obcB6dWgMCy2z+us0H79ucnmhzQKsjpxM9T1ncHovAQfiD3jVqfHULY53avh0wIAjosoTGbe8dyx80quHe+16qWan7C9idXeAYYJXbZt5hs6hLw4I8M1LsjTg6vwsqiaHZpsmDyyQLdFjNJldG7aosfS9F+BIpuwijF+1dashL0CPsbIJ | ||||||
|  | -----END CERTIFICATE----- | ||||||
|   | |||||||
| @@ -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) { | ||||||
|  |         // check if the random channel has the same center channel as the current channel | ||||||
|  |         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); |             ulog_info(`[%s] RCS done ... random channel found = %d\n`, iface, chosen_random_channel); | ||||||
|             res = 1; |             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,9 @@ 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_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_DATE:=2025-07-08 | PKG_SOURCE_DATE:=2025-08-11 | ||||||
| PKG_SOURCE_VERSION:=69829f63ea172ce9bd19b7b02073746fe9cf6a52 | PKG_SOURCE_VERSION:=549e84e5fea7230c5471d6a3dbddcc7d3152f665 | ||||||
|  |  | ||||||
| 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 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,9 +20,68 @@ let config; | |||||||
| let offline_timer; | let offline_timer; | ||||||
| let current_state; | let current_state; | ||||||
| let online = false; | let online = false; | ||||||
|  | let leds_off = 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 +101,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); | ||||||
| 	}, | 	}, | ||||||
| }; | }; | ||||||
| @@ -90,6 +149,13 @@ function online_handler() { | |||||||
|  |  | ||||||
| function config_load() { | function config_load() { | ||||||
| 	ulog(LOG_INFO, 'loading config\n'); | 	ulog(LOG_INFO, 'loading config\n'); | ||||||
|  |  | ||||||
|  | 	uci.load('system'); | ||||||
|  | 	let led_off_cfg = uci.get("system", "@system[0]", "leds_off"); | ||||||
|  | 	if (led_off_cfg == 1) { | ||||||
|  | 		leds_off = true; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	uci.load('state'); | 	uci.load('state'); | ||||||
| 	config = uci.get_all('state'); | 	config = uci.get_all('state'); | ||||||
|  |  | ||||||
| @@ -133,7 +199,7 @@ function led_find(alias) { | |||||||
| function factory_reset_timeout() { | function factory_reset_timeout() { | ||||||
| 	let led = led_find('led-running'); | 	let led = led_find('led-running'); | ||||||
| 	if (led) | 	if (led) | ||||||
| 		led_write(led, 'trigger', 'default-on'); | 		led_write(led, 'trigger', leds-off ? 'none' : 'default-on'); | ||||||
| } | } | ||||||
|  |  | ||||||
| let blink_timer; | let blink_timer; | ||||||
| @@ -152,7 +218,7 @@ let state_handler = { | |||||||
| 	offline: function() { | 	offline: function() { | ||||||
| 		online = false; | 		online = false; | ||||||
| 		let led = led_find('led-running'); | 		let led = led_find('led-running'); | ||||||
| 		if (led) | 		if (!leds_off && led) | ||||||
| 			led_write(led, 'trigger', 'heartbeat'); | 			led_write(led, 'trigger', 'heartbeat'); | ||||||
| 		if (config.ui.offline_trigger) { | 		if (config.ui.offline_trigger) { | ||||||
| 			if (offline_timer) | 			if (offline_timer) | ||||||
| @@ -165,7 +231,7 @@ let state_handler = { | |||||||
| 	online: function() { | 	online: function() { | ||||||
| 		online = true; | 		online = true; | ||||||
| 		let led = led_find('led-running'); | 		let led = led_find('led-running'); | ||||||
| 		if (led) | 		if (!leds_off && led) | ||||||
| 			led_write(led, 'trigger', 'default-on'); | 			led_write(led, 'trigger', 'default-on'); | ||||||
| 		online_handler(); | 		online_handler(); | ||||||
| 		return 0; | 		return 0; | ||||||
|   | |||||||
							
								
								
									
										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 | ||||||
|  |  | ||||||
							
								
								
									
										26
									
								
								patches/0099-elfutils-fix-build-with-GCC11.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								patches/0099-elfutils-fix-build-with-GCC11.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | |||||||
|  | From b82a8514a3f52b91ec84f703ef92740dda19d5d9 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: John Crispin <john@phrozen.org> | ||||||
|  | Date: Thu, 14 Aug 2025 10:29:29 +0200 | ||||||
|  | Subject: [PATCH] elfutils: fix build with GCC11 | ||||||
|  |  | ||||||
|  | Signed-off-by: John Crispin <john@phrozen.org> | ||||||
|  | --- | ||||||
|  |  package/libs/elfutils/Makefile | 2 +- | ||||||
|  |  1 file changed, 1 insertion(+), 1 deletion(-) | ||||||
|  |  | ||||||
|  | diff --git a/package/libs/elfutils/Makefile b/package/libs/elfutils/Makefile | ||||||
|  | index f7364c36be..76112c89ff 100644 | ||||||
|  | --- a/package/libs/elfutils/Makefile | ||||||
|  | +++ b/package/libs/elfutils/Makefile | ||||||
|  | @@ -87,7 +87,7 @@ TARGET_CFLAGS += \ | ||||||
|  |  	-Wno-unused-result \ | ||||||
|  |  	-Wno-format-nonliteral | ||||||
|  |   | ||||||
|  | -ifneq ($(CONFIG_GCC_USE_VERSION_11),y) | ||||||
|  | +ifneq ($(CONFIG_GCC_VERSION_11),y) | ||||||
|  |  TARGET_CFLAGS += \ | ||||||
|  |  	-Wno-error=use-after-free | ||||||
|  |  endif | ||||||
|  | --  | ||||||
|  | 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