mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-11-03 20:07:59 +00:00 
			
		
		
		
	Compare commits
	
		
			108 Commits
		
	
	
		
			feeds_use_
			...
			release/v4
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					5b69e6a41e | ||
| 
						 | 
					1a3955554a | ||
| 
						 | 
					0fb2bd197a | ||
| 
						 | 
					427ad99151 | ||
| 
						 | 
					02ed19e3ac | ||
| 
						 | 
					60968f8c89 | ||
| 
						 | 
					7e840d0a84 | ||
| 
						 | 
					207a592896 | ||
| 
						 | 
					1bae90f681 | ||
| 
						 | 
					9d06b517dc | ||
| 
						 | 
					f2afe49977 | ||
| 
						 | 
					04cc064026 | ||
| 
						 | 
					14778e1d2f | ||
| 
						 | 
					9712ce581f | ||
| 
						 | 
					a4dbeb376e | ||
| 
						 | 
					02b0457b28 | ||
| 
						 | 
					42007a147f | ||
| 
						 | 
					d1e18425b0 | ||
| 
						 | 
					125c75c49b | ||
| 
						 | 
					d98e18a143 | ||
| 
						 | 
					fd170fabed | ||
| 
						 | 
					9b2d80f2b4 | ||
| 
						 | 
					5c892e7a0c | ||
| 
						 | 
					6ed93db422 | ||
| 
						 | 
					92d67c15dd | ||
| 
						 | 
					460180f42e | ||
| 
						 | 
					ed57759824 | ||
| 
						 | 
					957e3ca997 | ||
| 
						 | 
					7c2b8e8de0 | ||
| 
						 | 
					741007178f | ||
| 
						 | 
					e9d3e39d5e | ||
| 
						 | 
					b82a2c5da1 | ||
| 
						 | 
					15429f39d8 | ||
| 
						 | 
					5df274325b | ||
| 
						 | 
					2e4972e9ad | ||
| 
						 | 
					a25480d479 | ||
| 
						 | 
					2f625c35f0 | ||
| 
						 | 
					b5422f80e4 | ||
| 
						 | 
					1ed503613d | ||
| 
						 | 
					f8954418f1 | ||
| 
						 | 
					3abc6a4463 | ||
| 
						 | 
					5bd8fe1249 | ||
| 
						 | 
					593cdba4d7 | ||
| 
						 | 
					f811aa6b73 | ||
| 
						 | 
					7213dc6dcb | ||
| 
						 | 
					811b63de93 | ||
| 
						 | 
					c66020fbc6 | ||
| 
						 | 
					da7682166f | ||
| 
						 | 
					bd50dfdf96 | ||
| 
						 | 
					cbf0e536df | ||
| 
						 | 
					20a7a48c9f | ||
| 
						 | 
					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 | 
@@ -0,0 +1,14 @@
 | 
				
			|||||||
 | 
					--- a/hostapd/ctrl_iface.c	2025-09-24 14:15:25.135668867 +0800
 | 
				
			||||||
 | 
					+++ b/hostapd/ctrl_iface.c	2025-09-24 15:32:46.082317382 +0800
 | 
				
			||||||
 | 
					@@ -2657,6 +2657,11 @@ static int hostapd_ctrl_iface_chan_switc
 | 
				
			||||||
 | 
					 		break;
 | 
				
			||||||
 | 
					 	}
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+    /* Initialize HT/VHT/HE parameters */
 | 
				
			||||||
 | 
					+    settings.freq_params.ht_enabled = iface->conf->ieee80211n;
 | 
				
			||||||
 | 
					+    settings.freq_params.vht_enabled = iface->conf->ieee80211ac;
 | 
				
			||||||
 | 
					+    settings.freq_params.he_enabled = iface->conf->ieee80211ax;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 	if (settings.freq_params.center_freq1)
 | 
				
			||||||
 | 
					 		dfs_range += hostapd_is_dfs_overlap(
 | 
				
			||||||
 | 
					 			iface, bandwidth, settings.freq_params.center_freq1);
 | 
				
			||||||
@@ -24,8 +24,6 @@ endef
 | 
				
			|||||||
#
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ALLWIFIBOARDS:= \
 | 
					ALLWIFIBOARDS:= \
 | 
				
			||||||
	cig-wf186w \
 | 
					 | 
				
			||||||
	cig-wf186h \
 | 
					 | 
				
			||||||
	cig-wf660a \
 | 
						cig-wf660a \
 | 
				
			||||||
	cig-wf194c \
 | 
						cig-wf194c \
 | 
				
			||||||
	cig-wf194c4 \
 | 
						cig-wf194c4 \
 | 
				
			||||||
@@ -49,6 +47,10 @@ ALLWIFIBOARDS:= \
 | 
				
			|||||||
	indio-um-310ax-v1 \
 | 
						indio-um-310ax-v1 \
 | 
				
			||||||
	indio-um-510axp-v1 \
 | 
						indio-um-510axp-v1 \
 | 
				
			||||||
	indio-um-510axm-v1 \
 | 
						indio-um-510axm-v1 \
 | 
				
			||||||
 | 
						indio-um-325ax-v2 \
 | 
				
			||||||
 | 
						indio-um-335ax \
 | 
				
			||||||
 | 
						indio-um-525axp \
 | 
				
			||||||
 | 
						indio-um-525axm \
 | 
				
			||||||
	muxi-ap3220l \
 | 
						muxi-ap3220l \
 | 
				
			||||||
	plasmacloud-pax1800 \
 | 
						plasmacloud-pax1800 \
 | 
				
			||||||
	wallys-dr5018 \
 | 
						wallys-dr5018 \
 | 
				
			||||||
@@ -108,6 +110,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 +296,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 +423,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))
 | 
				
			||||||
@@ -417,6 +445,10 @@ $(eval $(call generate-ath11k-wifi-package,liteon-wpx8324,Liteon WPX8324))
 | 
				
			|||||||
$(eval $(call generate-ath11k-wifi-package,indio-um-310ax-v1,Indio UM-310AX V1))
 | 
					$(eval $(call generate-ath11k-wifi-package,indio-um-310ax-v1,Indio UM-310AX V1))
 | 
				
			||||||
$(eval $(call generate-ath11k-wifi-package,indio-um-510axp-v1,Indio UM-510AXP V1))
 | 
					$(eval $(call generate-ath11k-wifi-package,indio-um-510axp-v1,Indio UM-510AXP V1))
 | 
				
			||||||
$(eval $(call generate-ath11k-wifi-package,indio-um-510axm-v1,Indio UM-510AXM V1))
 | 
					$(eval $(call generate-ath11k-wifi-package,indio-um-510axm-v1,Indio UM-510AXM V1))
 | 
				
			||||||
 | 
					$(eval $(call generate-ath11k-wifi-package,indio-um-325ax-v2,Indio UM-325AX V2))
 | 
				
			||||||
 | 
					$(eval $(call generate-ath11k-wifi-package,indio-um-335ax,Indio UM-335AX))
 | 
				
			||||||
 | 
					$(eval $(call generate-ath11k-wifi-package,indio-um-525axp,Indio UM-525AXP))
 | 
				
			||||||
 | 
					$(eval $(call generate-ath11k-wifi-package,indio-um-525axm,Indio UM-525AXM))
 | 
				
			||||||
$(eval $(call generate-ath11k-wifi-package,sonicfi-rap630c-311g,Sonicfi RAP630C 311G))
 | 
					$(eval $(call generate-ath11k-wifi-package,sonicfi-rap630c-311g,Sonicfi RAP630C 311G))
 | 
				
			||||||
$(eval $(call generate-ath11k-wifi-package,sonicfi-rap630w-311g,Sonicfi RAP630W 311G))
 | 
					$(eval $(call generate-ath11k-wifi-package,sonicfi-rap630w-311g,Sonicfi RAP630W 311G))
 | 
				
			||||||
$(eval $(call generate-ath11k-wifi-package,sonicfi-rap630w-312g,Sonicfi RAP630W 312G))
 | 
					$(eval $(call generate-ath11k-wifi-package,sonicfi-rap630w-312g,Sonicfi RAP630W 312G))
 | 
				
			||||||
@@ -440,6 +472,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.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-325ax-v2.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-325ax-v2.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-325ax-v2.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-325ax-v2.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-335ax.bin.IPQ5018
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-335ax.bin.IPQ5018
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-335ax.bin.QCN9074
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-335ax.bin.QCN9074
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axm.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axm.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axm.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axm.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axp.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axp.bin.IPQ5018
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axp.bin.QCN6122
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/ipq807x_v5.4/ath11k-wifi/board-indio-um-525axp.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);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,6 +16,14 @@ edgecore,eap104)
 | 
				
			|||||||
	ucidef_set_led_netdev "wan" "wan" "yellow:uplink" "eth0"
 | 
						ucidef_set_led_netdev "wan" "wan" "yellow:uplink" "eth0"
 | 
				
			||||||
        ucidef_set_led_default "power" "POWER" "green:power" "on"
 | 
					        ucidef_set_led_default "power" "POWER" "green:power" "on"
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 | 
					indio,um-325ax-v2|\
 | 
				
			||||||
 | 
					indio,um-335ax|\
 | 
				
			||||||
 | 
					indio,um-525axm|\
 | 
				
			||||||
 | 
					indio,um-525axp)
 | 
				
			||||||
 | 
						ucidef_set_led_wlan "wlan2g" "WLAN2G" "led_2g" "phy0tpt"
 | 
				
			||||||
 | 
						ucidef_set_led_wlan "wlan5g" "WLAN5G" "led_5g" "phy1tpt"
 | 
				
			||||||
 | 
						ucidef_set_led_default "power" "POWER" "led_sys" "on"
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
cig,wf186h|\
 | 
					cig,wf186h|\
 | 
				
			||||||
cig,wf186w)
 | 
					cig,wf186w)
 | 
				
			||||||
        ucidef_set_led_default "power" "POWER" "green:status" "on"
 | 
					        ucidef_set_led_default "power" "POWER" "green:status" "on"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -48,6 +48,15 @@ qcom_setup_interfaces()
 | 
				
			|||||||
		ucidef_add_switch "switch1" \
 | 
							ucidef_add_switch "switch1" \
 | 
				
			||||||
			"6u@eth1" "1:lan" "2:lan" "3:lan" "4:lan"
 | 
								"6u@eth1" "1:lan" "2:lan" "3:lan" "4:lan"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
 | 
						indio,um-325ax-v2|\
 | 
				
			||||||
 | 
						indio,um-335ax|\
 | 
				
			||||||
 | 
						indio,um-525axm|\
 | 
				
			||||||
 | 
						indio,um-525axp)
 | 
				
			||||||
 | 
							ucidef_set_interface_wan "eth1"
 | 
				
			||||||
 | 
							ucidef_set_interface_lan "eth0"
 | 
				
			||||||
 | 
							ucidef_add_switch "switch1" \
 | 
				
			||||||
 | 
								"6@eth1" "1:lan" "2:lan" "3:lan" "4:lan"
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
	emplus,wap385c|\
 | 
						emplus,wap385c|\
 | 
				
			||||||
	hfcl,ion4x_w|\
 | 
						hfcl,ion4x_w|\
 | 
				
			||||||
	hfcl,ion4xi_w)
 | 
						hfcl,ion4xi_w)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -142,6 +142,10 @@ ath11k/IPQ5018/hw1.0/caldata.bin)
 | 
				
			|||||||
	emplus,wap385c|\
 | 
						emplus,wap385c|\
 | 
				
			||||||
	hfcl,ion4x_w|\
 | 
						hfcl,ion4x_w|\
 | 
				
			||||||
	hfcl,ion4xi_w|\
 | 
						hfcl,ion4xi_w|\
 | 
				
			||||||
 | 
						indio,um-325ax-v2|\
 | 
				
			||||||
 | 
						indio,um-335ax|\
 | 
				
			||||||
 | 
						indio,um-525axm|\
 | 
				
			||||||
 | 
						indio,um-525axp|\
 | 
				
			||||||
	optimcloud,d60|\
 | 
						optimcloud,d60|\
 | 
				
			||||||
	optimcloud,d60-5g|\
 | 
						optimcloud,d60-5g|\
 | 
				
			||||||
	optimcloud,d50|\
 | 
						optimcloud,d50|\
 | 
				
			||||||
@@ -183,6 +187,9 @@ ath11k/qcn6122/hw1.0/caldata_1.bin)
 | 
				
			|||||||
	;;
 | 
						;;
 | 
				
			||||||
ath11k/qcn6122/hw1.0/caldata_2.bin)
 | 
					ath11k/qcn6122/hw1.0/caldata_2.bin)
 | 
				
			||||||
	case "$board" in
 | 
						case "$board" in
 | 
				
			||||||
 | 
						indio,um-325ax-v2|\
 | 
				
			||||||
 | 
						indio,um-525axm|\
 | 
				
			||||||
 | 
						indio,um-525axp|\
 | 
				
			||||||
	wallys,dr5018|\
 | 
						wallys,dr5018|\
 | 
				
			||||||
	edgecore,eap104|\
 | 
						edgecore,eap104|\
 | 
				
			||||||
	edgecore,oap101-6e|\
 | 
						edgecore,oap101-6e|\
 | 
				
			||||||
@@ -201,6 +208,7 @@ ath11k/qcn6122/hw1.0/caldata_2.bin)
 | 
				
			|||||||
	;;
 | 
						;;
 | 
				
			||||||
ath11k/QCN9074/hw1.0/caldata_1.bin)
 | 
					ath11k/QCN9074/hw1.0/caldata_1.bin)
 | 
				
			||||||
	case "$board" in
 | 
						case "$board" in
 | 
				
			||||||
 | 
						indio,um-335ax|\
 | 
				
			||||||
	optimcloud,d60|\
 | 
						optimcloud,d60|\
 | 
				
			||||||
	optimcloud,d60-5g|\
 | 
						optimcloud,d60-5g|\
 | 
				
			||||||
	optimcloud,d50|\
 | 
						optimcloud,d50|\
 | 
				
			||||||
@@ -234,6 +242,9 @@ ath11k-macs)
 | 
				
			|||||||
	edgecore,oap101|\
 | 
						edgecore,oap101|\
 | 
				
			||||||
	edgecore,oap101-6e|\
 | 
						edgecore,oap101-6e|\
 | 
				
			||||||
	edgecore,oap101e-6e|\
 | 
						edgecore,oap101e-6e|\
 | 
				
			||||||
 | 
						indio,um-325ax-v2|\
 | 
				
			||||||
 | 
						indio,um-525axp|\
 | 
				
			||||||
 | 
						indio,um-525axm|\
 | 
				
			||||||
	optimcloud,d60|\
 | 
						optimcloud,d60|\
 | 
				
			||||||
	optimcloud,d60-5g|\
 | 
						optimcloud,d60-5g|\
 | 
				
			||||||
	optimcloud,d50|\
 | 
						optimcloud,d50|\
 | 
				
			||||||
@@ -251,6 +262,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
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -81,6 +81,10 @@ platform_check_image() {
 | 
				
			|||||||
	wallys,dr5018|\
 | 
						wallys,dr5018|\
 | 
				
			||||||
	hfcl,ion4x_w|\
 | 
						hfcl,ion4x_w|\
 | 
				
			||||||
	hfcl,ion4xi_w|\
 | 
						hfcl,ion4xi_w|\
 | 
				
			||||||
 | 
						indio,um-325ax-v2|\
 | 
				
			||||||
 | 
						indio,um-335ax|\
 | 
				
			||||||
 | 
						indio,um-525axp|\
 | 
				
			||||||
 | 
						indio,um-525axm|\
 | 
				
			||||||
	optimcloud,d60|\
 | 
						optimcloud,d60|\
 | 
				
			||||||
	optimcloud,d60-5g|\
 | 
						optimcloud,d60-5g|\
 | 
				
			||||||
	optimcloud,d50|\
 | 
						optimcloud,d50|\
 | 
				
			||||||
@@ -107,12 +111,29 @@ platform_do_upgrade() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	board=$(board_name)
 | 
						board=$(board_name)
 | 
				
			||||||
	case $board in
 | 
						case $board in
 | 
				
			||||||
	glinet,b3000|\
 | 
						indio,um-325ax-v2|\
 | 
				
			||||||
 | 
						indio,um-335ax|\
 | 
				
			||||||
 | 
						indio,um-525axp|\
 | 
				
			||||||
 | 
						indio,um-525axm|\
 | 
				
			||||||
	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,941 @@
 | 
				
			|||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					/* Copyright (c) 2018-2020, The Linux Foundation. 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.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "ipq5018.dtsi"
 | 
				
			||||||
 | 
					#include <dt-bindings/input/input.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						#address-cells = <0x2>;
 | 
				
			||||||
 | 
						#size-cells = <0x2>;
 | 
				
			||||||
 | 
						model = "Indio UM-325AX V2";
 | 
				
			||||||
 | 
						compatible = "indio,um-325ax-v2", "qcom,ipq5018-mp03.5-c1", "qcom,ipq5018";
 | 
				
			||||||
 | 
						interrupt-parent = <&intc>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aliases {
 | 
				
			||||||
 | 
							sdhc1 = &sdhc_1; /* SDC1 eMMC slot */
 | 
				
			||||||
 | 
							serial0 = &blsp1_uart1;
 | 
				
			||||||
 | 
							serial1 = &blsp1_uart2;
 | 
				
			||||||
 | 
							ethernet0 = "/soc/dp1";
 | 
				
			||||||
 | 
							ethernet1 = "/soc/dp2";
 | 
				
			||||||
 | 
					                //led-failsafe = &led_red;
 | 
				
			||||||
 | 
					                //led-running = &led_green;
 | 
				
			||||||
 | 
					                //led-upgrade = &led_green;
 | 
				
			||||||
 | 
					                //led-gateway = &led_blue;
 | 
				
			||||||
 | 
					                //led-factory = &led_blue;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						chosen {
 | 
				
			||||||
 | 
							bootargs = "console=ttyMSM0,115200,n8 rw init=/init";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							bootargs-append = " swiotlb=1";
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							bootargs-append = " swiotlb=1 coherent_pool=2M";
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
							stdout-path = "serial0";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reserved-memory {
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						/*                   256 MB Profile
 | 
				
			||||||
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * |  Region  | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    NSS   |  0x40000000  |           8MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   Linux  |  0x40800000  | Depends on total memory |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   uboot  |  0x4A600000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    SBL   |  0x4AA00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   smem   |  0x4AB00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    TZ    |  0x4AC00000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    Q6    |              |                         |
 | 
				
			||||||
 | 
						 * |   code/  |  0x4B000000  |          20MB           |
 | 
				
			||||||
 | 
						 * |   data   |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4C400000  |          13MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4D100000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4D200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4D300000  |          15MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4E200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4E300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4E400000  |          15MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4F300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4F400000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * |            Rest of the memory for Linux           |
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * +===================================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x4500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x1400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5018_data: q6_ipq5018_data@4C400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C400000 0x0 0xD00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D100000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D100000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data1: q6_qcn6122_data1@4D300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D300000 0x0 0xF00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_1: m3_dump_qcn6122_1@4E200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_1: q6_qcn6122_etr_1@4E300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data2: q6_qcn6122_data2@4E400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E400000 0x0 0xF00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_2: m3_dump_qcn6122_2@4F300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_2: q6_qcn6122_etr_2@4F400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F400000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
						/*                 512MB/1GB Profiles
 | 
				
			||||||
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * |  Region  | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    NSS   |  0x40000000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   Linux  |  0x41000000  | Depends on total memory |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   uboot  |  0x4A600000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    SBL   |  0x4AA00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   smem   |  0x4AB00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    TZ    |  0x4AC00000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    Q6    |              |                         |
 | 
				
			||||||
 | 
						 * |   code/  |  0x4B000000  |          20MB           |
 | 
				
			||||||
 | 
						 * |   data   |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4C400000  |          14MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4D200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4D300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4D400000  |           2MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4D600000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4E600000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4E700000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4E800000  |           5MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4ED00000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4FD00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4FE00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4FF00000  |           5MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * |            Rest of the memory for Linux           |
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * +===================================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x5400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 01400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5018_data: q6_ipq5018_data@4C400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C400000 0x0 0xE00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_caldb_region: q6_caldb_region@4D400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D400000 0x0 0x200000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data1: q6_qcn6122_data1@4D600000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D600000 0x0 0x1000000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_1: m3_dump_qcn6122_1@4E600000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E600000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_1: q6_qcn6122_etr_1@4E700000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E700000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_caldb_1: q6_qcn6122_caldb_1@4E800000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E800000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data2: q6_qcn6122_data2@4E900000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4ED00000 0x0 0x1000000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_2: m3_dump_qcn6122_2@4FD00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FD00000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_2: q6_qcn6122_etr_2@4FE00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FE00000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_caldb_2: q6_qcn6122_caldb_2@4FF00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FF00000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						soc {
 | 
				
			||||||
 | 
							gpio-watchdog {
 | 
				
			||||||
 | 
								compatible = "linux,wdt-gpio";
 | 
				
			||||||
 | 
								gpios = <&tlmm 27 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								hw_algo = "toggle";
 | 
				
			||||||
 | 
								hw_margin_ms = <5000>;
 | 
				
			||||||
 | 
								always-running;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							serial@78af000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							blsp1_uart2: serial@78b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp1_uart_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qpic_bam: dma@7984000{
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nand: qpic-nand@79b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&qspi_nand_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							spi_0: spi@78b5000 { /* BLSP1 QUP0 */
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp0_spi_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								cs-select = <0>;
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								m25p80@0 {
 | 
				
			||||||
 | 
									#address-cells = <1>;
 | 
				
			||||||
 | 
									#size-cells = <1>;
 | 
				
			||||||
 | 
									reg = <0>;
 | 
				
			||||||
 | 
									compatible = "n25q128a11";
 | 
				
			||||||
 | 
									linux,modalias = "m25p80", "n25q128a11";
 | 
				
			||||||
 | 
									spi-max-frequency = <50000000>;
 | 
				
			||||||
 | 
									use-default-sizes;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio0: mdio@88000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <7>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio1: mdio@90000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
								pinctrl-0 = <&mdio1_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								phy-reset-gpio = <&tlmm 39 0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <28>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ess-instance {
 | 
				
			||||||
 | 
								num_devices = <0x1>;
 | 
				
			||||||
 | 
								ess-switch@0x39c00000 {
 | 
				
			||||||
 | 
									switch_mac_mode = <0xf>; /* mac mode for uniphy instance*/
 | 
				
			||||||
 | 
									cmnblk_clk = "internal_96MHz"; /* cmnblk clk*/
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <7>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio0>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@1 {
 | 
				
			||||||
 | 
											port_id = <2>;
 | 
				
			||||||
 | 
											phy_address = <0x1c>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
											port_mac_sel = "QGMAC_PORT";
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
									led_source@0 {
 | 
				
			||||||
 | 
										source = <0>;
 | 
				
			||||||
 | 
										mode = "normal";
 | 
				
			||||||
 | 
										speed = "all";
 | 
				
			||||||
 | 
										blink_en = "enable";
 | 
				
			||||||
 | 
										active = "high";
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
									ess-switch1@1 {
 | 
				
			||||||
 | 
									compatible = "qcom,ess-switch-qca83xx";
 | 
				
			||||||
 | 
									device_id = <1>;
 | 
				
			||||||
 | 
									switch_access_mode = "mdio";
 | 
				
			||||||
 | 
									mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
									reset_gpio = <0x28>;
 | 
				
			||||||
 | 
									switch_cpu_bmp = <0x40>;  /* cpu port bitmap */
 | 
				
			||||||
 | 
									switch_lan_bmp = <0x1e>; /* lan port bitmap */
 | 
				
			||||||
 | 
									switch_wan_bmp = <0x0>;  /* wan port bitmap */
 | 
				
			||||||
 | 
									qca,ar8327-initvals = <
 | 
				
			||||||
 | 
											0x00004 0x7600000   /* PAD0_MODE */
 | 
				
			||||||
 | 
											0x00008 0x1000000   /* PAD5_MODE */
 | 
				
			||||||
 | 
											0x0000c 0x80        /* PAD6_MODE */
 | 
				
			||||||
 | 
											0x00010 0x2613a0    /* PORT6 FORCE MODE*/
 | 
				
			||||||
 | 
											0x000e4 0xaa545     /* MAC_POWER_SEL */
 | 
				
			||||||
 | 
											0x000e0 0xc74164de  /* SGMII_CTRL */
 | 
				
			||||||
 | 
											0x0007c 0x4e        /* PORT0_STATUS */
 | 
				
			||||||
 | 
											0x00094 0x4e        /* PORT6_STATUS */
 | 
				
			||||||
 | 
									>;
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <28>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp1 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC0_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <1>;
 | 
				
			||||||
 | 
								reg = <0x39C00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <7>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio0>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp2 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC1_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <2>;
 | 
				
			||||||
 | 
								reg = <0x39D00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <28>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,test@0 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nss-macsec1 {
 | 
				
			||||||
 | 
								compatible = "qcom,nss-macsec";
 | 
				
			||||||
 | 
								phy_addr = <0x1c>;
 | 
				
			||||||
 | 
								mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							lpass: lpass@0xA000000{
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm: pcm@0xA3C0000{
 | 
				
			||||||
 | 
								pinctrl-0 = <&audio_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm_lb: pcm_lb@0 {
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						thermal-zones {
 | 
				
			||||||
 | 
							status = "ok";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
						pinctrl-0 = <&blsp0_uart_pins &phy_led_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_uart_pins: uart_pins {
 | 
				
			||||||
 | 
							blsp0_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio20", "gpio21";
 | 
				
			||||||
 | 
								function = "blsp0_uart0";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp1_uart_pins: blsp1_uart_pins {
 | 
				
			||||||
 | 
							blsp1_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio22", "gpio24", "gpio23", "gpio25";
 | 
				
			||||||
 | 
								function = "blsp1_uart2";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_spi_pins: blsp0_spi_pins {
 | 
				
			||||||
 | 
							mux {
 | 
				
			||||||
 | 
								pins = "gpio10", "gpio11", "gpio12", "gpio13";
 | 
				
			||||||
 | 
								function = "blsp0_spi";
 | 
				
			||||||
 | 
								drive-strength = <2>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qspi_nand_pins: qspi_nand_pins {
 | 
				
			||||||
 | 
							qspi_clock {
 | 
				
			||||||
 | 
								pins = "gpio9";
 | 
				
			||||||
 | 
								function = "qspi_clk";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_cs {
 | 
				
			||||||
 | 
								pins = "gpio8";
 | 
				
			||||||
 | 
								function = "qspi_cs";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_0 {
 | 
				
			||||||
 | 
								pins = "gpio7";
 | 
				
			||||||
 | 
								function = "qspi0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_1 {
 | 
				
			||||||
 | 
								pins = "gpio6";
 | 
				
			||||||
 | 
								function = "qspi1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_2 {
 | 
				
			||||||
 | 
								pins = "gpio5";
 | 
				
			||||||
 | 
								function = "qspi2";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_3 {
 | 
				
			||||||
 | 
								pins = "gpio4";
 | 
				
			||||||
 | 
								function = "qspi3";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mdio1_pins: mdio_pinmux {
 | 
				
			||||||
 | 
							mux_0 {
 | 
				
			||||||
 | 
								pins = "gpio36";
 | 
				
			||||||
 | 
								function = "mdc";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mux_1 {
 | 
				
			||||||
 | 
								pins = "gpio37";
 | 
				
			||||||
 | 
								function = "mdio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						phy_led_pins: phy_led_pins {
 | 
				
			||||||
 | 
							gephy_led_pin {
 | 
				
			||||||
 | 
								pins = "gpio46";
 | 
				
			||||||
 | 
								function = "led0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						i2c_pins: i2c_pins {
 | 
				
			||||||
 | 
							i2c_scl {
 | 
				
			||||||
 | 
								pins = "gpio25";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							i2c_sda {
 | 
				
			||||||
 | 
								pins = "gpio26";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						button_pins: button_pins {
 | 
				
			||||||
 | 
							reset_button {
 | 
				
			||||||
 | 
								pins = "gpio38";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					audio_pins: audio_pinmux {
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					        leds_pins: leds_pins {
 | 
				
			||||||
 | 
					                led_5g {
 | 
				
			||||||
 | 
					                        pins = "gpio34";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_2g {
 | 
				
			||||||
 | 
					                        pins = "gpio33";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_sys {
 | 
				
			||||||
 | 
					                        pins = "gpio26";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
							led_onekey {
 | 
				
			||||||
 | 
					                        pins = "gpio28";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
						gpio_keys {
 | 
				
			||||||
 | 
							compatible = "gpio-keys";
 | 
				
			||||||
 | 
							pinctrl-0 = <&button_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							button@1 {
 | 
				
			||||||
 | 
								label = "reset";
 | 
				
			||||||
 | 
								linux,code = <KEY_RESTART>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 38 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,input-type = <1>;
 | 
				
			||||||
 | 
								debounce-interval = <60>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        leds {
 | 
				
			||||||
 | 
					                compatible = "gpio-leds";
 | 
				
			||||||
 | 
					                pinctrl-0 = <&leds_pins>;
 | 
				
			||||||
 | 
					                pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                led_blue: led@34 {
 | 
				
			||||||
 | 
					                        label = "led_5g";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 34 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_5g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_green: led@33 {
 | 
				
			||||||
 | 
					                        label = "led_2g";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 33 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_2g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_red: led@26 {
 | 
				
			||||||
 | 
					                        label = "led_sys";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 26 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_sys";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
							led@28 {
 | 
				
			||||||
 | 
					                        label = "led_onekey";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 28 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_onekey";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&q6v5_wcss {
 | 
				
			||||||
 | 
						compatible = "qcom,ipq5018-q6-mpd";
 | 
				
			||||||
 | 
						#address-cells = <1>;
 | 
				
			||||||
 | 
						#size-cells = <1>;
 | 
				
			||||||
 | 
						ranges;
 | 
				
			||||||
 | 
						firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
						reg = <0x0cd00000 0x4040>,
 | 
				
			||||||
 | 
							<0x1938000 0x8>,
 | 
				
			||||||
 | 
							<0x193d204 0x4>;
 | 
				
			||||||
 | 
						reg-names = "qdsp6",
 | 
				
			||||||
 | 
								"tcsr-msip",
 | 
				
			||||||
 | 
								"tcsr-q6";
 | 
				
			||||||
 | 
						resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
								<&gcc GCC_WCSS_Q6_BCR>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
								"wcss_q6_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						clocks = <&gcc GCC_Q6_AXIS_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_ECAHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM2_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_S_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_AXI_S_CLK>;
 | 
				
			||||||
 | 
						clock-names = "gcc_q6_axis_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_ecahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim2_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_s_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_axi_s_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_mem_regions>, <&q6_etr_region>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_mem_regions>, <&q6_etr_region>,
 | 
				
			||||||
 | 
									<&q6_caldb_region>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qcom,rproc = <&q6v5_wcss>;
 | 
				
			||||||
 | 
						qcom,bootargs_smem = <507>;
 | 
				
			||||||
 | 
						boot-args = <0x1 0x4 0x3 0x0F 0x0 0x0>,
 | 
				
			||||||
 | 
								<0x2 0x4 0x2 0x12 0x0 0x0>;
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						q6_wcss_pd1: remoteproc_pd1@4ab000 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-ahb-mpd";
 | 
				
			||||||
 | 
							reg = <0x4ab000 0x20>;
 | 
				
			||||||
 | 
							reg-names = "rmb";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							m3_firmware = "IPQ5018/m3_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 8 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 9 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 12 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 11 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_BCR>,
 | 
				
			||||||
 | 
									<&gcc GCC_CE_BCR>;
 | 
				
			||||||
 | 
							reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
									"wcss_reset",
 | 
				
			||||||
 | 
									"ce_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							clocks = <&gcc GCC_WCSS_AHB_S_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_ACMT_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_AXI_M_CLK>;
 | 
				
			||||||
 | 
							clock-names = "gcc_wcss_ahb_s_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_acmt_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_axi_m_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,halt-regs = <&tcsr_q6_block 0xa000 0xd000 0x0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 8>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 9>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 10>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_ipq5018_data>, <&m3_dump>,
 | 
				
			||||||
 | 
									<&q6_etr_region>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_ipq5018_data>, <&m3_dump>,
 | 
				
			||||||
 | 
									<&q6_etr_region>, <&q6_caldb_region>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						q6_wcss_pd2: remoteproc_pd2 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-pcie-mpd";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							m3_firmware = "qcn6122/m3_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 16 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 17 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 20 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 19 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 16>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 17>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 18>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data1>, <&m3_dump_qcn6122_1>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_1>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data1>, <&m3_dump_qcn6122_1>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_1>, <&q6_qcn6122_caldb_1>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						q6_wcss_pd3: remoteproc_pd3 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-pcie-mpd";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 24 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 25 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 28 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 27 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 24>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 25>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 26>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef	__IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data2>, <&m3_dump_qcn6122_2>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_2>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data2>, <&m3_dump_qcn6122_2>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_2>, <&q6_qcn6122_caldb_2>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_0 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&i2c_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi0 {
 | 
				
			||||||
 | 
						/* IPQ5018 */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd1>;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd1";
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x24>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4C400000 0x4C400000 0x4C400000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4D400000 0x4D400000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x200000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi1 {
 | 
				
			||||||
 | 
						/* QCN6122 5G */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd2";
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd2>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x50>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4D600000 0x4D600000 0x4D300000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4E800000 0x4E800000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6122_data1>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6122_data1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi2 {
 | 
				
			||||||
 | 
						/* QCN6122 6G */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd3";
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd3>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0xb0>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4ED00000 0x4ED00000 0x4E400000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4FF00000 0x4FF00000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6122_data2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6122_data2>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&usb3 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						device-power-gpio = <&tlmm 24 1>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&dwc_0 {
 | 
				
			||||||
 | 
						/delete-property/ #phy-cells;
 | 
				
			||||||
 | 
						/delete-property/ phys;
 | 
				
			||||||
 | 
						/delete-property/ phy-names;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					&hs_m31phy_0 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&eud {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1 {
 | 
				
			||||||
 | 
						#status = "disabled";
 | 
				
			||||||
 | 
						#perst-gpio = <&tlmm 18 1>;
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 18 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2 {
 | 
				
			||||||
 | 
						#status = "disabled";
 | 
				
			||||||
 | 
						#perst-gpio = <&tlmm 15 1>;
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 15 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1_rp {
 | 
				
			||||||
 | 
					        status = "disabled";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_0: qcom,mhi@0 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2_rp {
 | 
				
			||||||
 | 
					        status = "disabled";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_1: qcom,mhi@1 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -0,0 +1,731 @@
 | 
				
			|||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					/* Copyright (c) 2018-2020, The Linux Foundation. All rights reserved.
 | 
				
			||||||
 | 
					 * Copyright (c) 2025, Shubham Vishwakarma <shubhamvis98@fossfrog.in>.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * 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.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "ipq5018.dtsi"
 | 
				
			||||||
 | 
					#include <dt-bindings/input/input.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						#address-cells = <0x2>;
 | 
				
			||||||
 | 
						#size-cells = <0x2>;
 | 
				
			||||||
 | 
						model = "Indio UM-335AX";
 | 
				
			||||||
 | 
						compatible = "indio,um-335ax", "qcom,ipq5018-ap-mp03.1", "qcom,ipq5018-mp03.1", "qcom,ipq5018";
 | 
				
			||||||
 | 
						interrupt-parent = <&intc>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aliases {
 | 
				
			||||||
 | 
							sdhc1 = &sdhc_1; /* SDC1 eMMC slot */
 | 
				
			||||||
 | 
							serial0 = &blsp1_uart1;
 | 
				
			||||||
 | 
							serial1 = &blsp1_uart2;
 | 
				
			||||||
 | 
							ethernet0 = "/soc/dp1";
 | 
				
			||||||
 | 
							ethernet1 = "/soc/dp2";
 | 
				
			||||||
 | 
							led-boot = &led_red;
 | 
				
			||||||
 | 
							led-failsafe = &led_red;
 | 
				
			||||||
 | 
							led-running = &led_red;
 | 
				
			||||||
 | 
							led-upgrade = &led_red;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						chosen {
 | 
				
			||||||
 | 
							bootargs = "console=ttyMSM0,115200,n8 rw init=/init";
 | 
				
			||||||
 | 
							bootargs-append = " swiotlb=1 coherent_pool=2M";
 | 
				
			||||||
 | 
							stdout-path = "serial0";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						gpio-watchdog {
 | 
				
			||||||
 | 
							compatible = "linux,wdt-gpio";
 | 
				
			||||||
 | 
							gpios = <&tlmm 27 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
							hw_algo = "toggle";
 | 
				
			||||||
 | 
							hw_margin_ms = <5000>;
 | 
				
			||||||
 | 
							always-running;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reserved-memory {
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x1800000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5018_data: q6_ipq5018_data@4C400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C400000 0x0 0xE00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4C800000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C800000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4C900000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C900000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_caldb_region: q6_caldb_region@4CA00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4CA00000 0x0 0x200000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcn9000_pcie0: qcn9000_pcie0@4cc00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4CC00000 0x0 0x2600000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#if defined(__CNSS2__)
 | 
				
			||||||
 | 
							mhi_region1: dma_pool1@4F200000 {
 | 
				
			||||||
 | 
								compatible = "shared-dma-pool";
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F200000 0x0 0x900000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						soc {
 | 
				
			||||||
 | 
							serial@78af000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							blsp1_uart2: serial@78b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp1_uart_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qpic_bam: dma@7984000{
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nand: qpic-nand@79b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&qspi_nand_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							spi_0: spi@78b5000 { /* BLSP1 QUP0 */
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp0_spi_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								cs-select = <0>;
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								m25p80@0 {
 | 
				
			||||||
 | 
									#address-cells = <1>;
 | 
				
			||||||
 | 
									#size-cells = <1>;
 | 
				
			||||||
 | 
									reg = <0>;
 | 
				
			||||||
 | 
									compatible = "n25q128a11";
 | 
				
			||||||
 | 
									linux,modalias = "m25p80", "n25q128a11";
 | 
				
			||||||
 | 
									spi-max-frequency = <50000000>;
 | 
				
			||||||
 | 
									use-default-sizes;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio0: mdio@88000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <7>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio1: mdio@90000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
								pinctrl-0 = <&mdio1_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								phy-reset-gpio = <&tlmm 39 0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <28>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ess-instance {
 | 
				
			||||||
 | 
								num_devices = <0x1>;
 | 
				
			||||||
 | 
								ess-switch@0x39c00000 {
 | 
				
			||||||
 | 
									switch_mac_mode = <0xf>; /* mac mode for uniphy instance*/
 | 
				
			||||||
 | 
									cmnblk_clk = "internal_96MHz"; /* cmnblk clk*/
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <7>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio0>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@1 {
 | 
				
			||||||
 | 
											port_id = <2>;
 | 
				
			||||||
 | 
											phy_address = <0x1c>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
											port_mac_sel = "QGMAC_PORT";
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
									led_source@0 {
 | 
				
			||||||
 | 
										source = <0>;
 | 
				
			||||||
 | 
										mode = "normal";
 | 
				
			||||||
 | 
										speed = "all";
 | 
				
			||||||
 | 
										blink_en = "enable";
 | 
				
			||||||
 | 
										active = "high";
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
									ess-switch1@1 {
 | 
				
			||||||
 | 
									compatible = "qcom,ess-switch-qca83xx";
 | 
				
			||||||
 | 
									device_id = <1>;
 | 
				
			||||||
 | 
									switch_access_mode = "mdio";
 | 
				
			||||||
 | 
									mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
									reset_gpio = <0x28>;
 | 
				
			||||||
 | 
									switch_cpu_bmp = <0x40>;  /* cpu port bitmap */
 | 
				
			||||||
 | 
									switch_lan_bmp = <0x1e>; /* lan port bitmap */
 | 
				
			||||||
 | 
									switch_wan_bmp = <0x0>;  /* wan port bitmap */
 | 
				
			||||||
 | 
									qca,ar8327-initvals = <
 | 
				
			||||||
 | 
											0x00004 0x7600000   /* PAD0_MODE */
 | 
				
			||||||
 | 
											0x00008 0x1000000   /* PAD5_MODE */
 | 
				
			||||||
 | 
											0x0000c 0x80        /* PAD6_MODE */
 | 
				
			||||||
 | 
											0x00010 0x2613a0    /* PORT6 FORCE MODE*/
 | 
				
			||||||
 | 
											0x000e4 0xaa545     /* MAC_POWER_SEL */
 | 
				
			||||||
 | 
											0x000e0 0xc74164de  /* SGMII_CTRL */
 | 
				
			||||||
 | 
											0x0007c 0x4e        /* PORT0_STATUS */
 | 
				
			||||||
 | 
											0x00094 0x4e        /* PORT6_STATUS */
 | 
				
			||||||
 | 
									>;
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <28>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp1 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC0_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <1>;
 | 
				
			||||||
 | 
								reg = <0x39C00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <7>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio0>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp2 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC1_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <2>;
 | 
				
			||||||
 | 
								reg = <0x39D00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <28>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,test@0 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nss-macsec1 {
 | 
				
			||||||
 | 
								compatible = "qcom,nss-macsec";
 | 
				
			||||||
 | 
								phy_addr = <0x1c>;
 | 
				
			||||||
 | 
								mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							lpass: lpass@0xA000000{
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm: pcm@0xA3C0000{
 | 
				
			||||||
 | 
								pinctrl-0 = <&audio_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm_lb: pcm_lb@0 {
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						thermal-zones {
 | 
				
			||||||
 | 
							status = "ok";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
						pinctrl-0 = <&blsp0_uart_pins &phy_led_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_uart_pins: uart_pins {
 | 
				
			||||||
 | 
							blsp0_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio20", "gpio21";
 | 
				
			||||||
 | 
								function = "blsp0_uart0";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp1_uart_pins: blsp1_uart_pins {
 | 
				
			||||||
 | 
							blsp1_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio22", "gpio24", "gpio23", "gpio25";
 | 
				
			||||||
 | 
								function = "blsp1_uart2";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_spi_pins: blsp0_spi_pins {
 | 
				
			||||||
 | 
							mux {
 | 
				
			||||||
 | 
								pins = "gpio10", "gpio11", "gpio12", "gpio13";
 | 
				
			||||||
 | 
								function = "blsp0_spi";
 | 
				
			||||||
 | 
								drive-strength = <2>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qspi_nand_pins: qspi_nand_pins {
 | 
				
			||||||
 | 
							qspi_clock {
 | 
				
			||||||
 | 
								pins = "gpio9";
 | 
				
			||||||
 | 
								function = "qspi_clk";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_cs {
 | 
				
			||||||
 | 
								pins = "gpio8";
 | 
				
			||||||
 | 
								function = "qspi_cs";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_0 {
 | 
				
			||||||
 | 
								pins = "gpio7";
 | 
				
			||||||
 | 
								function = "qspi0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_1 {
 | 
				
			||||||
 | 
								pins = "gpio6";
 | 
				
			||||||
 | 
								function = "qspi1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_2 {
 | 
				
			||||||
 | 
								pins = "gpio5";
 | 
				
			||||||
 | 
								function = "qspi2";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_3 {
 | 
				
			||||||
 | 
								pins = "gpio4";
 | 
				
			||||||
 | 
								function = "qspi3";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mdio1_pins: mdio_pinmux {
 | 
				
			||||||
 | 
							mux_0 {
 | 
				
			||||||
 | 
								pins = "gpio36";
 | 
				
			||||||
 | 
								function = "mdc";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mux_1 {
 | 
				
			||||||
 | 
								pins = "gpio37";
 | 
				
			||||||
 | 
								function = "mdio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						phy_led_pins: phy_led_pins {
 | 
				
			||||||
 | 
							gephy_led_pin {
 | 
				
			||||||
 | 
								pins = "gpio46";
 | 
				
			||||||
 | 
								function = "led0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						i2c_pins: i2c_pins {
 | 
				
			||||||
 | 
							i2c_scl {
 | 
				
			||||||
 | 
								pins = "gpio25";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							i2c_sda {
 | 
				
			||||||
 | 
								pins = "gpio26";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						button_pins: button_pins {
 | 
				
			||||||
 | 
							reset_button {
 | 
				
			||||||
 | 
								pins = "gpio38";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						audio_pins: audio_pinmux {
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						leds_pins: leds_pins {
 | 
				
			||||||
 | 
							led_blue: led_5g {
 | 
				
			||||||
 | 
								label = "led_5g";
 | 
				
			||||||
 | 
								pins = "gpio34";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_green: led_2g {
 | 
				
			||||||
 | 
								label = "led_2g";
 | 
				
			||||||
 | 
								pins = "gpio33";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_red: led_sys {
 | 
				
			||||||
 | 
								label = "led_sys";
 | 
				
			||||||
 | 
								pins = "gpio26";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_onekey {
 | 
				
			||||||
 | 
								pins = "gpio28";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
						gpio_keys {
 | 
				
			||||||
 | 
							compatible = "gpio-keys";
 | 
				
			||||||
 | 
							pinctrl-0 = <&button_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							button@1 {
 | 
				
			||||||
 | 
								label = "reset";
 | 
				
			||||||
 | 
								linux,code = <KEY_RESTART>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 38 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,input-type = <1>;
 | 
				
			||||||
 | 
								debounce-interval = <60>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						leds {
 | 
				
			||||||
 | 
							compatible = "gpio-leds";
 | 
				
			||||||
 | 
							pinctrl-0 = <&leds_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led@33 {
 | 
				
			||||||
 | 
								label = "led_5g";
 | 
				
			||||||
 | 
								gpios = <&tlmm 34 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,default-trigger = "led_5g";
 | 
				
			||||||
 | 
								default-state = "off";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							led@34 {
 | 
				
			||||||
 | 
								label = "led_2g";
 | 
				
			||||||
 | 
								gpios = <&tlmm 33 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,default-trigger = "led_2g";
 | 
				
			||||||
 | 
								default-state = "off";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							led@26 {
 | 
				
			||||||
 | 
								label = "led_sys";
 | 
				
			||||||
 | 
								gpios = <&tlmm 26 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,default-trigger = "led_sys";
 | 
				
			||||||
 | 
								default-state = "on";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							led@28 {
 | 
				
			||||||
 | 
								label = "led_onekey";
 | 
				
			||||||
 | 
								gpios = <&tlmm 28 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,default-trigger = "led_onekey";
 | 
				
			||||||
 | 
								default-state = "off";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&q6v5_wcss {
 | 
				
			||||||
 | 
						compatible = "qcom,ipq5018-q6-mpd";
 | 
				
			||||||
 | 
						#address-cells = <1>;
 | 
				
			||||||
 | 
						#size-cells = <1>;
 | 
				
			||||||
 | 
						ranges;
 | 
				
			||||||
 | 
						firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
						reg = <0x0cd00000 0x4040>,
 | 
				
			||||||
 | 
							<0x1938000 0x8>,
 | 
				
			||||||
 | 
							<0x193d204 0x4>;
 | 
				
			||||||
 | 
						reg-names = "qdsp6",
 | 
				
			||||||
 | 
								"tcsr-msip",
 | 
				
			||||||
 | 
								"tcsr-q6";
 | 
				
			||||||
 | 
						resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
								<&gcc GCC_WCSS_Q6_BCR>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
								"wcss_q6_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						clocks = <&gcc GCC_Q6_AXIS_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_ECAHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM2_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_S_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_AXI_S_CLK>;
 | 
				
			||||||
 | 
						clock-names = "gcc_q6_axis_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_ecahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim2_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_s_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_axi_s_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						memory-region = <&q6_mem_regions>, <&q6_etr_region>,
 | 
				
			||||||
 | 
								<&q6_caldb_region>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qcom,rproc = <&q6v5_wcss>;
 | 
				
			||||||
 | 
						qcom,bootargs_smem = <507>;
 | 
				
			||||||
 | 
						boot-args = <0x1 0x4 0x3 0x0F 0x0 0x0>,
 | 
				
			||||||
 | 
								<0x2 0x4 0x2 0x12 0x0 0x0>;
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						q6_wcss_pd1: remoteproc_pd1@4ab000 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-ahb-mpd";
 | 
				
			||||||
 | 
							reg = <0x4ab000 0x20>;
 | 
				
			||||||
 | 
							reg-names = "rmb";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							m3_firmware = "IPQ5018/m3_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 8 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 9 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 12 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 11 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_BCR>,
 | 
				
			||||||
 | 
									<&gcc GCC_CE_BCR>;
 | 
				
			||||||
 | 
							reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
									"wcss_reset",
 | 
				
			||||||
 | 
									"ce_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							clocks = <&gcc GCC_WCSS_AHB_S_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_ACMT_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_AXI_M_CLK>;
 | 
				
			||||||
 | 
							clock-names = "gcc_wcss_ahb_s_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_acmt_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_axi_m_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,halt-regs = <&tcsr_q6_block 0xa000 0xd000 0x0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 8>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 9>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 10>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
							memory-region = <&q6_ipq5018_data>, <&m3_dump>,
 | 
				
			||||||
 | 
									<&q6_etr_region>, <&q6_caldb_region>;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_0 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&i2c_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						// status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&usb3 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						device-power-gpio = <&tlmm 24 1>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&dwc_0 {
 | 
				
			||||||
 | 
						/delete-property/ #phy-cells;
 | 
				
			||||||
 | 
						/delete-property/ phys;
 | 
				
			||||||
 | 
						/delete-property/ phy-names;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&blsp1_uart1 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&ssuniphy_0 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&hs_m31phy_0 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&eud {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1 {
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 18 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 15 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wcss {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2phy {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1_rp {
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_0: qcom,mhi@0 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2_rp {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_1: qcom,mhi@1 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
							qrtr_instance_id = <0x20>;
 | 
				
			||||||
 | 
							qti,disable-rddm-prealloc;
 | 
				
			||||||
 | 
							qti,rddm-seg-len = <0x1000>;
 | 
				
			||||||
 | 
							#address-cells = <0x2>;
 | 
				
			||||||
 | 
							#size-cells = <0x2>;
 | 
				
			||||||
 | 
					#if defined(__CNSS2__)
 | 
				
			||||||
 | 
							memory-region = <0>,<&mhi_region1>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
							base-addr = <0x4CB00000>;
 | 
				
			||||||
 | 
							m3-dump-addr = <0x4DF00000>;
 | 
				
			||||||
 | 
							etr-addr = <0x4E000000>;
 | 
				
			||||||
 | 
							qcom,caldb-addr = <0x4E100000>;
 | 
				
			||||||
 | 
							pageable-addr = <0x4E900000>;
 | 
				
			||||||
 | 
							qcom,tgt-mem-mode = <0x1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi0 {
 | 
				
			||||||
 | 
						/* IPQ5018 */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd1>;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd1";
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
						qcom,board_id = <0x24>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4C400000 0x4C400000 0x4C400000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4D400000 0x4D400000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x200000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi3 {
 | 
				
			||||||
 | 
						/* QCN9000 5G */
 | 
				
			||||||
 | 
						board_id = <0xa0>;
 | 
				
			||||||
 | 
						hremote_node = <&qcn9000_pcie0>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						/* QCN9000 tgt-mem-mode=2 layout - 17MB
 | 
				
			||||||
 | 
						 * +=========+==============+=========+
 | 
				
			||||||
 | 
						 * |  Region | Start Offset |   Size  |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | HREMOTE |  0x4C900000  |   11MB  |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | M3 Dump |  0x4D400000  |   1MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * |   ETR   |  0x4D500000  |   1MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | Pageable|  0x4D600000  |   4MB   |
 | 
				
			||||||
 | 
						 * +==================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						base-addr = <0x4C900000>;
 | 
				
			||||||
 | 
						m3-dump-addr = <0x4D400000>;
 | 
				
			||||||
 | 
						etr-addr = <0x4D500000>;
 | 
				
			||||||
 | 
						caldb-addr = <0>;
 | 
				
			||||||
 | 
						pageable-addr = <0x4D600000>;
 | 
				
			||||||
 | 
						caldb-size = <0>;
 | 
				
			||||||
 | 
						hremote-size = <0xB00000>;
 | 
				
			||||||
 | 
						tgt-mem-mode = <0x2>;
 | 
				
			||||||
 | 
						pageable-size = <0x400000>;
 | 
				
			||||||
 | 
					#elif __IPQ_MEM_PROFILE_512_MB__
 | 
				
			||||||
 | 
						/* QCN9000 tgt-mem-mode=1 layout - 26MB
 | 
				
			||||||
 | 
						 * +=========+==============+=========+
 | 
				
			||||||
 | 
						 * |  Region | Start Offset |   Size  |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | HREMOTE |  0x4CB00000  |   12MB  |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | M3 Dump |  0x4D700000  |   1MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * |   ETR   |  0x4D800000  |   1MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * |  Caldb  |  0x4D900000  |   8MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | Pageable|  0x4E100000  |   4MB   |
 | 
				
			||||||
 | 
						 * +==================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						base-addr = <0x4CB00000>;
 | 
				
			||||||
 | 
						m3-dump-addr = <0x4D700000>;
 | 
				
			||||||
 | 
						etr-addr = <0x4D800000>;
 | 
				
			||||||
 | 
						caldb-addr = <0x4D900000>;
 | 
				
			||||||
 | 
						pageable-addr = <0x4E100000>;
 | 
				
			||||||
 | 
						caldb-size = <0x800000>;
 | 
				
			||||||
 | 
						hremote-size = <0xC00000>;
 | 
				
			||||||
 | 
						tgt-mem-mode = <0x1>;
 | 
				
			||||||
 | 
						pageable-size = <0x400000>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						/* QCN9000 tgt-mem-mode=0 layout - 53MB
 | 
				
			||||||
 | 
						 * +=========+==============+=========+
 | 
				
			||||||
 | 
						 * |  Region | Start Offset |   Size  |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | HREMOTE |  0x4CB00000  |   35MB  |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | M3 Dump |  0x4EE00000  |   1MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * |   ETR   |  0x4EF00000  |   1MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * |  Caldb  |  0x4F000000  |   8MB   |
 | 
				
			||||||
 | 
						 * +---------+--------------+---------+
 | 
				
			||||||
 | 
						 * | Pageable|  0x4F800000  |   8MB   |
 | 
				
			||||||
 | 
						 * +==================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
						base-addr = <0x4CB00000>;
 | 
				
			||||||
 | 
						m3-dump-addr = <0x4EE00000>;
 | 
				
			||||||
 | 
						etr-addr = <0x4EF00000>;
 | 
				
			||||||
 | 
						caldb-addr = <0x4F000000>;
 | 
				
			||||||
 | 
						pageable-addr = <0x4F800000>;
 | 
				
			||||||
 | 
						hremote-size = <0x2300000>;
 | 
				
			||||||
 | 
						caldb-size = <0x800000>;
 | 
				
			||||||
 | 
						tgt-mem-mode = <0x0>;
 | 
				
			||||||
 | 
						pageable-size = <0x800000>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -0,0 +1,941 @@
 | 
				
			|||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					/* Copyright (c) 2018-2020, The Linux Foundation. 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.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "ipq5018.dtsi"
 | 
				
			||||||
 | 
					#include <dt-bindings/input/input.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						#address-cells = <0x2>;
 | 
				
			||||||
 | 
						#size-cells = <0x2>;
 | 
				
			||||||
 | 
						model = "Indio UM-525AXM";
 | 
				
			||||||
 | 
						compatible = "indio,um-525axm", "qcom,ipq5018-mp03.5-c1", "qcom,ipq5018";
 | 
				
			||||||
 | 
						interrupt-parent = <&intc>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aliases {
 | 
				
			||||||
 | 
							sdhc1 = &sdhc_1; /* SDC1 eMMC slot */
 | 
				
			||||||
 | 
							serial0 = &blsp1_uart1;
 | 
				
			||||||
 | 
							serial1 = &blsp1_uart2;
 | 
				
			||||||
 | 
							ethernet0 = "/soc/dp1";
 | 
				
			||||||
 | 
							ethernet1 = "/soc/dp2";
 | 
				
			||||||
 | 
					                //led-failsafe = &led_red;
 | 
				
			||||||
 | 
					                //led-running = &led_green;
 | 
				
			||||||
 | 
					                //led-upgrade = &led_green;
 | 
				
			||||||
 | 
					                //led-gateway = &led_blue;
 | 
				
			||||||
 | 
					                //led-factory = &led_blue;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						chosen {
 | 
				
			||||||
 | 
							bootargs = "console=ttyMSM0,115200,n8 rw init=/init";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							bootargs-append = " swiotlb=1";
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							bootargs-append = " swiotlb=1 coherent_pool=2M";
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
							stdout-path = "serial0";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reserved-memory {
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						/*                   256 MB Profile
 | 
				
			||||||
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * |  Region  | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    NSS   |  0x40000000  |           8MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   Linux  |  0x40800000  | Depends on total memory |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   uboot  |  0x4A600000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    SBL   |  0x4AA00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   smem   |  0x4AB00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    TZ    |  0x4AC00000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    Q6    |              |                         |
 | 
				
			||||||
 | 
						 * |   code/  |  0x4B000000  |          20MB           |
 | 
				
			||||||
 | 
						 * |   data   |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4C400000  |          13MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4D100000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4D200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4D300000  |          15MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4E200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4E300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4E400000  |          15MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4F300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4F400000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * |            Rest of the memory for Linux           |
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * +===================================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x4500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x1400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5018_data: q6_ipq5018_data@4C400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C400000 0x0 0xD00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D100000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D100000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data1: q6_qcn6122_data1@4D300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D300000 0x0 0xF00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_1: m3_dump_qcn6122_1@4E200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_1: q6_qcn6122_etr_1@4E300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data2: q6_qcn6122_data2@4E400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E400000 0x0 0xF00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_2: m3_dump_qcn6122_2@4F300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_2: q6_qcn6122_etr_2@4F400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F400000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
						/*                 512MB/1GB Profiles
 | 
				
			||||||
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * |  Region  | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    NSS   |  0x40000000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   Linux  |  0x41000000  | Depends on total memory |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   uboot  |  0x4A600000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    SBL   |  0x4AA00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   smem   |  0x4AB00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    TZ    |  0x4AC00000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    Q6    |              |                         |
 | 
				
			||||||
 | 
						 * |   code/  |  0x4B000000  |          20MB           |
 | 
				
			||||||
 | 
						 * |   data   |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4C400000  |          14MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4D200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4D300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4D400000  |           2MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4D600000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4E600000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4E700000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4E800000  |           5MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4ED00000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4FD00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4FE00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4FF00000  |           5MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * |            Rest of the memory for Linux           |
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * +===================================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x5400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 01400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5018_data: q6_ipq5018_data@4C400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C400000 0x0 0xE00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_caldb_region: q6_caldb_region@4D400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D400000 0x0 0x200000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data1: q6_qcn6122_data1@4D600000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D600000 0x0 0x1000000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_1: m3_dump_qcn6122_1@4E600000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E600000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_1: q6_qcn6122_etr_1@4E700000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E700000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_caldb_1: q6_qcn6122_caldb_1@4E800000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E800000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data2: q6_qcn6122_data2@4E900000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4ED00000 0x0 0x1000000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_2: m3_dump_qcn6122_2@4FD00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FD00000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_2: q6_qcn6122_etr_2@4FE00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FE00000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_caldb_2: q6_qcn6122_caldb_2@4FF00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FF00000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						soc {
 | 
				
			||||||
 | 
							gpio-watchdog {
 | 
				
			||||||
 | 
								compatible = "linux,wdt-gpio";
 | 
				
			||||||
 | 
								gpios = <&tlmm 27 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								hw_algo = "toggle";
 | 
				
			||||||
 | 
								hw_margin_ms = <5000>;
 | 
				
			||||||
 | 
								always-running;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							serial@78af000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							blsp1_uart2: serial@78b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp1_uart_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qpic_bam: dma@7984000{
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nand: qpic-nand@79b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&qspi_nand_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							spi_0: spi@78b5000 { /* BLSP1 QUP0 */
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp0_spi_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								cs-select = <0>;
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								m25p80@0 {
 | 
				
			||||||
 | 
									#address-cells = <1>;
 | 
				
			||||||
 | 
									#size-cells = <1>;
 | 
				
			||||||
 | 
									reg = <0>;
 | 
				
			||||||
 | 
									compatible = "n25q128a11";
 | 
				
			||||||
 | 
									linux,modalias = "m25p80", "n25q128a11";
 | 
				
			||||||
 | 
									spi-max-frequency = <50000000>;
 | 
				
			||||||
 | 
									use-default-sizes;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio0: mdio@88000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <7>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio1: mdio@90000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
								pinctrl-0 = <&mdio1_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								phy-reset-gpio = <&tlmm 39 0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <28>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ess-instance {
 | 
				
			||||||
 | 
								num_devices = <0x1>;
 | 
				
			||||||
 | 
								ess-switch@0x39c00000 {
 | 
				
			||||||
 | 
									switch_mac_mode = <0xf>; /* mac mode for uniphy instance*/
 | 
				
			||||||
 | 
									cmnblk_clk = "internal_96MHz"; /* cmnblk clk*/
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <7>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio0>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@1 {
 | 
				
			||||||
 | 
											port_id = <2>;
 | 
				
			||||||
 | 
											phy_address = <0x1c>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
											port_mac_sel = "QGMAC_PORT";
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
									led_source@0 {
 | 
				
			||||||
 | 
										source = <0>;
 | 
				
			||||||
 | 
										mode = "normal";
 | 
				
			||||||
 | 
										speed = "all";
 | 
				
			||||||
 | 
										blink_en = "enable";
 | 
				
			||||||
 | 
										active = "high";
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
									ess-switch1@1 {
 | 
				
			||||||
 | 
									compatible = "qcom,ess-switch-qca83xx";
 | 
				
			||||||
 | 
									device_id = <1>;
 | 
				
			||||||
 | 
									switch_access_mode = "mdio";
 | 
				
			||||||
 | 
									mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
									reset_gpio = <0x28>;
 | 
				
			||||||
 | 
									switch_cpu_bmp = <0x40>;  /* cpu port bitmap */
 | 
				
			||||||
 | 
									switch_lan_bmp = <0x1e>; /* lan port bitmap */
 | 
				
			||||||
 | 
									switch_wan_bmp = <0x0>;  /* wan port bitmap */
 | 
				
			||||||
 | 
									qca,ar8327-initvals = <
 | 
				
			||||||
 | 
											0x00004 0x7600000   /* PAD0_MODE */
 | 
				
			||||||
 | 
											0x00008 0x1000000   /* PAD5_MODE */
 | 
				
			||||||
 | 
											0x0000c 0x80        /* PAD6_MODE */
 | 
				
			||||||
 | 
											0x00010 0x2613a0    /* PORT6 FORCE MODE*/
 | 
				
			||||||
 | 
											0x000e4 0xaa545     /* MAC_POWER_SEL */
 | 
				
			||||||
 | 
											0x000e0 0xc74164de  /* SGMII_CTRL */
 | 
				
			||||||
 | 
											0x0007c 0x4e        /* PORT0_STATUS */
 | 
				
			||||||
 | 
											0x00094 0x4e        /* PORT6_STATUS */
 | 
				
			||||||
 | 
									>;
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <28>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp1 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC0_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <1>;
 | 
				
			||||||
 | 
								reg = <0x39C00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <7>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio0>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp2 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC1_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <2>;
 | 
				
			||||||
 | 
								reg = <0x39D00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <28>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,test@0 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nss-macsec1 {
 | 
				
			||||||
 | 
								compatible = "qcom,nss-macsec";
 | 
				
			||||||
 | 
								phy_addr = <0x1c>;
 | 
				
			||||||
 | 
								mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							lpass: lpass@0xA000000{
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm: pcm@0xA3C0000{
 | 
				
			||||||
 | 
								pinctrl-0 = <&audio_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm_lb: pcm_lb@0 {
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						thermal-zones {
 | 
				
			||||||
 | 
							status = "ok";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
						pinctrl-0 = <&blsp0_uart_pins &phy_led_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_uart_pins: uart_pins {
 | 
				
			||||||
 | 
							blsp0_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio20", "gpio21";
 | 
				
			||||||
 | 
								function = "blsp0_uart0";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp1_uart_pins: blsp1_uart_pins {
 | 
				
			||||||
 | 
							blsp1_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio22", "gpio24", "gpio23", "gpio25";
 | 
				
			||||||
 | 
								function = "blsp1_uart2";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_spi_pins: blsp0_spi_pins {
 | 
				
			||||||
 | 
							mux {
 | 
				
			||||||
 | 
								pins = "gpio10", "gpio11", "gpio12", "gpio13";
 | 
				
			||||||
 | 
								function = "blsp0_spi";
 | 
				
			||||||
 | 
								drive-strength = <2>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qspi_nand_pins: qspi_nand_pins {
 | 
				
			||||||
 | 
							qspi_clock {
 | 
				
			||||||
 | 
								pins = "gpio9";
 | 
				
			||||||
 | 
								function = "qspi_clk";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_cs {
 | 
				
			||||||
 | 
								pins = "gpio8";
 | 
				
			||||||
 | 
								function = "qspi_cs";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_0 {
 | 
				
			||||||
 | 
								pins = "gpio7";
 | 
				
			||||||
 | 
								function = "qspi0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_1 {
 | 
				
			||||||
 | 
								pins = "gpio6";
 | 
				
			||||||
 | 
								function = "qspi1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_2 {
 | 
				
			||||||
 | 
								pins = "gpio5";
 | 
				
			||||||
 | 
								function = "qspi2";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_3 {
 | 
				
			||||||
 | 
								pins = "gpio4";
 | 
				
			||||||
 | 
								function = "qspi3";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mdio1_pins: mdio_pinmux {
 | 
				
			||||||
 | 
							mux_0 {
 | 
				
			||||||
 | 
								pins = "gpio36";
 | 
				
			||||||
 | 
								function = "mdc";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mux_1 {
 | 
				
			||||||
 | 
								pins = "gpio37";
 | 
				
			||||||
 | 
								function = "mdio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						phy_led_pins: phy_led_pins {
 | 
				
			||||||
 | 
							gephy_led_pin {
 | 
				
			||||||
 | 
								pins = "gpio46";
 | 
				
			||||||
 | 
								function = "led0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						i2c_pins: i2c_pins {
 | 
				
			||||||
 | 
							i2c_scl {
 | 
				
			||||||
 | 
								pins = "gpio25";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							i2c_sda {
 | 
				
			||||||
 | 
								pins = "gpio26";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						button_pins: button_pins {
 | 
				
			||||||
 | 
							reset_button {
 | 
				
			||||||
 | 
								pins = "gpio38";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					audio_pins: audio_pinmux {
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					        leds_pins: leds_pins {
 | 
				
			||||||
 | 
					                led_5g {
 | 
				
			||||||
 | 
					                        pins = "gpio34";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_2g {
 | 
				
			||||||
 | 
					                        pins = "gpio33";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_sys {
 | 
				
			||||||
 | 
					                        pins = "gpio26";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
							led_onekey {
 | 
				
			||||||
 | 
					                        pins = "gpio28";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
						gpio_keys {
 | 
				
			||||||
 | 
							compatible = "gpio-keys";
 | 
				
			||||||
 | 
							pinctrl-0 = <&button_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							button@1 {
 | 
				
			||||||
 | 
								label = "reset";
 | 
				
			||||||
 | 
								linux,code = <KEY_RESTART>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 38 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,input-type = <1>;
 | 
				
			||||||
 | 
								debounce-interval = <60>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        leds {
 | 
				
			||||||
 | 
					                compatible = "gpio-leds";
 | 
				
			||||||
 | 
					                pinctrl-0 = <&leds_pins>;
 | 
				
			||||||
 | 
					                pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                led_blue: led@34 {
 | 
				
			||||||
 | 
					                        label = "led_5g";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 34 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_5g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_green: led@33 {
 | 
				
			||||||
 | 
					                        label = "led_2g";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 33 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_2g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_red: led@26 {
 | 
				
			||||||
 | 
					                        label = "led_sys";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 26 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_sys";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
							led@28 {
 | 
				
			||||||
 | 
					                        label = "led_onekey";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 28 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_onekey";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&q6v5_wcss {
 | 
				
			||||||
 | 
						compatible = "qcom,ipq5018-q6-mpd";
 | 
				
			||||||
 | 
						#address-cells = <1>;
 | 
				
			||||||
 | 
						#size-cells = <1>;
 | 
				
			||||||
 | 
						ranges;
 | 
				
			||||||
 | 
						firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
						reg = <0x0cd00000 0x4040>,
 | 
				
			||||||
 | 
							<0x1938000 0x8>,
 | 
				
			||||||
 | 
							<0x193d204 0x4>;
 | 
				
			||||||
 | 
						reg-names = "qdsp6",
 | 
				
			||||||
 | 
								"tcsr-msip",
 | 
				
			||||||
 | 
								"tcsr-q6";
 | 
				
			||||||
 | 
						resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
								<&gcc GCC_WCSS_Q6_BCR>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
								"wcss_q6_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						clocks = <&gcc GCC_Q6_AXIS_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_ECAHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM2_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_S_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_AXI_S_CLK>;
 | 
				
			||||||
 | 
						clock-names = "gcc_q6_axis_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_ecahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim2_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_s_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_axi_s_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_mem_regions>, <&q6_etr_region>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_mem_regions>, <&q6_etr_region>,
 | 
				
			||||||
 | 
									<&q6_caldb_region>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qcom,rproc = <&q6v5_wcss>;
 | 
				
			||||||
 | 
						qcom,bootargs_smem = <507>;
 | 
				
			||||||
 | 
						boot-args = <0x1 0x4 0x3 0x0F 0x0 0x0>,
 | 
				
			||||||
 | 
								<0x2 0x4 0x2 0x12 0x0 0x0>;
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						q6_wcss_pd1: remoteproc_pd1@4ab000 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-ahb-mpd";
 | 
				
			||||||
 | 
							reg = <0x4ab000 0x20>;
 | 
				
			||||||
 | 
							reg-names = "rmb";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							m3_firmware = "IPQ5018/m3_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 8 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 9 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 12 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 11 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_BCR>,
 | 
				
			||||||
 | 
									<&gcc GCC_CE_BCR>;
 | 
				
			||||||
 | 
							reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
									"wcss_reset",
 | 
				
			||||||
 | 
									"ce_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							clocks = <&gcc GCC_WCSS_AHB_S_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_ACMT_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_AXI_M_CLK>;
 | 
				
			||||||
 | 
							clock-names = "gcc_wcss_ahb_s_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_acmt_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_axi_m_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,halt-regs = <&tcsr_q6_block 0xa000 0xd000 0x0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 8>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 9>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 10>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_ipq5018_data>, <&m3_dump>,
 | 
				
			||||||
 | 
									<&q6_etr_region>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_ipq5018_data>, <&m3_dump>,
 | 
				
			||||||
 | 
									<&q6_etr_region>, <&q6_caldb_region>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						q6_wcss_pd2: remoteproc_pd2 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-pcie-mpd";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							m3_firmware = "qcn6122/m3_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 16 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 17 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 20 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 19 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 16>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 17>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 18>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data1>, <&m3_dump_qcn6122_1>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_1>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data1>, <&m3_dump_qcn6122_1>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_1>, <&q6_qcn6122_caldb_1>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						q6_wcss_pd3: remoteproc_pd3 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-pcie-mpd";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 24 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 25 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 28 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 27 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 24>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 25>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 26>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef	__IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data2>, <&m3_dump_qcn6122_2>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_2>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data2>, <&m3_dump_qcn6122_2>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_2>, <&q6_qcn6122_caldb_2>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_0 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&i2c_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi0 {
 | 
				
			||||||
 | 
						/* IPQ5018 */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd1>;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd1";
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x24>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4C400000 0x4C400000 0x4C400000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4D400000 0x4D400000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x200000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi1 {
 | 
				
			||||||
 | 
						/* QCN6122 5G */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd2";
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd2>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x50>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4D600000 0x4D600000 0x4D300000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4E800000 0x4E800000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6122_data1>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6122_data1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi2 {
 | 
				
			||||||
 | 
						/* QCN6122 6G */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd3";
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd3>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0xb0>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4ED00000 0x4ED00000 0x4E400000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4FF00000 0x4FF00000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6122_data2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6122_data2>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&usb3 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						device-power-gpio = <&tlmm 24 1>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&dwc_0 {
 | 
				
			||||||
 | 
						/delete-property/ #phy-cells;
 | 
				
			||||||
 | 
						/delete-property/ phys;
 | 
				
			||||||
 | 
						/delete-property/ phy-names;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					&hs_m31phy_0 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&eud {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1 {
 | 
				
			||||||
 | 
						#status = "disabled";
 | 
				
			||||||
 | 
						#perst-gpio = <&tlmm 18 1>;
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 18 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2 {
 | 
				
			||||||
 | 
						#status = "disabled";
 | 
				
			||||||
 | 
						#perst-gpio = <&tlmm 15 1>;
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 15 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1_rp {
 | 
				
			||||||
 | 
					        status = "disabled";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_0: qcom,mhi@0 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2_rp {
 | 
				
			||||||
 | 
					        status = "disabled";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_1: qcom,mhi@1 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -0,0 +1,941 @@
 | 
				
			|||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					/* Copyright (c) 2018-2020, The Linux Foundation. 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.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "ipq5018.dtsi"
 | 
				
			||||||
 | 
					#include <dt-bindings/input/input.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						#address-cells = <0x2>;
 | 
				
			||||||
 | 
						#size-cells = <0x2>;
 | 
				
			||||||
 | 
						model = "Indio UM-525AXP";
 | 
				
			||||||
 | 
						compatible = "indio,um-525axp", "qcom,ipq5018-mp03.5-c1", "qcom,ipq5018";
 | 
				
			||||||
 | 
						interrupt-parent = <&intc>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aliases {
 | 
				
			||||||
 | 
							sdhc1 = &sdhc_1; /* SDC1 eMMC slot */
 | 
				
			||||||
 | 
							serial0 = &blsp1_uart1;
 | 
				
			||||||
 | 
							serial1 = &blsp1_uart2;
 | 
				
			||||||
 | 
							ethernet0 = "/soc/dp1";
 | 
				
			||||||
 | 
							ethernet1 = "/soc/dp2";
 | 
				
			||||||
 | 
					                //led-failsafe = &led_red;
 | 
				
			||||||
 | 
					                //led-running = &led_green;
 | 
				
			||||||
 | 
					                //led-upgrade = &led_green;
 | 
				
			||||||
 | 
					                //led-gateway = &led_blue;
 | 
				
			||||||
 | 
					                //led-factory = &led_blue;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						chosen {
 | 
				
			||||||
 | 
							bootargs = "console=ttyMSM0,115200,n8 rw init=/init";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							bootargs-append = " swiotlb=1";
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							bootargs-append = " swiotlb=1 coherent_pool=2M";
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
							stdout-path = "serial0";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reserved-memory {
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						/*                   256 MB Profile
 | 
				
			||||||
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * |  Region  | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    NSS   |  0x40000000  |           8MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   Linux  |  0x40800000  | Depends on total memory |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   uboot  |  0x4A600000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    SBL   |  0x4AA00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   smem   |  0x4AB00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    TZ    |  0x4AC00000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    Q6    |              |                         |
 | 
				
			||||||
 | 
						 * |   code/  |  0x4B000000  |          20MB           |
 | 
				
			||||||
 | 
						 * |   data   |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4C400000  |          13MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4D100000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4D200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4D300000  |          15MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4E200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4E300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4E400000  |          15MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4F300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4F400000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * |            Rest of the memory for Linux           |
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * +===================================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x4500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x1400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5018_data: q6_ipq5018_data@4C400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C400000 0x0 0xD00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D100000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D100000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data1: q6_qcn6122_data1@4D300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D300000 0x0 0xF00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_1: m3_dump_qcn6122_1@4E200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_1: q6_qcn6122_etr_1@4E300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data2: q6_qcn6122_data2@4E400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E400000 0x0 0xF00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_2: m3_dump_qcn6122_2@4F300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_2: q6_qcn6122_etr_2@4F400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F400000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
						/*                 512MB/1GB Profiles
 | 
				
			||||||
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * |  Region  | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |          |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    NSS   |  0x40000000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   Linux  |  0x41000000  | Depends on total memory |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   uboot  |  0x4A600000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    SBL   |  0x4AA00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   smem   |  0x4AB00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    TZ    |  0x4AC00000  |           4MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |    Q6    |              |                         |
 | 
				
			||||||
 | 
						 * |   code/  |  0x4B000000  |          20MB           |
 | 
				
			||||||
 | 
						 * |   data   |              |                         |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4C400000  |          14MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4D200000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4D300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |  IPQ5018 |              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4D400000  |           2MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4D600000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4E600000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4E700000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_1|              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4E800000  |           5MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   data   |  0x4ED00000  |          16MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  M3 Dump |  0x4FD00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |   QDSS   |  0x4FE00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | QCN6122_2|              |                         |
 | 
				
			||||||
 | 
						 * |  Caldb   |  0x4FF00000  |           5MB           |
 | 
				
			||||||
 | 
						 * +----------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * |            Rest of the memory for Linux           |
 | 
				
			||||||
 | 
						 * |                                                   |
 | 
				
			||||||
 | 
						 * +===================================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 0x5400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4B000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4B000000 0x0 01400000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5018_data: q6_ipq5018_data@4C400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C400000 0x0 0xE00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D200000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D300000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_caldb_region: q6_caldb_region@4D400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D400000 0x0 0x200000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data1: q6_qcn6122_data1@4D600000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D600000 0x0 0x1000000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_1: m3_dump_qcn6122_1@4E600000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E600000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_1: q6_qcn6122_etr_1@4E700000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E700000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_caldb_1: q6_qcn6122_caldb_1@4E800000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4E800000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_data2: q6_qcn6122_data2@4E900000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4ED00000 0x0 0x1000000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6122_2: m3_dump_qcn6122_2@4FD00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FD00000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_etr_2: q6_qcn6122_etr_2@4FE00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FE00000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6122_caldb_2: q6_qcn6122_caldb_2@4FF00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FF00000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						soc {
 | 
				
			||||||
 | 
							gpio-watchdog {
 | 
				
			||||||
 | 
								compatible = "linux,wdt-gpio";
 | 
				
			||||||
 | 
								gpios = <&tlmm 27 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								hw_algo = "toggle";
 | 
				
			||||||
 | 
								hw_margin_ms = <5000>;
 | 
				
			||||||
 | 
								always-running;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							serial@78af000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							blsp1_uart2: serial@78b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp1_uart_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qpic_bam: dma@7984000{
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nand: qpic-nand@79b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&qspi_nand_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							spi_0: spi@78b5000 { /* BLSP1 QUP0 */
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp0_spi_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								cs-select = <0>;
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								m25p80@0 {
 | 
				
			||||||
 | 
									#address-cells = <1>;
 | 
				
			||||||
 | 
									#size-cells = <1>;
 | 
				
			||||||
 | 
									reg = <0>;
 | 
				
			||||||
 | 
									compatible = "n25q128a11";
 | 
				
			||||||
 | 
									linux,modalias = "m25p80", "n25q128a11";
 | 
				
			||||||
 | 
									spi-max-frequency = <50000000>;
 | 
				
			||||||
 | 
									use-default-sizes;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio0: mdio@88000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <7>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio1: mdio@90000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
								pinctrl-0 = <&mdio1_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								phy-reset-gpio = <&tlmm 39 0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <28>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ess-instance {
 | 
				
			||||||
 | 
								num_devices = <0x1>;
 | 
				
			||||||
 | 
								ess-switch@0x39c00000 {
 | 
				
			||||||
 | 
									switch_mac_mode = <0xf>; /* mac mode for uniphy instance*/
 | 
				
			||||||
 | 
									cmnblk_clk = "internal_96MHz"; /* cmnblk clk*/
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <7>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio0>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@1 {
 | 
				
			||||||
 | 
											port_id = <2>;
 | 
				
			||||||
 | 
											phy_address = <0x1c>;
 | 
				
			||||||
 | 
											mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
											port_mac_sel = "QGMAC_PORT";
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
									led_source@0 {
 | 
				
			||||||
 | 
										source = <0>;
 | 
				
			||||||
 | 
										mode = "normal";
 | 
				
			||||||
 | 
										speed = "all";
 | 
				
			||||||
 | 
										blink_en = "enable";
 | 
				
			||||||
 | 
										active = "high";
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
									ess-switch1@1 {
 | 
				
			||||||
 | 
									compatible = "qcom,ess-switch-qca83xx";
 | 
				
			||||||
 | 
									device_id = <1>;
 | 
				
			||||||
 | 
									switch_access_mode = "mdio";
 | 
				
			||||||
 | 
									mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
									reset_gpio = <0x28>;
 | 
				
			||||||
 | 
									switch_cpu_bmp = <0x40>;  /* cpu port bitmap */
 | 
				
			||||||
 | 
									switch_lan_bmp = <0x1e>; /* lan port bitmap */
 | 
				
			||||||
 | 
									switch_wan_bmp = <0x0>;  /* wan port bitmap */
 | 
				
			||||||
 | 
									qca,ar8327-initvals = <
 | 
				
			||||||
 | 
											0x00004 0x7600000   /* PAD0_MODE */
 | 
				
			||||||
 | 
											0x00008 0x1000000   /* PAD5_MODE */
 | 
				
			||||||
 | 
											0x0000c 0x80        /* PAD6_MODE */
 | 
				
			||||||
 | 
											0x00010 0x2613a0    /* PORT6 FORCE MODE*/
 | 
				
			||||||
 | 
											0x000e4 0xaa545     /* MAC_POWER_SEL */
 | 
				
			||||||
 | 
											0x000e0 0xc74164de  /* SGMII_CTRL */
 | 
				
			||||||
 | 
											0x0007c 0x4e        /* PORT0_STATUS */
 | 
				
			||||||
 | 
											0x00094 0x4e        /* PORT6_STATUS */
 | 
				
			||||||
 | 
									>;
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <28>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp1 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC0_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <1>;
 | 
				
			||||||
 | 
								reg = <0x39C00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <7>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio0>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp2 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								clocks = <&gcc GCC_SNOC_GMAC1_AXI_CLK>;
 | 
				
			||||||
 | 
								clock-names = "nss-snoc-gmac-axi-clk";
 | 
				
			||||||
 | 
								qcom,id = <2>;
 | 
				
			||||||
 | 
								reg = <0x39D00000 0x10000>;
 | 
				
			||||||
 | 
								interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
 | 
				
			||||||
 | 
								qcom,mactype = <2>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <28>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,test@0 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nss-macsec1 {
 | 
				
			||||||
 | 
								compatible = "qcom,nss-macsec";
 | 
				
			||||||
 | 
								phy_addr = <0x1c>;
 | 
				
			||||||
 | 
								mdiobus = <&mdio1>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							lpass: lpass@0xA000000{
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm: pcm@0xA3C0000{
 | 
				
			||||||
 | 
								pinctrl-0 = <&audio_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							pcm_lb: pcm_lb@0 {
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						thermal-zones {
 | 
				
			||||||
 | 
							status = "ok";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
						pinctrl-0 = <&blsp0_uart_pins &phy_led_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_uart_pins: uart_pins {
 | 
				
			||||||
 | 
							blsp0_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio20", "gpio21";
 | 
				
			||||||
 | 
								function = "blsp0_uart0";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp1_uart_pins: blsp1_uart_pins {
 | 
				
			||||||
 | 
							blsp1_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio22", "gpio24", "gpio23", "gpio25";
 | 
				
			||||||
 | 
								function = "blsp1_uart2";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_spi_pins: blsp0_spi_pins {
 | 
				
			||||||
 | 
							mux {
 | 
				
			||||||
 | 
								pins = "gpio10", "gpio11", "gpio12", "gpio13";
 | 
				
			||||||
 | 
								function = "blsp0_spi";
 | 
				
			||||||
 | 
								drive-strength = <2>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qspi_nand_pins: qspi_nand_pins {
 | 
				
			||||||
 | 
							qspi_clock {
 | 
				
			||||||
 | 
								pins = "gpio9";
 | 
				
			||||||
 | 
								function = "qspi_clk";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_cs {
 | 
				
			||||||
 | 
								pins = "gpio8";
 | 
				
			||||||
 | 
								function = "qspi_cs";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_0 {
 | 
				
			||||||
 | 
								pins = "gpio7";
 | 
				
			||||||
 | 
								function = "qspi0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_1 {
 | 
				
			||||||
 | 
								pins = "gpio6";
 | 
				
			||||||
 | 
								function = "qspi1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_2 {
 | 
				
			||||||
 | 
								pins = "gpio5";
 | 
				
			||||||
 | 
								function = "qspi2";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							qspi_data_3 {
 | 
				
			||||||
 | 
								pins = "gpio4";
 | 
				
			||||||
 | 
								function = "qspi3";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mdio1_pins: mdio_pinmux {
 | 
				
			||||||
 | 
							mux_0 {
 | 
				
			||||||
 | 
								pins = "gpio36";
 | 
				
			||||||
 | 
								function = "mdc";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mux_1 {
 | 
				
			||||||
 | 
								pins = "gpio37";
 | 
				
			||||||
 | 
								function = "mdio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						phy_led_pins: phy_led_pins {
 | 
				
			||||||
 | 
							gephy_led_pin {
 | 
				
			||||||
 | 
								pins = "gpio46";
 | 
				
			||||||
 | 
								function = "led0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						i2c_pins: i2c_pins {
 | 
				
			||||||
 | 
							i2c_scl {
 | 
				
			||||||
 | 
								pins = "gpio25";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							i2c_sda {
 | 
				
			||||||
 | 
								pins = "gpio26";
 | 
				
			||||||
 | 
								function = "blsp2_i2c1";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						button_pins: button_pins {
 | 
				
			||||||
 | 
							reset_button {
 | 
				
			||||||
 | 
								pins = "gpio38";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					audio_pins: audio_pinmux {
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					        leds_pins: leds_pins {
 | 
				
			||||||
 | 
					                led_5g {
 | 
				
			||||||
 | 
					                        pins = "gpio34";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_2g {
 | 
				
			||||||
 | 
					                        pins = "gpio33";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_sys {
 | 
				
			||||||
 | 
					                        pins = "gpio26";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
							led_onekey {
 | 
				
			||||||
 | 
					                        pins = "gpio28";
 | 
				
			||||||
 | 
					                        function = "gpio";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
						gpio_keys {
 | 
				
			||||||
 | 
							compatible = "gpio-keys";
 | 
				
			||||||
 | 
							pinctrl-0 = <&button_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							button@1 {
 | 
				
			||||||
 | 
								label = "reset";
 | 
				
			||||||
 | 
								linux,code = <KEY_RESTART>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 38 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,input-type = <1>;
 | 
				
			||||||
 | 
								debounce-interval = <60>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        leds {
 | 
				
			||||||
 | 
					                compatible = "gpio-leds";
 | 
				
			||||||
 | 
					                pinctrl-0 = <&leds_pins>;
 | 
				
			||||||
 | 
					                pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                led_blue: led@34 {
 | 
				
			||||||
 | 
					                        label = "led_5g";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 34 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_5g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_green: led@33 {
 | 
				
			||||||
 | 
					                        label = "led_2g";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 33 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_2g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led_red: led@26 {
 | 
				
			||||||
 | 
					                        label = "led_sys";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 26 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_sys";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
							led@28 {
 | 
				
			||||||
 | 
					                        label = "led_onekey";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 28 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_onekey";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&q6v5_wcss {
 | 
				
			||||||
 | 
						compatible = "qcom,ipq5018-q6-mpd";
 | 
				
			||||||
 | 
						#address-cells = <1>;
 | 
				
			||||||
 | 
						#size-cells = <1>;
 | 
				
			||||||
 | 
						ranges;
 | 
				
			||||||
 | 
						firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
						reg = <0x0cd00000 0x4040>,
 | 
				
			||||||
 | 
							<0x1938000 0x8>,
 | 
				
			||||||
 | 
							<0x193d204 0x4>;
 | 
				
			||||||
 | 
						reg-names = "qdsp6",
 | 
				
			||||||
 | 
								"tcsr-msip",
 | 
				
			||||||
 | 
								"tcsr-q6";
 | 
				
			||||||
 | 
						resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
								<&gcc GCC_WCSS_Q6_BCR>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
								"wcss_q6_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						clocks = <&gcc GCC_Q6_AXIS_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_ECAHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AXIM2_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_Q6_AHB_S_CLK>,
 | 
				
			||||||
 | 
							<&gcc GCC_WCSS_AXI_S_CLK>;
 | 
				
			||||||
 | 
						clock-names = "gcc_q6_axis_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_ecahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim_clk",
 | 
				
			||||||
 | 
							"gcc_q6_axim2_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_clk",
 | 
				
			||||||
 | 
							"gcc_q6_ahb_s_clk",
 | 
				
			||||||
 | 
							"gcc_wcss_axi_s_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_mem_regions>, <&q6_etr_region>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_mem_regions>, <&q6_etr_region>,
 | 
				
			||||||
 | 
									<&q6_caldb_region>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qcom,rproc = <&q6v5_wcss>;
 | 
				
			||||||
 | 
						qcom,bootargs_smem = <507>;
 | 
				
			||||||
 | 
						boot-args = <0x1 0x4 0x3 0x0F 0x0 0x0>,
 | 
				
			||||||
 | 
								<0x2 0x4 0x2 0x12 0x0 0x0>;
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						q6_wcss_pd1: remoteproc_pd1@4ab000 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-ahb-mpd";
 | 
				
			||||||
 | 
							reg = <0x4ab000 0x20>;
 | 
				
			||||||
 | 
							reg-names = "rmb";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							m3_firmware = "IPQ5018/m3_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 8 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 9 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 12 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 11 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							resets = <&gcc GCC_WCSSAON_RESET>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_BCR>,
 | 
				
			||||||
 | 
									<&gcc GCC_CE_BCR>;
 | 
				
			||||||
 | 
							reset-names = "wcss_aon_reset",
 | 
				
			||||||
 | 
									"wcss_reset",
 | 
				
			||||||
 | 
									"ce_reset";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							clocks = <&gcc GCC_WCSS_AHB_S_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_ACMT_CLK>,
 | 
				
			||||||
 | 
									<&gcc GCC_WCSS_AXI_M_CLK>;
 | 
				
			||||||
 | 
							clock-names = "gcc_wcss_ahb_s_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_acmt_clk",
 | 
				
			||||||
 | 
										"gcc_wcss_axi_m_clk";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,halt-regs = <&tcsr_q6_block 0xa000 0xd000 0x0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 8>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 9>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 10>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_ipq5018_data>, <&m3_dump>,
 | 
				
			||||||
 | 
									<&q6_etr_region>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_ipq5018_data>, <&m3_dump>,
 | 
				
			||||||
 | 
									<&q6_etr_region>, <&q6_caldb_region>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						q6_wcss_pd2: remoteproc_pd2 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-pcie-mpd";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							m3_firmware = "qcn6122/m3_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 16 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 17 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 20 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 19 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 16>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 17>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 18>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data1>, <&m3_dump_qcn6122_1>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_1>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data1>, <&m3_dump_qcn6122_1>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_1>, <&q6_qcn6122_caldb_1>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						q6_wcss_pd3: remoteproc_pd3 {
 | 
				
			||||||
 | 
							compatible = "qcom,ipq5018-wcss-pcie-mpd";
 | 
				
			||||||
 | 
							firmware = "IPQ5018/q6_fw.mdt";
 | 
				
			||||||
 | 
							interrupts-extended = <&wcss_smp2p_in 24 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 25 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 28 0>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_in 27 0>;
 | 
				
			||||||
 | 
							interrupt-names = "fatal",
 | 
				
			||||||
 | 
										"ready",
 | 
				
			||||||
 | 
										"spawn-ack",
 | 
				
			||||||
 | 
										"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,smem-states = <&wcss_smp2p_out 24>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 25>,
 | 
				
			||||||
 | 
										<&wcss_smp2p_out 26>;
 | 
				
			||||||
 | 
							qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
										"stop",
 | 
				
			||||||
 | 
										"spawn";
 | 
				
			||||||
 | 
						#ifdef	__IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data2>, <&m3_dump_qcn6122_2>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_2>;
 | 
				
			||||||
 | 
						#else
 | 
				
			||||||
 | 
							memory-region = <&q6_qcn6122_data2>, <&m3_dump_qcn6122_2>,
 | 
				
			||||||
 | 
									<&q6_qcn6122_etr_2>, <&q6_qcn6122_caldb_2>;
 | 
				
			||||||
 | 
						#endif
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_0 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&i2c_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi0 {
 | 
				
			||||||
 | 
						/* IPQ5018 */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd1>;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd1";
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x24>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4C400000 0x4C400000 0x4C400000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4D400000 0x4D400000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x200000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_ipq5018_data>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi1 {
 | 
				
			||||||
 | 
						/* QCN6122 5G */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd2";
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd2>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x50>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4D600000 0x4D600000 0x4D300000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4E800000 0x4E800000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6122_data1>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6122_data1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi2 {
 | 
				
			||||||
 | 
						/* QCN6122 6G */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd3";
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd3>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_256_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0xb0>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4ED00000 0x4ED00000 0x4E400000 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4FF00000 0x4FF00000 0 0 0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6122_data2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6122_data2>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&usb3 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						device-power-gpio = <&tlmm 24 1>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&dwc_0 {
 | 
				
			||||||
 | 
						/delete-property/ #phy-cells;
 | 
				
			||||||
 | 
						/delete-property/ phys;
 | 
				
			||||||
 | 
						/delete-property/ phy-names;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					&hs_m31phy_0 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&eud {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1 {
 | 
				
			||||||
 | 
						#status = "disabled";
 | 
				
			||||||
 | 
						#perst-gpio = <&tlmm 18 1>;
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 18 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2 {
 | 
				
			||||||
 | 
						#status = "disabled";
 | 
				
			||||||
 | 
						#perst-gpio = <&tlmm 15 1>;
 | 
				
			||||||
 | 
						perst-gpio = <&tlmm 15 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x1_rp {
 | 
				
			||||||
 | 
					        status = "disabled";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_0: qcom,mhi@0 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pcie_x2_rp {
 | 
				
			||||||
 | 
					        status = "disabled";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mhi_1: qcom,mhi@1 {
 | 
				
			||||||
 | 
							reg = <0 0 0 0 0 >;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -151,6 +151,14 @@
 | 
				
			|||||||
			no-map;
 | 
								no-map;
 | 
				
			||||||
			reg = <0x0 0x4F000000 0x0 0x100000>;
 | 
								reg = <0x0 0x4F000000 0x0 0x100000>;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ramoops: ramoops@4f100000 {
 | 
				
			||||||
 | 
								compatible = "ramoops";
 | 
				
			||||||
 | 
								reg = <0x0 0x4f100000 0x0 0x80000>;
 | 
				
			||||||
 | 
								record-size = <0x20000>;
 | 
				
			||||||
 | 
								console-size = <0x20000>;
 | 
				
			||||||
 | 
								pmsg-size = <0x20000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
	#else
 | 
						#else
 | 
				
			||||||
	/*                 512MB/1GB Profiles
 | 
						/*                 512MB/1GB Profiles
 | 
				
			||||||
	 * +==========+==============+=========================+
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
@@ -285,6 +293,13 @@
 | 
				
			|||||||
			reg = <0x0 0x4F800000 0x0 0x500000>;
 | 
								reg = <0x0 0x4F800000 0x0 0x500000>;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ramoops: ramoops@4fd00000 {
 | 
				
			||||||
 | 
								compatible = "ramoops";
 | 
				
			||||||
 | 
								reg = <0x0 0x4fd00000 0x0 0x80000>;
 | 
				
			||||||
 | 
								record-size = <0x20000>;
 | 
				
			||||||
 | 
								console-size = <0x20000>;
 | 
				
			||||||
 | 
								pmsg-size = <0x20000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
	#endif
 | 
						#endif
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -151,6 +151,14 @@
 | 
				
			|||||||
			no-map;
 | 
								no-map;
 | 
				
			||||||
			reg = <0x0 0x4F000000 0x0 0x100000>;
 | 
								reg = <0x0 0x4F000000 0x0 0x100000>;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ramoops: ramoops@4f100000 {
 | 
				
			||||||
 | 
								compatible = "ramoops";
 | 
				
			||||||
 | 
								reg = <0x0 0x4f100000 0x0 0x80000>;
 | 
				
			||||||
 | 
								record-size = <0x20000>;
 | 
				
			||||||
 | 
								console-size = <0x20000>;
 | 
				
			||||||
 | 
								pmsg-size = <0x20000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
	#else
 | 
						#else
 | 
				
			||||||
	/*                 512MB/1GB Profiles
 | 
						/*                 512MB/1GB Profiles
 | 
				
			||||||
	 * +==========+==============+=========================+
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
@@ -285,6 +293,13 @@
 | 
				
			|||||||
			reg = <0x0 0x4F800000 0x0 0x500000>;
 | 
								reg = <0x0 0x4F800000 0x0 0x500000>;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ramoops: ramoops@4fd00000 {
 | 
				
			||||||
 | 
								compatible = "ramoops";
 | 
				
			||||||
 | 
								reg = <0x0 0x4fd00000 0x0 0x80000>;
 | 
				
			||||||
 | 
								record-size = <0x20000>;
 | 
				
			||||||
 | 
								console-size = <0x20000>;
 | 
				
			||||||
 | 
								pmsg-size = <0x20000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
	#endif
 | 
						#endif
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -154,6 +154,14 @@
 | 
				
			|||||||
			no-map;
 | 
								no-map;
 | 
				
			||||||
			reg = <0x0 0x4F000000 0x0 0x100000>;
 | 
								reg = <0x0 0x4F000000 0x0 0x100000>;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ramoops: ramoops@4f100000 {
 | 
				
			||||||
 | 
								compatible = "ramoops";
 | 
				
			||||||
 | 
								reg = <0x0 0x4f100000 0x0 0x80000>;
 | 
				
			||||||
 | 
								record-size = <0x20000>;
 | 
				
			||||||
 | 
								console-size = <0x20000>;
 | 
				
			||||||
 | 
								pmsg-size = <0x20000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
	#else
 | 
						#else
 | 
				
			||||||
	/*		 512MB/1GB Profiles
 | 
						/*		 512MB/1GB Profiles
 | 
				
			||||||
	 * +==========+==============+=========================+
 | 
						 * +==========+==============+=========================+
 | 
				
			||||||
@@ -288,6 +296,13 @@
 | 
				
			|||||||
			reg = <0x0 0x4F800000 0x0 0x500000>;
 | 
								reg = <0x0 0x4F800000 0x0 0x500000>;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ramoops: ramoops@4fd00000 {
 | 
				
			||||||
 | 
								compatible = "ramoops";
 | 
				
			||||||
 | 
								reg = <0x0 0x4fd00000 0x0 0x80000>;
 | 
				
			||||||
 | 
								record-size = <0x20000>;
 | 
				
			||||||
 | 
								console-size = <0x20000>;
 | 
				
			||||||
 | 
								pmsg-size = <0x20000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
	#endif
 | 
						#endif
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -93,6 +93,42 @@ define Device/edgecore_eap104
 | 
				
			|||||||
endef
 | 
					endef
 | 
				
			||||||
TARGET_DEVICES += edgecore_eap104
 | 
					TARGET_DEVICES += edgecore_eap104
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/indio_um-325ax-v2
 | 
				
			||||||
 | 
					  DEVICE_TITLE := Indio UM-325ax-V2
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq5018-indio-um-325ax-v2
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := indio,um-325ax-v2
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-indio-um-325ax-v2 ath11k-firmware-ipq50xx-spruce ath11k-firmware-qcn6122
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@mp03.5-c1
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += indio_um-325ax-v2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/indio_um-335ax
 | 
				
			||||||
 | 
					  DEVICE_TITLE := Indio UM-335ax
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq5018-indio-um-335ax
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := indio,um-335ax
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-indio-um-335ax ath11k-firmware-qcn9000 ath11k-firmware-ipq50xx-spruce
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@mp03.1
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += indio_um-335ax
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/indio_um-525axp
 | 
				
			||||||
 | 
					  DEVICE_TITLE := Indio UM-525axp
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq5018-indio-um-525axp
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := indio,um-525axp
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-indio-um-525axp ath11k-firmware-ipq50xx-spruce ath11k-firmware-qcn6122
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@mp03.5-c1
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += indio_um-525axp
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/indio_um-525axm
 | 
				
			||||||
 | 
					  DEVICE_TITLE := Indio UM-525axm
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq5018-indio-um-525axm
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := indio,um-525axm
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-indio-um-525axm ath11k-firmware-ipq50xx-spruce ath11k-firmware-qcn6122
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@mp03.5-c1
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += indio_um-525axm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Device/udaya_a6_id2
 | 
					define Device/udaya_a6_id2
 | 
				
			||||||
  DEVICE_TITLE := Udaya A6 - ID2
 | 
					  DEVICE_TITLE := Udaya A6 - ID2
 | 
				
			||||||
  DEVICE_DTS := qcom-ipq5018-udaya-a6-id2
 | 
					  DEVICE_DTS := qcom-ipq5018-udaya-a6-id2
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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>;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -169,7 +169,8 @@
 | 
				
			|||||||
		compatible = "mediatek,eth-mac";
 | 
							compatible = "mediatek,eth-mac";
 | 
				
			||||||
		reg = <0>;
 | 
							reg = <0>;
 | 
				
			||||||
		phy-mode = "sgmii";
 | 
							phy-mode = "sgmii";
 | 
				
			||||||
		phy-handle = <&phy1>;      // add phy handler
 | 
							phy-handle = <&phy30>;
 | 
				
			||||||
 | 
							phy-handle2 = <&phy1>;
 | 
				
			||||||
		mtd-mac-address = <&factory 0x24>;
 | 
							mtd-mac-address = <&factory 0x24>;
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -193,6 +194,16 @@
 | 
				
			|||||||
			nvmem-cell-names = "phy-cal-data";
 | 
								nvmem-cell-names = "phy-cal-data";
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							phy30: ethernet-phy@30 { // AN8801SB
 | 
				
			||||||
 | 
								compatible = "ethernet-phy-idc0ff.0421";
 | 
				
			||||||
 | 
								reg = <30>; //0x1e
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
								full-duplex;
 | 
				
			||||||
 | 
								pause;
 | 
				
			||||||
 | 
								airoha,surge = <0>;
 | 
				
			||||||
 | 
								airoha,polarity = <2>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		phy1: ethernet-phy@1 {
 | 
							phy1: ethernet-phy@1 {
 | 
				
			||||||
			compatible = "ethernet-phy-id03a2.9471";
 | 
								compatible = "ethernet-phy-id03a2.9471";
 | 
				
			||||||
			reg = <24>;            // set phy address to 0x18
 | 
								reg = <24>;            // set phy address to 0x18
 | 
				
			||||||
@@ -201,7 +212,6 @@
 | 
				
			|||||||
			reset-deassert-us = <20000>;
 | 
								reset-deassert-us = <20000>;
 | 
				
			||||||
			phy-mode = "sgmii";
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
 | 
					 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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
 | 
				
			||||||
@@ -88,6 +93,11 @@ $(call Package/ath12k-wifi-default)
 | 
				
			|||||||
    TITLE:=board-2.bin for NWA130BE
 | 
					    TITLE:=board-2.bin for NWA130BE
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Package/ath12k-wifi-zyxel-nwa50be
 | 
				
			||||||
 | 
					$(call Package/ath12k-wifi-default)
 | 
				
			||||||
 | 
					    TITLE:=board-2.bin for NWA50BE
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Package/ath12k-wifi-cig-wf672
 | 
					define Package/ath12k-wifi-cig-wf672
 | 
				
			||||||
$(call Package/ath12k-wifi-default)
 | 
					$(call Package/ath12k-wifi-default)
 | 
				
			||||||
    TITLE:=board-2.bin for WF672
 | 
					    TITLE:=board-2.bin for WF672
 | 
				
			||||||
@@ -96,8 +106,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 +117,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 +161,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 +170,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
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -179,15 +196,24 @@ define Package/ath12k-wifi-zyxel-nwa130be/install
 | 
				
			|||||||
	$(INSTALL_DATA) ./board-2.bin.nwa130be.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin
 | 
						$(INSTALL_DATA) ./board-2.bin.nwa130be.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Package/ath12k-wifi-zyxel-nwa50be/install
 | 
				
			||||||
 | 
						$(INSTALL_DIR) $(1)/lib/firmware/ath12k/QCN6432/hw1.0/
 | 
				
			||||||
 | 
						$(INSTALL_DIR) $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/
 | 
				
			||||||
 | 
						$(INSTALL_DATA) ./board-2.bin.nwa50be.QCN6432 $(1)/lib/firmware/ath12k/QCN6432/hw1.0/board-2.bin
 | 
				
			||||||
 | 
						$(INSTALL_DATA) ./board-2.bin.nwa50be.IPQ5332 $(1)/lib/firmware/ath12k/IPQ5332/hw1.0/board-2.bin
 | 
				
			||||||
 | 
						$(INSTALL_DATA) ./ipq5332_qcn6432.regdb $(1)/lib/firmware/ath12k/QCN6432/hw1.0/regdb.bin
 | 
				
			||||||
 | 
					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))
 | 
				
			||||||
@@ -197,4 +223,5 @@ $(eval $(call BuildPackage,ath12k-wifi-cig-wf189h))
 | 
				
			|||||||
$(eval $(call BuildPackage,ath12k-wifi-sercomm-ap72tip))
 | 
					$(eval $(call BuildPackage,ath12k-wifi-sercomm-ap72tip))
 | 
				
			||||||
$(eval $(call BuildPackage,ath12k-wifi-sercomm-ap72tip-v4))
 | 
					$(eval $(call BuildPackage,ath12k-wifi-sercomm-ap72tip-v4))
 | 
				
			||||||
$(eval $(call BuildPackage,ath12k-wifi-zyxel-nwa130be))
 | 
					$(eval $(call BuildPackage,ath12k-wifi-zyxel-nwa130be))
 | 
				
			||||||
 | 
					$(eval $(call BuildPackage,ath12k-wifi-zyxel-nwa50be))
 | 
				
			||||||
$(eval $(call BuildPackage,ath12k-wifi-cig-wf672))
 | 
					$(eval $(call BuildPackage,ath12k-wifi-cig-wf672))
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										20
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2-nwa50be-IPQ5332.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2-nwa50be-IPQ5332.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,20 @@
 | 
				
			|||||||
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "board": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "names": [
 | 
				
			||||||
 | 
					                    "bus=ahb,qmi-chip-id=0,qmi-board-id=18"
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                "data": "nwa50be-IPQ5332.bin"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "regdb": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "names": [
 | 
				
			||||||
 | 
					                    "bus=ahb,qmi-chip-id=0,qmi-board-id=18"
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                "data": "ipq5332.regdb"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					]
 | 
				
			||||||
							
								
								
									
										20
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2-nwa50be-QCN6432.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2-nwa50be-QCN6432.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,20 @@
 | 
				
			|||||||
 | 
					[
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        "board": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "names": [
 | 
				
			||||||
 | 
					                    "bus=ahb,qmi-chip-id=0,qmi-board-id=112"
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                "data": "nwa50be-QCN6432.bin"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "regdb": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "names": [
 | 
				
			||||||
 | 
					                    "bus=ahb,qmi-chip-id=0,qmi-board-id=112"
 | 
				
			||||||
 | 
					                ],
 | 
				
			||||||
 | 
					                "data": "ipq5332_qcn6432.regdb"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ]
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					]
 | 
				
			||||||
										
											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.nwa50be.IPQ5332
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2.bin.nwa50be.IPQ5332
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2.bin.nwa50be.QCN6432
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/board-2.bin.nwa50be.QCN6432
									
									
									
									
									
										Normal file
									
								
							
										
											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.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							@@ -18,3 +18,6 @@ $encoder -c board-2-ap72tip-v4-QCN92XX.json -o board-2.bin.ap72tip-v4.QCN92XX
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
$encoder -c board-2-nwa130be-IPQ5332.json -o board-2.bin.nwa130be.IPQ5332
 | 
					$encoder -c board-2-nwa130be-IPQ5332.json -o board-2.bin.nwa130be.IPQ5332
 | 
				
			||||||
$encoder -c board-2-nwa130be-QCN92XX.json -o board-2.bin.nwa130be.QCN92XX
 | 
					$encoder -c board-2-nwa130be-QCN92XX.json -o board-2.bin.nwa130be.QCN92XX
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$encoder -c board-2-nwa50be-IPQ5332.json -o board-2.bin.nwa50be.IPQ5332
 | 
				
			||||||
 | 
					$encoder -c board-2-nwa50be-QCN6432.json -o board-2.bin.nwa50be.QCN6432
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/nwa50be-IPQ5332.bin
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/nwa50be-IPQ5332.bin
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/nwa50be-QCN6432.bin
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/qca-wifi-7/ath12k-wifi/nwa50be-QCN6432.bin
									
									
									
									
									
										Executable file
									
								
							
										
											Binary file not shown.
										
									
								
							@@ -24,7 +24,9 @@ endef
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
define KernelPackage/cig-wifi-mode-sw/install
 | 
					define KernelPackage/cig-wifi-mode-sw/install
 | 
				
			||||||
	$(INSTALL_DIR) $(1)/usr/sbin/
 | 
						$(INSTALL_DIR) $(1)/usr/sbin/
 | 
				
			||||||
 | 
						$(INSTALL_DIR) $(1)/etc/init.d/
 | 
				
			||||||
	$(INSTALL_BIN) ./files/cig_wifi_mode_sw $(1)/usr/sbin/cig_wms
 | 
						$(INSTALL_BIN) ./files/cig_wifi_mode_sw $(1)/usr/sbin/cig_wms
 | 
				
			||||||
 | 
						$(INSTALL_BIN) ./files/cig_wifi_mode_boot $(1)/etc/init.d/cig_wmb
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(eval $(call KernelPackage,cig-wifi-mode-sw))
 | 
					$(eval $(call KernelPackage,cig-wifi-mode-sw))
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										13
									
								
								feeds/qca-wifi-7/cig-platform-pkg/cig-wifi-mode-sw/files/cig_wifi_mode_boot
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										13
									
								
								feeds/qca-wifi-7/cig-platform-pkg/cig-wifi-mode-sw/files/cig_wifi_mode_boot
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,13 @@
 | 
				
			|||||||
 | 
					#!/bin/sh /etc/rc.common
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					START=60
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					boot(){
 | 
				
			||||||
 | 
						local bands=$(cat /proc/rf_switch)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if [ "x$bands" = "x3" ]; then
 | 
				
			||||||
 | 
							echo "AFC is not ready, switch to 2-band mode" >/dev/console
 | 
				
			||||||
 | 
							echo 2 > /proc/rf_switch
 | 
				
			||||||
 | 
							firstboot -y -r
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -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);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -259,8 +259,13 @@ const phy_proto = {
 | 
				
			|||||||
			addr[0] ^= idx << 2;
 | 
								addr[0] ^= idx << 2;
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
		case "b5":
 | 
							case "b5":
 | 
				
			||||||
			if (mbssid)
 | 
								if (mbssid) {
 | 
				
			||||||
 | 
									let b5 = addr[5];
 | 
				
			||||||
 | 
									addr[5] = addr[3];
 | 
				
			||||||
 | 
									addr[3] = b5;
 | 
				
			||||||
 | 
									addr[5] &= ~0xf;
 | 
				
			||||||
				addr[0] |= 2;
 | 
									addr[0] |= 2;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
			addr[5] ^= idx;
 | 
								addr[5] ^= idx;
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
		default:
 | 
							default:
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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,15 +13,18 @@ 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)
 | 
				
			||||||
 | 
							ucidef_set_interfaces_lan_wan "eth1" "eth0"
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
	sonicfi,rap750w-311a)
 | 
						sonicfi,rap750w-311a)
 | 
				
			||||||
		ucidef_set_interfaces_lan_wan "eth1" "eth0"
 | 
							ucidef_set_interfaces_lan_wan "eth1" "eth0"
 | 
				
			||||||
 | 
							ucidef_add_switch "switch1" "0u@eth1" "3:lan" "2:lan" "1:lan"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	sonicfi,rap7110c-341x|\
 | 
						sonicfi,rap7110c-341x|\
 | 
				
			||||||
	sonicfi,rap750e-h|\
 | 
						sonicfi,rap750e-h|\
 | 
				
			||||||
	sonicfi,rap750e-s)
 | 
						sonicfi,rap750e-s|\
 | 
				
			||||||
 | 
						zyxel,nwa50be)
 | 
				
			||||||
		ucidef_set_interfaces_lan_wan "" "eth0"
 | 
							ucidef_set_interfaces_lan_wan "" "eth0"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	cig,wf189w)
 | 
						cig,wf189w)
 | 
				
			||||||
@@ -32,6 +35,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 +111,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)
 | 
				
			||||||
@@ -123,6 +131,16 @@ qcom_setup_macs()
 | 
				
			|||||||
		ucidef_set_wireless_macaddr_base 5g $(macaddr_add "$wan_mac" 3)
 | 
							ucidef_set_wireless_macaddr_base 5g $(macaddr_add "$wan_mac" 3)
 | 
				
			||||||
		ucidef_set_wireless_macaddr_base 6g $(macaddr_add "$wan_mac" 4)
 | 
							ucidef_set_wireless_macaddr_base 6g $(macaddr_add "$wan_mac" 4)
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
 | 
						zyxel,nwa50be)
 | 
				
			||||||
 | 
							wan_mac=$(cat /proc/cmdline)
 | 
				
			||||||
 | 
							wan_mac="${wan_mac##*hwaddr=}"
 | 
				
			||||||
 | 
							wan_mac="${wan_mac%% *}"
 | 
				
			||||||
 | 
							wan_mac="$(echo ${wan_mac} | sed 's/\(..\)/\1:/g;s/:$//')"
 | 
				
			||||||
 | 
							ucidef_set_network_device_mac eth0 $wan_mac
 | 
				
			||||||
 | 
							ucidef_set_label_macaddr $wan_mac
 | 
				
			||||||
 | 
							ucidef_set_wireless_macaddr_base 2g $(macaddr_add "$wan_mac" 1)
 | 
				
			||||||
 | 
							ucidef_set_wireless_macaddr_base 5g $(macaddr_add "$wan_mac" 2)
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
        *)
 | 
					        *)
 | 
				
			||||||
                wan_mac=$(cat /sys/class/net/eth1/address)
 | 
					                wan_mac=$(cat /sys/class/net/eth1/address)
 | 
				
			||||||
                lan_mac=$(macaddr_add "$wan_mac" 1)
 | 
					                lan_mac=$(macaddr_add "$wan_mac" 1)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -64,9 +64,11 @@ 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|\
 | 
				
			||||||
 | 
						zyxel,nwa50be)
 | 
				
			||||||
		caldata_extract "0:ART" 0x1000 0x20000
 | 
							caldata_extract "0:ART" 0x1000 0x20000
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	cig,wf672)
 | 
						cig,wf672)
 | 
				
			||||||
@@ -86,6 +88,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)
 | 
				
			||||||
@@ -122,6 +125,50 @@ ath12k/QCN6432/hw1.0/cal-ahb-soc@0:wifi2@c0000000.bin)
 | 
				
			|||||||
	cig,wf189w)
 | 
						cig,wf189w)
 | 
				
			||||||
		caldata_extract "0:ART" 0x58800 0x20000
 | 
							caldata_extract "0:ART" 0x58800 0x20000
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
 | 
						zyxel,nwa50be)
 | 
				
			||||||
 | 
							caldata_extract "0:ART" 0x58800 0x2d000
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
 | 
						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
 | 
						esac
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
*)
 | 
					*)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -9,14 +9,5 @@ boot() {
 | 
				
			|||||||
	edgecore,eap105)
 | 
						edgecore,eap105)
 | 
				
			||||||
		ssdk_sh debug phy set 0x1 0x601FD032 0xff
 | 
							ssdk_sh debug phy set 0x1 0x601FD032 0xff
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	zyxel,nwa130be)
 | 
					 | 
				
			||||||
		#eth0: APPE: phyaddr 4  green:2.5G  orange:others
 | 
					 | 
				
			||||||
		ssdk_sh debug phy set 4 0x40078074 0x670
 | 
					 | 
				
			||||||
		ssdk_sh debug phy set 4 0x40078078 0x8600
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		#eth1:  MHT: phyaddr 3  green:2.5G orange:others
 | 
					 | 
				
			||||||
		ssdk_sh debug phy set 3 0x40078074 0x670
 | 
					 | 
				
			||||||
		ssdk_sh debug phy set 3 0x40078078 0x8600
 | 
					 | 
				
			||||||
		;;
 | 
					 | 
				
			||||||
	esac
 | 
						esac
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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
 | 
				
			||||||
@@ -173,7 +174,8 @@ platform_do_upgrade() {
 | 
				
			|||||||
		sonicfi_dualimage_check
 | 
							sonicfi_dualimage_check
 | 
				
			||||||
		nand_upgrade_tar "$1"
 | 
							nand_upgrade_tar "$1"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	zyxel,nwa130be)
 | 
						zyxel,nwa130be|\
 | 
				
			||||||
 | 
						zyxel,nwa50be)
 | 
				
			||||||
		nand_upgrade_tar "$1"
 | 
							nand_upgrade_tar "$1"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	esac
 | 
						esac
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1180,7 +1180,7 @@ CONFIG_QTI_LICENSE_MANAGER=y
 | 
				
			|||||||
# CONFIG_SYMBOLIC_ERRNAME is not set
 | 
					# CONFIG_SYMBOLIC_ERRNAME is not set
 | 
				
			||||||
# CONFIG_LEDS_BRIGHTNESS_HW_CHANGED is not set
 | 
					# CONFIG_LEDS_BRIGHTNESS_HW_CHANGED is not set
 | 
				
			||||||
# CONFIG_LEDS_CLASS_MULTICOLOR is not set
 | 
					# CONFIG_LEDS_CLASS_MULTICOLOR is not set
 | 
				
			||||||
# CONFIG_LEDS_TRIGGER_HEARTBEAT is not set
 | 
					CONFIG_LEDS_TRIGGER_HEARTBEAT=y 
 | 
				
			||||||
# CONFIG_MITIGATE_SPECTRE_BRANCH_HISTORY is not set
 | 
					# CONFIG_MITIGATE_SPECTRE_BRANCH_HISTORY is not set
 | 
				
			||||||
# CONFIG_PINCTRL_SINGLE is not set
 | 
					# CONFIG_PINCTRL_SINGLE is not set
 | 
				
			||||||
# CONFIG_RANDOM_TRUST_BOOTLOADER is not set
 | 
					# CONFIG_RANDOM_TRUST_BOOTLOADER is not set
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										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>;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,6 +18,21 @@
 | 
				
			|||||||
	model = "Zyxel NWA130BE";
 | 
						model = "Zyxel NWA130BE";
 | 
				
			||||||
	compatible = "zyxel,nwa130be", "qcom,ipq5332-ap-mi01.6", "qcom,ipq5332-rdp468", "qcom,ipq5332";
 | 
						compatible = "zyxel,nwa130be", "qcom,ipq5332-ap-mi01.6", "qcom,ipq5332-rdp468", "qcom,ipq5332";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reserved-memory {
 | 
				
			||||||
 | 
							#address-cells = <2>;
 | 
				
			||||||
 | 
							#size-cells = <2>;
 | 
				
			||||||
 | 
							ranges;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ramoops@49c00000 {
 | 
				
			||||||
 | 
								compatible = "ramoops";
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x49c00000 0x0 0x100000>;
 | 
				
			||||||
 | 
								record-size = <0x20000>;
 | 
				
			||||||
 | 
								console-size = <0x20000>;
 | 
				
			||||||
 | 
								pmsg-size = <0x20000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	aliases {
 | 
						aliases {
 | 
				
			||||||
		serial0 = &blsp1_uart0;
 | 
							serial0 = &blsp1_uart0;
 | 
				
			||||||
		serial1 = &blsp1_uart1;
 | 
							serial1 = &blsp1_uart1;
 | 
				
			||||||
@@ -128,6 +143,26 @@
 | 
				
			|||||||
					blink_en = "enable";
 | 
										blink_en = "enable";
 | 
				
			||||||
					active = "high";
 | 
										active = "high";
 | 
				
			||||||
				};
 | 
									};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									qcom,port_ledinfo {
 | 
				
			||||||
 | 
										port@1 {
 | 
				
			||||||
 | 
											port = <2>;
 | 
				
			||||||
 | 
											led_source@0 {
 | 
				
			||||||
 | 
												source = <0>;
 | 
				
			||||||
 | 
												mode = "normal";
 | 
				
			||||||
 | 
												speed = "2500M";
 | 
				
			||||||
 | 
												active = "high";
 | 
				
			||||||
 | 
												blink_en = "enable";
 | 
				
			||||||
 | 
											};
 | 
				
			||||||
 | 
											led_source@1 {
 | 
				
			||||||
 | 
												source = <1>;
 | 
				
			||||||
 | 
												mode = "normal";
 | 
				
			||||||
 | 
												speed = "10M", "100M","1000M";
 | 
				
			||||||
 | 
												active = "high";
 | 
				
			||||||
 | 
												blink_en = "enable";
 | 
				
			||||||
 | 
											};
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
			};
 | 
								};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
			ess-switch1@1 {
 | 
								ess-switch1@1 {
 | 
				
			||||||
@@ -164,6 +199,26 @@
 | 
				
			|||||||
					};
 | 
										};
 | 
				
			||||||
				};
 | 
									};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									qcom,port_ledinfo {
 | 
				
			||||||
 | 
										port@3 {
 | 
				
			||||||
 | 
											port = <3>;
 | 
				
			||||||
 | 
											led_source@0 {
 | 
				
			||||||
 | 
												source = <0>;
 | 
				
			||||||
 | 
												mode = "normal";
 | 
				
			||||||
 | 
												speed = "2500M";
 | 
				
			||||||
 | 
												active = "high";
 | 
				
			||||||
 | 
												blink_en = "enable";
 | 
				
			||||||
 | 
											};
 | 
				
			||||||
 | 
											led_source@1 {
 | 
				
			||||||
 | 
												source = <1>;
 | 
				
			||||||
 | 
												mode = "normal";
 | 
				
			||||||
 | 
												speed = "10M", "100M","1000M";
 | 
				
			||||||
 | 
												active = "high";
 | 
				
			||||||
 | 
												blink_en = "enable";
 | 
				
			||||||
 | 
											};
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
				led_source@2 {
 | 
									led_source@2 {
 | 
				
			||||||
					source = <2>;
 | 
										source = <2>;
 | 
				
			||||||
					mode = "normal";
 | 
										mode = "normal";
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										956
									
								
								feeds/qca-wifi-7/ipq53xx/dts/ipq5332-zyxel-nwa50be.dts
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										956
									
								
								feeds/qca-wifi-7/ipq53xx/dts/ipq5332-zyxel-nwa50be.dts
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,956 @@
 | 
				
			|||||||
 | 
					// SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause)
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * IPQ5332 RDP442 board device tree source
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * Copyright (c) 2020-2021 The Linux Foundation. All rights reserved.
 | 
				
			||||||
 | 
					 * Copyright (c) 2022-2024 Qualcomm Innovation Center, Inc. All rights reserved.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "ipq5332.dtsi"
 | 
				
			||||||
 | 
					#include <dt-bindings/gpio/gpio.h>
 | 
				
			||||||
 | 
					#include <dt-bindings/input/input.h>
 | 
				
			||||||
 | 
					#include <dt-bindings/leds/common.h>
 | 
				
			||||||
 | 
					#include "ipq5332-default-memory.dtsi"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						model = "Qualcomm Technologies, Inc. IPQ5332/RDP442/AP-MI01.3";
 | 
				
			||||||
 | 
						compatible = "zyxel,nwa50be", "qcom,ipq5332-ap-mi01.3", "qcom,ipq5332-rdp442", "qcom,ipq5332";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_512_MB__
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/*     512M  Layout for IPQ5332 + QCN6432 + QCN6432
 | 
				
			||||||
 | 
						 * +==========+==============+========================+
 | 
				
			||||||
 | 
						 * |         |              |                         |
 | 
				
			||||||
 | 
						 * |  Region | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |         |              |                         |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |   Q6    |              |                         |
 | 
				
			||||||
 | 
						 * |  code/  |  0x4A900000  |          25MB           |
 | 
				
			||||||
 | 
						 * |  data   |              |                         |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						 * |  data   |  0x4C200000  |          17MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						 * | M3 Dump |  0x4D300000  |           1MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						 * |  QDSS   |  0x4D400000  |           1MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						 * |  CALDB  |  0x4D500000  |           3MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						 * |  data   |  0x4D800000  |          16MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						 * | M3 Dump |  0x4E800000  |           1MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						 * |  QDSS   |  0x4E900000  |           1MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						 * |  CALDB  |  0x4EA00000  |           5MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						 * |  data   |  0x4EF00000  |          16MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						 * | M3 Dump |  0x4FF00000  |           1MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						 * |  QDSS   |  0x50000000  |           1MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						 * |  CALDB  |  0x50100000  |           5MB           |
 | 
				
			||||||
 | 
						 * +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |         |              |                         |
 | 
				
			||||||
 | 
						 * |   MLO   |  0x50600000  |          12MB           |
 | 
				
			||||||
 | 
						 * +==================================================+
 | 
				
			||||||
 | 
						 * |                                                  |
 | 
				
			||||||
 | 
						 * |                                                  |
 | 
				
			||||||
 | 
						 * |                                                  |
 | 
				
			||||||
 | 
						 * |             Rest of memory for Linux             |
 | 
				
			||||||
 | 
						 * |                                                  |
 | 
				
			||||||
 | 
						 * |                                                  |
 | 
				
			||||||
 | 
						 * |                                                  |
 | 
				
			||||||
 | 
						 * +==================================================+
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						reserved-memory {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/delete-node/ m3_dump@4cc00000;
 | 
				
			||||||
 | 
							/delete-node/ q6_etr_dump@1;
 | 
				
			||||||
 | 
							/delete-node/ mlo_global_mem_0@0x4db00000;
 | 
				
			||||||
 | 
							/delete-node/ wcnss@4a900000;
 | 
				
			||||||
 | 
							/delete-node/ q6_caldb_region@4ce00000;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_mem_regions: q6_mem_regions@4A900000  {
 | 
				
			||||||
 | 
								reg = <0x0 0x4a900000 0x0 0x5D00000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4A900000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4a900000 0x0 0x1900000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5332_data: q6_ipq5332_data@4C200000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4C200000 0x0 0x1100000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D300000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4D300000 0x0 0x100000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D400000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4D400000 0x0 0x100000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5332_caldb: q6_ipq5332_caldb@4D500000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4D500000 0x0 0x300000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_data_1: q6_qcn6432_data_1@4D800000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4D800000 0x0 0x1000000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6432_1: m3_dump_qcn6432_1@4E800000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4E800000 0x0 0x100000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_etr_1: q6_qcn6432_etr_1@4E900000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4E900000 0x0 0x100000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_caldb_1: q6_qcn6432_caldb_1@4EA00000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4EA00000 0x0 0x500000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_data_2: q6_qcn6432_data_2@4EF00000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4EF00000 0x0 0x1000000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6432_2: m3_dump_qcn6432_2@4FF00000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x4FF00000 0x0 0x100000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_etr_2: q6_qcn6432_etr_2@50000000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x50000000 0x0 0x100000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_caldb_2: q6_qcn6432_caldb_2@50100000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x50100000 0x0 0x500000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mlo_global_mem0: mlo_global_mem_0@50600000 {
 | 
				
			||||||
 | 
								reg = <0x0 0x50600000 0x0 0xC00000>;
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/*  1G  Layout for IPQ5332 + QCN6432 + QCN6432
 | 
				
			||||||
 | 
						* +==========+==============+========================+
 | 
				
			||||||
 | 
						* |         |              |                         |
 | 
				
			||||||
 | 
						* |  Region | Start Offset |          Size           |
 | 
				
			||||||
 | 
						* |         |              |                         |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |   Q6    |              |                         |
 | 
				
			||||||
 | 
						* |  code/  |  0x4A900000  |          25MB           |
 | 
				
			||||||
 | 
						* |  data   |              |                         |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						* |  data   |  0x4C200000  |          21MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						* | M3 Dump |  0x4D700000  |           1MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						* |  QDSS   |  0x4D800000  |           1MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* | IPQ5332 |              |                         |
 | 
				
			||||||
 | 
						* |  CALDB  |  0x4D900000  |           5MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						* |  data   |  0x4DE00000  |          21MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						* | M3 Dump |  0x4F300000  |           1MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						* |  QDSS   |  0x4F400000  |           1MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_1|              |                         |
 | 
				
			||||||
 | 
						* |  CALDB  |  0x4F500000  |           5MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						* |  data   |  0x4FA00000  |          21MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						* | M3 Dump |  0x50F00000  |           1MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						* |  QDSS   |  0x51000000  |           1MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |QCN6432_2|              |                         |
 | 
				
			||||||
 | 
						* |  CALDB  |  0x51100000  |           5MB           |
 | 
				
			||||||
 | 
						* +---------+--------------+-------------------------+
 | 
				
			||||||
 | 
						* |         |              |                         |
 | 
				
			||||||
 | 
						* |   MLO   |  0x51600000  |          12MB           |
 | 
				
			||||||
 | 
						* +==================================================+
 | 
				
			||||||
 | 
						* |                                                  |
 | 
				
			||||||
 | 
						* |                                                  |
 | 
				
			||||||
 | 
						* |                                                  |
 | 
				
			||||||
 | 
						* |             Rest of memory for Linux             |
 | 
				
			||||||
 | 
						* |                                                  |
 | 
				
			||||||
 | 
						* |                                                  |
 | 
				
			||||||
 | 
						* |                                                  |
 | 
				
			||||||
 | 
						* +==================================================+
 | 
				
			||||||
 | 
						*/
 | 
				
			||||||
 | 
						reserved-memory {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/delete-node/ m3_dump@4cc00000;
 | 
				
			||||||
 | 
							/delete-node/ q6_etr_dump@1;
 | 
				
			||||||
 | 
							/delete-node/ mlo_global_mem_0@0x4db00000;
 | 
				
			||||||
 | 
							/delete-node/ wcnss@4a900000;
 | 
				
			||||||
 | 
							/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  {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4a900000 0x0 0x6D00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_code_data: q6_code_data@4A900000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4a900000 0x0 0x1900000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5332_data: q6_ipq5332_data@4C200000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4C200000 0x0 0x1500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump: m3_dump@4D700000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D700000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_etr_region: q6_etr_dump@4D800000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D800000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_ipq5332_caldb: q6_ipq5332_caldb@4D900000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4D900000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_data_1: q6_qcn6432_data_1@4DE00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4DE00000 0x0 0x1500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6432_1: m3_dump_qcn6432_1@4F300000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F300000 0x0 0x100000>;
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_etr_1: q6_qcn6432_etr_1@4F400000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F400000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_caldb_1: q6_qcn6432_caldb_1@4F500000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4F500000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_data_2: q6_qcn6432_data_2@4FA00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x4FA00000 0x0 0x1500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							m3_dump_qcn6432_2: m3_dump_qcn6432_2@50F00000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x50F00000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_etr_2: q6_qcn6432_etr_2@51000000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x51000000 0x0 0x100000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6_qcn6432_caldb_2: q6_qcn6432_caldb_2@51100000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x51100000 0x0 0x500000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mlo_global_mem0: mlo_global_mem_0@51600000 {
 | 
				
			||||||
 | 
								no-map;
 | 
				
			||||||
 | 
								reg = <0x0 0x51600000 0x0 0xC00000>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aliases {
 | 
				
			||||||
 | 
							serial0 = &blsp1_uart0;
 | 
				
			||||||
 | 
							serial1 = &blsp1_uart1;
 | 
				
			||||||
 | 
							ethernet0 = "/soc/dp1";
 | 
				
			||||||
 | 
							ethernet1 = "/soc/dp2";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						chosen {
 | 
				
			||||||
 | 
							stdout-path = "serial0";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						soc@0 {
 | 
				
			||||||
 | 
							mdio:mdio@90000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&mdio1_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								/*gpio22 is for wan napa, gpio51 for lan napa*/
 | 
				
			||||||
 | 
								phy-reset-gpio = <&tlmm 51 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								status = "okay";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								phy2: ethernet-phy@2 {
 | 
				
			||||||
 | 
									reg = <28>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							leds {
 | 
				
			||||||
 | 
								compatible = "gpio-leds";
 | 
				
			||||||
 | 
								pinctrl-0 = <&led_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								led_blue{
 | 
				
			||||||
 | 
									label = "led_blue";
 | 
				
			||||||
 | 
									gpio = <&tlmm 22 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
									linux,default-trigger = "led_blue";
 | 
				
			||||||
 | 
									default-state = "off";
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
								led_green {
 | 
				
			||||||
 | 
									label = "led_green";
 | 
				
			||||||
 | 
									gpio = <&tlmm 45 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
									linux,default-trigger = "led_green";
 | 
				
			||||||
 | 
									default-state = "on";
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
								led_white {
 | 
				
			||||||
 | 
									label = "led_white";
 | 
				
			||||||
 | 
									gpio = <&tlmm 43 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
									linux,default-trigger = "led_white";
 | 
				
			||||||
 | 
									default-state = "off";
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
								led_red {
 | 
				
			||||||
 | 
									label = "led_red";
 | 
				
			||||||
 | 
									gpio = <&tlmm 44 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
									linux,default-trigger = "led_red";
 | 
				
			||||||
 | 
									default-state = "off";
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							gpio_keys {
 | 
				
			||||||
 | 
								compatible = "gpio-keys";
 | 
				
			||||||
 | 
								pinctrl-0 = <&button_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "okay";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								button@1 {
 | 
				
			||||||
 | 
									label = "reset";
 | 
				
			||||||
 | 
									linux,code = <KEY_RESTART>;
 | 
				
			||||||
 | 
									gpios = <&tlmm 30 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
									linux,input-type = <1>;
 | 
				
			||||||
 | 
									debounce-interval = <60>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ess-instance {
 | 
				
			||||||
 | 
								ess-switch@3a000000 {
 | 
				
			||||||
 | 
									switch_cpu_bmp = <0x1>;  /* cpu port bitmap */
 | 
				
			||||||
 | 
									switch_lan_bmp = <0x4>; /* lan port bitmap */
 | 
				
			||||||
 | 
									switch_wan_bmp = <0x0>; /* wan port bitmap */
 | 
				
			||||||
 | 
									switch_mac_mode = <0xf>; /* mac mode for uniphy instance0*/
 | 
				
			||||||
 | 
									switch_mac_mode1 = <0xc>; /* mac mode for uniphy instance1*/
 | 
				
			||||||
 | 
									switch_mac_mode2 = <0xff>; /* mac mode for uniphy instance2*/
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <2>;
 | 
				
			||||||
 | 
											phy_address = <28>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
									qcom,port_ledinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port = <2>;
 | 
				
			||||||
 | 
											led_source@0 {
 | 
				
			||||||
 | 
												source = <0>;
 | 
				
			||||||
 | 
												mode = "normal";
 | 
				
			||||||
 | 
												speed = "2500M";
 | 
				
			||||||
 | 
												active = "high";
 | 
				
			||||||
 | 
												blink_en = "enable";
 | 
				
			||||||
 | 
											};
 | 
				
			||||||
 | 
											led_source@1 {
 | 
				
			||||||
 | 
												source = <1>;
 | 
				
			||||||
 | 
												mode = "normal";
 | 
				
			||||||
 | 
												speed = "10M", "100M","1000M";
 | 
				
			||||||
 | 
												active = "high";
 | 
				
			||||||
 | 
												blink_en = "enable";
 | 
				
			||||||
 | 
											};
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							dp1 {
 | 
				
			||||||
 | 
								device_type = "network";
 | 
				
			||||||
 | 
								compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
								qcom,id = <2>;
 | 
				
			||||||
 | 
								reg = <0x3a504000 0x4000>;
 | 
				
			||||||
 | 
								qcom,mactype = <1>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								mdio-bus = <&mdio>;
 | 
				
			||||||
 | 
								qcom,phy-mdio-addr = <28>;
 | 
				
			||||||
 | 
								qcom,link-poll = <1>;
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nss-macsec0 {
 | 
				
			||||||
 | 
								compatible = "qcom,nss-macsec";
 | 
				
			||||||
 | 
								phy_addr = <28>;
 | 
				
			||||||
 | 
								mdiobus = <&mdio>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* 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 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 */
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							wsi: wsi {
 | 
				
			||||||
 | 
								id = <0>;
 | 
				
			||||||
 | 
								num_chip = <2>;
 | 
				
			||||||
 | 
								chip_info = <0 1 1>,
 | 
				
			||||||
 | 
									    <1 1 0>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							q6v5_wcss: remoteproc@d100000 {
 | 
				
			||||||
 | 
								boot-args = <0x1 0x4 0x3 0x0 0x26 0x2>,
 | 
				
			||||||
 | 
										<0x1 0x4 0x4 0x1 0x2f 0x2>;
 | 
				
			||||||
 | 
								memory-region = <&q6_mem_regions>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								/delete-node/ remoteproc_pd1;
 | 
				
			||||||
 | 
								/delete-node/ remoteproc_pd2;
 | 
				
			||||||
 | 
								/delete-node/ remoteproc_pd3;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								q6_wcss_pd4: remoteproc_pd4 {
 | 
				
			||||||
 | 
									compatible = "qcom,ipq5332-mpd-upd-text";
 | 
				
			||||||
 | 
									firmware = "IPQ5332/q6_fw4.mdt";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									q6_wcss_pd1: remoteproc_pd1 {
 | 
				
			||||||
 | 
										compatible = "qcom,ipq5332-wcss-ahb-mpd";
 | 
				
			||||||
 | 
										firmware = "IPQ5332/q6_fw1.mdt";
 | 
				
			||||||
 | 
										m3_firmware = "IPQ5332/iu_fw.mdt";
 | 
				
			||||||
 | 
										interrupts-extended = <&wcss_smp2p_in 8 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 9 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 12 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 11 0>;
 | 
				
			||||||
 | 
										interrupt-names = "fatal",
 | 
				
			||||||
 | 
												"ready",
 | 
				
			||||||
 | 
												"spawn-ack",
 | 
				
			||||||
 | 
												"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										qcom,smem-states = <&wcss_smp2p_out 8>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_out 9>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_out 10>;
 | 
				
			||||||
 | 
										qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
													"stop",
 | 
				
			||||||
 | 
													"spawn";
 | 
				
			||||||
 | 
										memory-region = <&q6_ipq5332_data>,
 | 
				
			||||||
 | 
												<&m3_dump>,
 | 
				
			||||||
 | 
												<&q6_etr_region>,
 | 
				
			||||||
 | 
												<&q6_ipq5332_caldb>;
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									q6_wcss_pd2: remoteproc_pd2 {
 | 
				
			||||||
 | 
										compatible = "qcom,ipq5332-wcss-pcie-mpd";
 | 
				
			||||||
 | 
										firmware = "IPQ5332/q6_fw2.mdt";
 | 
				
			||||||
 | 
										m3_firmware = "qcn6432/iu_fw.mdt";
 | 
				
			||||||
 | 
										interrupts-extended = <&wcss_smp2p_in 16 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 17 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 20 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 19 0>;
 | 
				
			||||||
 | 
										interrupt-names = "fatal",
 | 
				
			||||||
 | 
												"ready",
 | 
				
			||||||
 | 
												"spawn-ack",
 | 
				
			||||||
 | 
												"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										qcom,smem-states = <&wcss_smp2p_out 16>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_out 17>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_out 18>;
 | 
				
			||||||
 | 
										qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
													"stop",
 | 
				
			||||||
 | 
													"spawn";
 | 
				
			||||||
 | 
										memory-region = <&q6_qcn6432_data_1>,
 | 
				
			||||||
 | 
												<&m3_dump_qcn6432_1>,
 | 
				
			||||||
 | 
												<&q6_qcn6432_etr_1>,
 | 
				
			||||||
 | 
												<&q6_qcn6432_caldb_1>;
 | 
				
			||||||
 | 
										status = "okay";
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									q6_wcss_pd3: remoteproc_pd3 {
 | 
				
			||||||
 | 
										compatible = "qcom,ipq5332-wcss-pcie-mpd";
 | 
				
			||||||
 | 
										firmware = "IPQ5332/q6_fw3.mdt";
 | 
				
			||||||
 | 
										interrupts-extended = <&wcss_smp2p_in 24 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 25 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 28 0>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_in 27 0>;
 | 
				
			||||||
 | 
										interrupt-names = "fatal",
 | 
				
			||||||
 | 
												"ready",
 | 
				
			||||||
 | 
												"spawn-ack",
 | 
				
			||||||
 | 
												"stop-ack";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										qcom,smem-states = <&wcss_smp2p_out 24>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_out 25>,
 | 
				
			||||||
 | 
												<&wcss_smp2p_out 26>;
 | 
				
			||||||
 | 
										qcom,smem-state-names = "shutdown",
 | 
				
			||||||
 | 
													"stop",
 | 
				
			||||||
 | 
													"spawn";
 | 
				
			||||||
 | 
										memory-region = <&q6_qcn6432_data_2>,
 | 
				
			||||||
 | 
												<&m3_dump_qcn6432_2>,
 | 
				
			||||||
 | 
												<&q6_qcn6432_etr_2>,
 | 
				
			||||||
 | 
												<&q6_qcn6432_caldb_2>;
 | 
				
			||||||
 | 
										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";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&blsp1_i2c1 {
 | 
				
			||||||
 | 
						clock-frequency  = <400000>;
 | 
				
			||||||
 | 
						pinctrl-0 = <&i2c_1_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&blsp1_spi0 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&spi_0_data_clk_pins &spi_0_cs_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "okay";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						flash@0 {
 | 
				
			||||||
 | 
							compatible = "n25q128a11", "micron,n25q128a11", "jedec,spi-nor";
 | 
				
			||||||
 | 
							reg = <0>;
 | 
				
			||||||
 | 
							#address-cells = <1>;
 | 
				
			||||||
 | 
							#size-cells = <1>;
 | 
				
			||||||
 | 
							spi-max-frequency = <50000000>;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&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>;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* PINCTRL */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						led_pins: led_pins {
 | 
				
			||||||
 | 
							board_info {
 | 
				
			||||||
 | 
								pins = "gpio2", "gpio3";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
								input-enable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							apd_dc_in {
 | 
				
			||||||
 | 
								pins = "gpio24";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down; //Adapter un-plug
 | 
				
			||||||
 | 
								input-enable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							poe_status {
 | 
				
			||||||
 | 
								pins = "gpio34";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up; //AF
 | 
				
			||||||
 | 
								input-enable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* To MR pin */
 | 
				
			||||||
 | 
							rst_mb {
 | 
				
			||||||
 | 
								pins = "gpio29";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								output-high;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_blue {
 | 
				
			||||||
 | 
								pins = "gpio22";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_green {
 | 
				
			||||||
 | 
								pins = "gpio45";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_white {
 | 
				
			||||||
 | 
								pins = "gpio43";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_red {
 | 
				
			||||||
 | 
								pins = "gpio44";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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 {
 | 
				
			||||||
 | 
							pins = "gpio33", "gpio34", "gpio35", "gpio36";
 | 
				
			||||||
 | 
							function = "blsp1_uart2";
 | 
				
			||||||
 | 
							drive-strength = <8>;
 | 
				
			||||||
 | 
							bias-pull-up;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						i2c_1_pins: i2c-1-state {
 | 
				
			||||||
 | 
							pins = "gpio29", "gpio30";
 | 
				
			||||||
 | 
							function = "blsp1_i2c0";
 | 
				
			||||||
 | 
							drive-strength = <8>;
 | 
				
			||||||
 | 
							bias-pull-up;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						button_pins: button-state {
 | 
				
			||||||
 | 
							pins = "gpio35";
 | 
				
			||||||
 | 
							function = "gpio";
 | 
				
			||||||
 | 
							drive-strength = <8>;
 | 
				
			||||||
 | 
							bias-pull-up;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						pwm_pins: pwm-state {
 | 
				
			||||||
 | 
							pins = "gpio46";
 | 
				
			||||||
 | 
							function = "pwm0";
 | 
				
			||||||
 | 
							drive-strength = <8>;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mdio1_pins: mdio1-state {
 | 
				
			||||||
 | 
							mux_0 {
 | 
				
			||||||
 | 
								pins = "gpio27";
 | 
				
			||||||
 | 
								function = "mdc1";
 | 
				
			||||||
 | 
								drive-strength = <2>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							mux_1 {
 | 
				
			||||||
 | 
								pins = "gpio28";
 | 
				
			||||||
 | 
								function = "mdio1";
 | 
				
			||||||
 | 
								drive-strength = <2>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&license_manager {
 | 
				
			||||||
 | 
						status = "okay";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&usb3 {
 | 
				
			||||||
 | 
						qcom,select-utmi-as-pipe-clk;
 | 
				
			||||||
 | 
						status = "okay";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						dwc3@8a00000 {
 | 
				
			||||||
 | 
							/delete-property/ #phy-cells;
 | 
				
			||||||
 | 
							/delete-property/ phys;
 | 
				
			||||||
 | 
							/delete-property/ phy-names;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&pwm {
 | 
				
			||||||
 | 
						pinctrl-0 = <&pwm_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "okay";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&hs_m31phy_0 {
 | 
				
			||||||
 | 
						status = "okay";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi0 {
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd1>;
 | 
				
			||||||
 | 
						qcom,rproc_rpd = <&q6v5_wcss>;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd1";
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4C200000 0x4C200000 0x4C200000 0x0 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4D900000 0x4D500000 0x0 0x0 0x0 0x0>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_512_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x300000>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <0>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x12>;
 | 
				
			||||||
 | 
					#if defined(__CNSS2__)
 | 
				
			||||||
 | 
						mem-region = <&q6_ipq5332_data>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_ipq5332_data>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,wsi = <&wsi>;
 | 
				
			||||||
 | 
						qcom,wsi_index = <0>;
 | 
				
			||||||
 | 
						status = "okay";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi1 {
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd2>;
 | 
				
			||||||
 | 
						qcom,rproc_rpd = <&q6v5_wcss>;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd2";
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4DE00000 0x4D800000 0x0 0x0 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4F500000 0x4EA00000 0x0 0x0 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,umac-irq-reset-addr = <0x20000884>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_512_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <0>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x060>;
 | 
				
			||||||
 | 
					#if defined(__CNSS2__)
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6432_data_1>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6432_data_1>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,wsi = <&wsi>;
 | 
				
			||||||
 | 
						qcom,wsi_index = <1>;
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
						interrupts = <GIC_SPI 33 IRQ_TYPE_EDGE_RISING>;
 | 
				
			||||||
 | 
						interrupt-names = "umac_reset";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi2 {
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,rproc = <&q6_wcss_pd3>;
 | 
				
			||||||
 | 
						qcom,rproc_rpd = <&q6v5_wcss>;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd3";
 | 
				
			||||||
 | 
						qcom,bdf-addr = <0x4FA00000 0x4EF00000 0x4FA00000 0x0 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x51100000 0x50100000 0x51100000 0x0 0x0 0x0>;
 | 
				
			||||||
 | 
						qcom,umac-irq-reset-addr = <0x18000884>;
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
					#ifdef __IPQ_MEM_PROFILE_512_MB__
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <1>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,tgt-mem-mode = <0>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,board_id = <0x070>;
 | 
				
			||||||
 | 
					#if defined(__CNSS2__)
 | 
				
			||||||
 | 
						mem-region = <&q6_qcn6432_data_2>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						memory-region = <&q6_qcn6432_data_2>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,wsi = <&wsi>;
 | 
				
			||||||
 | 
						qcom,wsi_index = <1>;
 | 
				
			||||||
 | 
						qcom,wide_band = <1>;
 | 
				
			||||||
 | 
						status = "okay";
 | 
				
			||||||
 | 
						interrupts = <GIC_SPI 410 IRQ_TYPE_EDGE_RISING>;
 | 
				
			||||||
 | 
						interrupt-names = "umac_reset";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -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
 | 
				
			||||||
@@ -149,6 +162,22 @@ define Device/zyxel_nwa130be
 | 
				
			|||||||
endef
 | 
					endef
 | 
				
			||||||
TARGET_DEVICES += zyxel_nwa130be
 | 
					TARGET_DEVICES += zyxel_nwa130be
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/zyxel_nwa50be
 | 
				
			||||||
 | 
					  DEVICE_TITLE := Zyxel NWA50BE
 | 
				
			||||||
 | 
					  DEVICE_DTS := ipq5332-zyxel-nwa50be
 | 
				
			||||||
 | 
					  DEVICE_DTS_DIR := ../dts
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@mi01.3
 | 
				
			||||||
 | 
					  IMAGES := sysupgrade.tar nand-factory.bin nand-factory.ubi
 | 
				
			||||||
 | 
					  BLOCKSIZE := 128k
 | 
				
			||||||
 | 
					  PAGESIZE := 2048
 | 
				
			||||||
 | 
					  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-zyxel-nwa50be ath12k-firmware-ipq5332-peb-peb -ath12k-firmware-qcn92xx
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += zyxel_nwa50be
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Device/cig_wf672
 | 
					define Device/cig_wf672
 | 
				
			||||||
  DEVICE_TITLE := CIG WF672
 | 
					  DEVICE_TITLE := CIG WF672
 | 
				
			||||||
  DEVICE_DTS := ipq5332-cig-wf672
 | 
					  DEVICE_DTS := ipq5332-cig-wf672
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,33 @@
 | 
				
			|||||||
 | 
					From f7b27331b915477cd289c37b56efb0d28b2d6f38 Mon Sep 17 00:00:00 2001
 | 
				
			||||||
 | 
					From: Antonio Wu <antonio.wu@cybertan.com.tw>
 | 
				
			||||||
 | 
					Date: Tue, 5 Aug 2025 10:39:58 +0000
 | 
				
			||||||
 | 
					Subject: [PATCH] Add IPQ_MEM_PROFILE in arm64 kconfig
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					---
 | 
				
			||||||
 | 
					 arch/arm64/Kconfig | 10 ++++++++++
 | 
				
			||||||
 | 
					 1 file changed, 10 insertions(+)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					diff --git a/arch/arm64/Kconfig b/arch/arm64/Kconfig
 | 
				
			||||||
 | 
					index 702a289..7864e79 100644
 | 
				
			||||||
 | 
					--- a/arch/arm64/Kconfig
 | 
				
			||||||
 | 
					+++ b/arch/arm64/Kconfig
 | 
				
			||||||
 | 
					@@ -2143,6 +2143,16 @@ config STACKPROTECTOR_PER_TASK
 | 
				
			||||||
 | 
					 	def_bool y
 | 
				
			||||||
 | 
					 	depends on STACKPROTECTOR && CC_HAVE_STACKPROTECTOR_SYSREG
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+config IPQ_MEM_PROFILE
 | 
				
			||||||
 | 
					+	int "Select Memory Profile"
 | 
				
			||||||
 | 
					+	range 0 1024
 | 
				
			||||||
 | 
					+	default 0
 | 
				
			||||||
 | 
					+	help
 | 
				
			||||||
 | 
					+	  This option select memory profile to be used, which defines
 | 
				
			||||||
 | 
					+	  the reserved memory configuration used in device tree.
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	  If unsure, say 0
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 # The GPIO number here must be sorted by descending number. In case of
 | 
				
			||||||
 | 
					 # a multiplatform kernel, we just want the highest value required by the
 | 
				
			||||||
 | 
					 # selected platforms.
 | 
				
			||||||
 | 
					-- 
 | 
				
			||||||
 | 
					2.17.1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -0,0 +1,63 @@
 | 
				
			|||||||
 | 
					Index: backports-6.5-rc3/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					===================================================================
 | 
				
			||||||
 | 
					--- backports-6.5-rc3.orig/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					+++ backports-6.5-rc3/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					@@ -13,35 +13,35 @@
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 /* Below temperatures are in celsius */
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_TEMP_LOW_MARK -100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL0_TEMP_HIGH_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_TEMP_LOW_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL0_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_TEMP_HIGH_MARK 115
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_TEMP_LOW_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_TEMP_LOW_MARK 115
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_TEMP_HIGH_MARK 125
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_V2_TEMP_LOW_MARK -100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL0_V2_TEMP_HIGH_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_TEMP_LOW_MARK 90
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_TEMP_HIGH_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_TEMP_LOW_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL4_V2_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL0_V2_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_TEMP_HIGH_MARK 115
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_TEMP_LOW_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL4_V2_TEMP_LOW_MARK 110
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL4_V2_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_DUTY_CYCLE 0
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_DUTY_CYCLE 50
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_DUTY_CYCLE 90
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_DUTY_CYCLE 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_DUTY_CYCLE 30
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_DUTY_CYCLE 50
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_DUTY_CYCLE 70
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL0_V2_DUTY_CYCLE ATH12K_THERMAL_LVL0_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_DUTY_CYCLE ATH12K_THERMAL_LVL0_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_DUTY_CYCLE ATH12K_THERMAL_LVL1_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_DUTY_CYCLE ATH12K_THERMAL_LVL2_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL4_V2_DUTY_CYCLE ATH12K_THERMAL_LVL3_DUTY_CYCLE
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL0_V2_DUTY_CYCLE 0
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_DUTY_CYCLE 20
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_DUTY_CYCLE 40
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_DUTY_CYCLE 80
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL4_V2_DUTY_CYCLE 100
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define THERMAL_CONFIG_POUT0                        0
 | 
				
			||||||
 | 
					 #define THERMAL_CONFIG_POUT1                        12
 | 
				
			||||||
@@ -0,0 +1,57 @@
 | 
				
			|||||||
 | 
					--- a/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					+++ b/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					@@ -13,34 +13,34 @@
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 /* Below temperatures are in celsius */
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_TEMP_LOW_MARK -100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL0_TEMP_HIGH_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_TEMP_LOW_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL0_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_TEMP_HIGH_MARK 115
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_TEMP_LOW_MARK 110
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL3_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_V2_TEMP_LOW_MARK -100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL0_V2_TEMP_HIGH_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_TEMP_LOW_MARK 90
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_TEMP_HIGH_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_TEMP_LOW_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL4_V2_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL0_V2_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_TEMP_HIGH_MARK 115
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_TEMP_LOW_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL4_V2_TEMP_LOW_MARK 110
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL4_V2_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_DUTY_CYCLE 0
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_DUTY_CYCLE 50
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_DUTY_CYCLE 90
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_DUTY_CYCLE 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_DUTY_CYCLE 30
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_DUTY_CYCLE 50
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_DUTY_CYCLE 70
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_V2_DUTY_CYCLE ATH12K_THERMAL_LVL0_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_DUTY_CYCLE ATH12K_THERMAL_LVL0_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_DUTY_CYCLE ATH12K_THERMAL_LVL1_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_DUTY_CYCLE ATH12K_THERMAL_LVL2_DUTY_CYCLE
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_DUTY_CYCLE ATH12K_THERMAL_LVL1_DUTY_CYCLE
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_DUTY_CYCLE ATH12K_THERMAL_LVL2_DUTY_CYCLE
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_DUTY_CYCLE ATH12K_THERMAL_LVL3_DUTY_CYCLE
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL4_V2_DUTY_CYCLE ATH12K_THERMAL_LVL3_DUTY_CYCLE
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define THERMAL_CONFIG_POUT0                        0
 | 
				
			||||||
@@ -0,0 +1,74 @@
 | 
				
			|||||||
 | 
					From 357da3320f8bcad056b905fb85cad3a29c343d31 Mon Sep 17 00:00:00 2001
 | 
				
			||||||
 | 
					From: YenLin Pan <yenlin.pan@zyxel.com.tw>
 | 
				
			||||||
 | 
					Date: Tue, 12 Aug 2025 15:41:39 +0800
 | 
				
			||||||
 | 
					Subject: [PATCH] thermal: thermal setting
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					lo0 -100 -hi0 105 -off0 0
 | 
				
			||||||
 | 
					lo1 95 -hi1 110 -off1 20
 | 
				
			||||||
 | 
					lo2 100 -hi2 115 -off2 60
 | 
				
			||||||
 | 
					lo3 105 -hi3 119 -off3 98
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Signed-off-by: YenLin Pan <YenLin.Pan@zyxel.com.tw>
 | 
				
			||||||
 | 
					---
 | 
				
			||||||
 | 
					 drivers/net/wireless/ath/ath12k/thermal.h | 34 +++++++++++------------
 | 
				
			||||||
 | 
					 1 file changed, 17 insertions(+), 17 deletions(-)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					diff --git a/drivers/net/wireless/ath/ath12k/thermal.h b/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					index 5c91906..e81f9a4 100644
 | 
				
			||||||
 | 
					--- a/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					+++ b/drivers/net/wireless/ath/ath12k/thermal.h
 | 
				
			||||||
 | 
					@@ -13,34 +13,34 @@
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 /* Below temperatures are in celsius */
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_TEMP_LOW_MARK -100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL0_TEMP_HIGH_MARK 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL0_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL1_TEMP_LOW_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_TEMP_HIGH_MARK 115
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL3_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_TEMP_HIGH_MARK 119
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_V2_TEMP_LOW_MARK -100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL0_V2_TEMP_HIGH_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_TEMP_LOW_MARK 90
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_TEMP_HIGH_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_TEMP_LOW_MARK 95
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL0_V2_TEMP_HIGH_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_TEMP_LOW_MARK 95
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_TEMP_HIGH_MARK 110
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_TEMP_LOW_MARK 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_TEMP_HIGH_MARK 115
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_TEMP_HIGH_MARK 119
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL4_V2_TEMP_LOW_MARK 105
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL4_V2_TEMP_HIGH_MARK 120
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_DUTY_CYCLE 0
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_DUTY_CYCLE 50
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_DUTY_CYCLE 90
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_DUTY_CYCLE 100
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_DUTY_CYCLE 20
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_DUTY_CYCLE 60
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_DUTY_CYCLE 98
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL0_V2_DUTY_CYCLE ATH12K_THERMAL_LVL0_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL1_V2_DUTY_CYCLE ATH12K_THERMAL_LVL0_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL2_V2_DUTY_CYCLE ATH12K_THERMAL_LVL1_DUTY_CYCLE
 | 
				
			||||||
 | 
					-#define ATH12K_THERMAL_LVL3_V2_DUTY_CYCLE ATH12K_THERMAL_LVL2_DUTY_CYCLE
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL1_V2_DUTY_CYCLE ATH12K_THERMAL_LVL1_DUTY_CYCLE
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL2_V2_DUTY_CYCLE ATH12K_THERMAL_LVL2_DUTY_CYCLE
 | 
				
			||||||
 | 
					+#define ATH12K_THERMAL_LVL3_V2_DUTY_CYCLE ATH12K_THERMAL_LVL3_DUTY_CYCLE
 | 
				
			||||||
 | 
					 #define ATH12K_THERMAL_LVL4_V2_DUTY_CYCLE ATH12K_THERMAL_LVL3_DUTY_CYCLE
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #define THERMAL_CONFIG_POUT0                        0
 | 
				
			||||||
 | 
					-- 
 | 
				
			||||||
 | 
					2.34.1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -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
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										315
									
								
								feeds/qca-wifi-7/qca-ssdk-qca/files-zyxel_nwa50be/qca-ssdk
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										315
									
								
								feeds/qca-wifi-7/qca-ssdk-qca/files-zyxel_nwa50be/qca-ssdk
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,315 @@
 | 
				
			|||||||
 | 
					#!/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 () {
 | 
				
			||||||
 | 
						#PHY (8081->5321): Full amplitude (bit[7:5]=000), half swing (bit[4]=1)
 | 
				
			||||||
 | 
						#for qca808x phy sgmii, set half amplitude with src_half_swing register
 | 
				
			||||||
 | 
						port_id=2
 | 
				
			||||||
 | 
						phy_addr=0x1d
 | 
				
			||||||
 | 
						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 $phy_addr 0x40010087 0x208a
 | 
				
			||||||
 | 
							#Set the Reg0x67 bits[7:5]=3’b000 and bit4=1’b1
 | 
				
			||||||
 | 
							ampl_val=$(ssdk_sh debug phy get $phy_addr 0x40010067 | grep SSDK | grep -oE '0x[0-9a-fA-F]+' | sed 's/\(0x..\)./\11/')
 | 
				
			||||||
 | 
							ssdk_sh debug phy set $phy_addr 0x40010067 $ampl_val
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function ipq53xx_uniphy_amplitude_set () {
 | 
				
			||||||
 | 
					        #UniPhy (5321->8081): Custom amplitude (bit[8:4]=21) = 0xb15d
 | 
				
			||||||
 | 
						#for ipq53xx sgmii, set half amplitude with tx_emp_lvl/margin_index and tx_margin
 | 
				
			||||||
 | 
						ssdk_sh debug uniphy set 1 0x7ac 0xb15d 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,10 +20,16 @@ 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
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
boot() {
 | 
					boot() {
 | 
				
			||||||
 | 
						case "$(board_name)" in
 | 
				
			||||||
 | 
						sonicfi,rap6*)
 | 
				
			||||||
 | 
							touch /tmp/squashfs
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
 | 
						esac
 | 
				
			||||||
	[ -f /etc/ucentral/key.pem ] && return
 | 
						[ -f /etc/ucentral/key.pem ] && return
 | 
				
			||||||
	/usr/bin/mount_certs
 | 
						/usr/bin/mount_certs
 | 
				
			||||||
	copy_certificates
 | 
						copy_certificates
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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
 | 
				
			||||||
@@ -34,12 +37,29 @@ sonicfi,rap7*)
 | 
				
			|||||||
		mtd=$(find_mtd_index certificates)
 | 
							mtd=$(find_mtd_index certificates)
 | 
				
			||||||
		[ -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
 | 
						;;
 | 
				
			||||||
		bootconfig=$(bootconfig_lookup)
 | 
					sonicfi,rap6*)
 | 
				
			||||||
		if [ -n "$bootconfig" ]; then
 | 
						mtd=$(find_mtd_index certificates)
 | 
				
			||||||
			mmc_dev=$(echo $(find_mmc_part "$bootconfig") | sed 's/^.\{5\}//')
 | 
						if [ "$(head -c 4 /dev/mtd$mtd)" == "hsqs" ]; then
 | 
				
			||||||
			[ -n "$mmc_dev" ] && tar xf /dev/$mmc_dev -C /certificates
 | 
							mount -t squashfs /dev/mtdblock$mtd /mnt
 | 
				
			||||||
 | 
							cp /mnt/* /certificates
 | 
				
			||||||
 | 
							umount /mnt
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
							mtd=$(find_mtd_index devinfo)
 | 
				
			||||||
 | 
							[ -n "$mtd" ] && tar xf /dev/mtdblock$mtd -C /certificates
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
 | 
					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
 | 
						fi
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
*)
 | 
					*)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,25 +1,36 @@
 | 
				
			|||||||
#!/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)
 | 
					udaya,a5-id2|\
 | 
				
			||||||
 | 
					yuncore,ax820)
 | 
				
			||||||
	cd /certificates
 | 
						cd /certificates
 | 
				
			||||||
	tar cf /tmp/certs.tar
 | 
						tar cf /tmp/certs.tar .
 | 
				
			||||||
	bootconfig=$(bootconfig_lookup)
 | 
						part=$(tar_part_lookup "insta1" "insta2")
 | 
				
			||||||
	mmc_dev=$(echo $(find_mmc_part $bootconfig) | sed 's/^.\{5\}//')
 | 
						mtd=$(find_mtd_index $part)
 | 
				
			||||||
	dd if=/tmp/certs.tar of=/dev/$bootconfig
 | 
						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 .
 | 
				
			||||||
 | 
							mtd=$(find_mtd_index devinfo)
 | 
				
			||||||
 | 
							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,15 @@ 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 discovery_block_list = [];
 | 
				
			||||||
let validate_time;
 | 
					let validate_time;
 | 
				
			||||||
let offline_time;
 | 
					let offline_time;
 | 
				
			||||||
let orphan_time;
 | 
					let orphan_time;
 | 
				
			||||||
@@ -27,6 +33,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 +43,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 +102,17 @@ function gateway_load() {
 | 
				
			|||||||
	return readjsonfile('/etc/ucentral/gateway.json');
 | 
						return readjsonfile('/etc/ucentral/gateway.json');
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function discovery_state_write() {
 | 
				
			||||||
 | 
						if (length(discovery_method) == 0)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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 +126,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;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -120,6 +159,7 @@ function set_state(set) {
 | 
				
			|||||||
		ulog(LOG_INFO, 'Wait for validation\n');
 | 
							ulog(LOG_INFO, 'Wait for validation\n');
 | 
				
			||||||
		validate_time = time();
 | 
							validate_time = time();
 | 
				
			||||||
		state = VALIDATING;
 | 
							state = VALIDATING;
 | 
				
			||||||
 | 
							push(discovery_block_list, discovery_method);
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case ONLINE:
 | 
						case ONLINE:
 | 
				
			||||||
@@ -127,6 +167,8 @@ 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();
 | 
				
			||||||
 | 
								discovery_block_list = [];
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -161,7 +203,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);
 | 
				
			||||||
@@ -195,6 +237,13 @@ function time_is_valid() {
 | 
				
			|||||||
	return valid;
 | 
						return valid;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function is_discover_method_blacked() {
 | 
				
			||||||
 | 
						if (discovery_method in discovery_block_list)
 | 
				
			||||||
 | 
							return true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return false;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function interval_handler() {
 | 
					function interval_handler() {
 | 
				
			||||||
	printf(`State ${state}\n`);
 | 
						printf(`State ${state}\n`);
 | 
				
			||||||
	switch(state) {
 | 
						switch(state) {
 | 
				
			||||||
@@ -224,16 +273,21 @@ function interval_handler() {
 | 
				
			|||||||
		if (!time_is_valid())
 | 
							if (!time_is_valid())
 | 
				
			||||||
			return;
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (discover_dhcp())
 | 
					 | 
				
			||||||
			return;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		if (system('/usr/bin/est_client enroll'))
 | 
							if (system('/usr/bin/est_client enroll'))
 | 
				
			||||||
			return;
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!discover_flash())
 | 
							discovery_method = DISCOVER_DHCP;
 | 
				
			||||||
 | 
							if (!is_discover_method_blacked() && discover_dhcp())
 | 
				
			||||||
			return;
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							discovery_method = DISCOVER_FLASH;
 | 
				
			||||||
 | 
							if (!is_discover_method_blacked() && !discover_flash())
 | 
				
			||||||
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							discovery_method = DISCOVER_LOOKUP;
 | 
				
			||||||
		redirector_lookup();
 | 
							redirector_lookup();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							discovery_block_list = [];
 | 
				
			||||||
		break;
 | 
							break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	case VALIDATING:
 | 
						case VALIDATING:
 | 
				
			||||||
@@ -252,6 +306,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 +410,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 +437,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,8 +5,8 @@ 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 = fs.readfile('/tmp/dhcp-option-138');
 | 
				
			||||||
let opt224 = getenv("opt224");
 | 
					let opt224 = fs.readfile('/tmp/dhcp-option-224');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if (cmd != 'bound' && cmd != 'renew')
 | 
					if (cmd != 'bound' && cmd != 'renew')
 | 
				
			||||||
	exit(0);
 | 
						exit(0);
 | 
				
			||||||
@@ -23,14 +23,14 @@ let cloud = {
 | 
				
			|||||||
	lease: true,
 | 
						lease: true,
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
if (opt138) {
 | 
					if (opt138) {
 | 
				
			||||||
	let dhcp = hexdec(opt138);
 | 
						let dhcp = opt138;
 | 
				
			||||||
	dhcp = split(dhcp, ':');
 | 
						dhcp = split(dhcp, ':');
 | 
				
			||||||
	cloud.dhcp_server = dhcp[0];
 | 
						cloud.dhcp_server = dhcp[0];
 | 
				
			||||||
	cloud.dhcp_port = dhcp[1] ?? 15002;
 | 
						cloud.dhcp_port = dhcp[1] ?? 15002;
 | 
				
			||||||
	cloud.no_validation = true;
 | 
						cloud.no_validation = true;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
if (opt224) {
 | 
					if (opt224) {
 | 
				
			||||||
	let dhcp = hexdec(opt224);
 | 
						let dhcp = opt224;
 | 
				
			||||||
	dhcp = split(dhcp, ':');
 | 
						dhcp = split(dhcp, ':');
 | 
				
			||||||
	cloud.dhcp_server = dhcp[0];
 | 
						cloud.dhcp_server = dhcp[0];
 | 
				
			||||||
	cloud.dhcp_port = dhcp[1] ?? 15002;
 | 
						cloud.dhcp_port = dhcp[1] ?? 15002;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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,10 @@ PKG_NAME:=ucentral-client
 | 
				
			|||||||
PKG_RELEASE:=1
 | 
					PKG_RELEASE:=1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-client.git
 | 
					PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-client.git
 | 
				
			||||||
PKG_MIRROR_HASH:=2e28e0aa61b74851c7daf3634ec34d303a603e881e6c5d1fd76c837dea527582
 | 
					PKG_MIRROR_HASH:=2935998d6074f0c290d9b96c2988c89aae6f405608f12a0063fa7215498bae9a
 | 
				
			||||||
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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,5 +1,5 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	"major": 4,
 | 
						"major": 4,
 | 
				
			||||||
	"minor": 1,
 | 
						"minor": 1,
 | 
				
			||||||
	"patch": 0
 | 
						"patch": 1
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2,6 +2,8 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
'use strict';
 | 
					'use strict';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					push(REQUIRE_SEARCH_PATH, '/usr/share/ucentral/*.uc');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import * as libubus from 'ubus';
 | 
					import * as libubus from 'ubus';
 | 
				
			||||||
import * as libuci from 'uci';
 | 
					import * as libuci from 'uci';
 | 
				
			||||||
import * as uloop from 'uloop';
 | 
					import * as uloop from 'uloop';
 | 
				
			||||||
@@ -36,6 +38,7 @@ let ucentral_running = false;
 | 
				
			|||||||
let pending_events = [];
 | 
					let pending_events = [];
 | 
				
			||||||
let relay = {};
 | 
					let relay = {};
 | 
				
			||||||
let net_config = {};
 | 
					let net_config = {};
 | 
				
			||||||
 | 
					let vlan_refcount = {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function config_load() {
 | 
					function config_load() {
 | 
				
			||||||
@@ -52,6 +55,20 @@ function config_load() {
 | 
				
			|||||||
	net_config = {};
 | 
						net_config = {};
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function vlan_refcount_init() {
 | 
				
			||||||
 | 
						let stations = require('wifi.station');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						vlan_refcount = {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for (let k, v in stations) {
 | 
				
			||||||
 | 
							let vlan = split(k, '-v')[1];
 | 
				
			||||||
 | 
							let count = length(v);
 | 
				
			||||||
 | 
							if (vlan && count > 0) {
 | 
				
			||||||
 | 
								vlan_refcount[vlan] = count;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function match(object, type, list) {
 | 
					function match(object, type, list) {
 | 
				
			||||||
	if (object in list || type in list)
 | 
						if (object in list || type in list)
 | 
				
			||||||
		return true;
 | 
							return true;
 | 
				
			||||||
@@ -261,6 +278,16 @@ handlers = {
 | 
				
			|||||||
		if (config.config.swconfig)
 | 
							if (config.config.swconfig)
 | 
				
			||||||
			return handlers.vlan_add_swconfig(notify);
 | 
								return handlers.vlan_add_swconfig(notify);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							let vlan_id = `${notify.data.vlan_id}`;
 | 
				
			||||||
 | 
							vlan_refcount[vlan_id] = (vlan_refcount[vlan_id] || 0) + 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							let parts = split(notify.data.ifname, '-v');
 | 
				
			||||||
 | 
							let is_wifi_iface = (length(parts) == 2 && wildcard(parts[0], 'wlan*'));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (vlan_refcount[vlan_id] > 1 && !is_wifi_iface)
 | 
				
			||||||
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (vlan_refcount[vlan_id] == 1) {
 | 
				
			||||||
			for (let wan in wan_ports) {
 | 
								for (let wan in wan_ports) {
 | 
				
			||||||
				let msg = {
 | 
									let msg = {
 | 
				
			||||||
					name: wan,
 | 
										name: wan,
 | 
				
			||||||
@@ -269,6 +296,7 @@ handlers = {
 | 
				
			|||||||
				ubus.call('network.interface.up_none', 'add_device', msg);
 | 
									ubus.call('network.interface.up_none', 'add_device', msg);
 | 
				
			||||||
				ubus.call('udevstats', 'add_device', { device: wan, vlan: +notify.data.vlan_id });
 | 
									ubus.call('udevstats', 'add_device', { device: wan, vlan: +notify.data.vlan_id });
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		let msg = {
 | 
							let msg = {
 | 
				
			||||||
			name: notify.data.ifname,
 | 
								name: notify.data.ifname,
 | 
				
			||||||
@@ -282,6 +310,14 @@ handlers = {
 | 
				
			|||||||
	vlan_remove: function(notify) {
 | 
						vlan_remove: function(notify) {
 | 
				
			||||||
		if (config.config.swconfig)
 | 
							if (config.config.swconfig)
 | 
				
			||||||
			return;
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							let vlan_id = `${notify.data.vlan_id}`;
 | 
				
			||||||
 | 
							vlan_refcount[vlan_id] = (vlan_refcount[vlan_id] || 1) - 1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (vlan_refcount[vlan_id] > 0)
 | 
				
			||||||
 | 
								return;
 | 
				
			||||||
 | 
							delete vlan_refcount[vlan_id];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		for (let wan in wan_ports) {
 | 
							for (let wan in wan_ports) {
 | 
				
			||||||
			let msg = {
 | 
								let msg = {
 | 
				
			||||||
				name: wan,
 | 
									name: wan,
 | 
				
			||||||
@@ -624,6 +660,7 @@ let ubus_methods = {
 | 
				
			|||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
config_load();
 | 
					config_load();
 | 
				
			||||||
 | 
					vlan_refcount_init();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
hapd_subscriber = ubus.subscriber(hapd_subscriber_notify_cb, hapd_subscriber_remove_cb);
 | 
					hapd_subscriber = ubus.subscriber(hapd_subscriber_notify_cb, hapd_subscriber_remove_cb);
 | 
				
			||||||
dhcp_subscriber = ubus.subscriber(dhcp_subscriber_notify_cb, dhcp_subscriber_remove_cb);
 | 
					dhcp_subscriber = ubus.subscriber(dhcp_subscriber_notify_cb, dhcp_subscriber_remove_cb);
 | 
				
			||||||
 
 | 
				
			|||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user