mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-10-31 10:28:06 +00:00 
			
		
		
		
	Compare commits
	
		
			57 Commits
		
	
	
		
			v2.7.0-rc1
			...
			v2.7.2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | b6776698b6 | ||
|   | 8233c10569 | ||
|   | 6ce868a890 | ||
|   | fb73d889ed | ||
|   | 05e2b6319e | ||
|   | 80bfb8671d | ||
|   | 521df1a142 | ||
|   | 72a75b72ac | ||
|   | c22dce10d3 | ||
|   | 8eb801a0cc | ||
|   | 25d7b9d62d | ||
|   | 6eaef7adad | ||
|   | 0272d4bcad | ||
|   | 41c64e9978 | ||
|   | 9c2f0a098d | ||
|   | 0bb8d0dcc0 | ||
|   | a542660072 | ||
|   | 8ee15d0053 | ||
|   | 311515867c | ||
|   | 16bbcddd40 | ||
|   | 26391d3524 | ||
|   | a4b663b824 | ||
|   | 736ab2b803 | ||
|   | cd2fbd11f2 | ||
|   | 708fe70e75 | ||
|   | 0c9499c085 | ||
|   | d52d4ff627 | ||
|   | 324df56861 | ||
|   | a21a08e8bf | ||
|   | 393db0ec2a | ||
|   | ca26d347eb | ||
|   | 9ea3e4ce9b | ||
|   | c56b7adea8 | ||
|   | 84d31765db | ||
|   | fb617ea136 | ||
|   | 47468145c6 | ||
|   | 854c8a44d4 | ||
|   | 86948e1052 | ||
|   | 39053d366d | ||
|   | daaed910da | ||
|   | bf6abd80dd | ||
|   | e74e22e184 | ||
|   | b8f5e17e38 | ||
|   | 956a31db8f | ||
|   | 9eeefa2fbf | ||
|   | c33705ca60 | ||
|   | ba41e6773b | ||
|   | 8ebf884436 | ||
|   | 7d4353caf0 | ||
|   | fa6220a615 | ||
|   | 26517bb6ae | ||
|   | ea4c4b3fe5 | ||
|   | 00f273000e | ||
|   | 6014d3a04d | ||
|   | 08f082acfe | ||
|   | 12e5efcda4 | ||
|   | 26be5ba20e | 
							
								
								
									
										2
									
								
								.github/workflows/build-dev.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build-dev.yml
									
									
									
									
										vendored
									
									
								
							| @@ -21,7 +21,7 @@ jobs: | |||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         target: ['actiontec_web7200', 'cig_wf188n', 'cig_wf194c', 'cig_wf194c4', 'cig_wf196', 'cig_wf610d', 'cig_wf808', 'cybertan_eww622-a1', 'edgecore_eap101', 'edgecore_eap102', 'edgecore_eap104', 'edgecore_ecs4100-12ph', 'edgecore_ecw5211', 'edgecore_ecw5410', 'edgecore_oap100', 'edgecore_ssw2ac2600', 'edgecore_spw2ac1200', 'edgecore_spw2ac1200-lan-poe', 'hfcl_ion4', 'hfcl_ion4xe', 'hfcl_ion4xi', 'indio_um-305ac', 'indio_um-305ax', 'indio_um-325ac', 'indio_um-510ac-v3', 'indio_um-550ac', 'linksys_ea6350-v4', 'linksys_e8450-ubi', 'linksys_ea8300', 'meshpp_s618_cp03', 'meshpp_s618_cp01', 'tp-link_ec420-g1', 'tplink_ex227', 'tplink_ex228', 'tplink_ex447', 'udaya_a5-id2', 'wallys_dr40x9', 'wallys_dr6018', 'x64_vm' ] |         target: ['actiontec_web7200', 'cig_wf188n', 'cig_wf196', 'cig_wf610d', 'cig_wf808', 'cybertan_eww622-a1', 'edgecore_eap101', 'edgecore_eap102', 'edgecore_eap104', 'liteon_wpx8324', 'edgecore_ecs4100-12ph', 'edgecore_ecw5211', 'edgecore_ecw5410', 'edgecore_oap100', 'edgecore_ssw2ac2600', 'edgecore_spw2ac1200', 'edgecore_spw2ac1200-lan-poe', 'hfcl_ion4', 'hfcl_ion4xe', 'hfcl_ion4xi', 'indio_um-305ac', 'indio_um-305ax', 'indio_um-325ac', 'indio_um-510ac-v3', 'indio_um-550ac', 'linksys_ea6350-v4', 'linksys_e8450-ubi', 'linksys_ea8300', 'meshpp_s618_cp03', 'meshpp_s618_cp01', 'udaya_a5-id2', 'wallys_dr40x9', 'wallys_dr6018', 'wallys_dr6018_v4', 'x64_vm' ] | ||||||
|  |  | ||||||
|     steps: |     steps: | ||||||
|     - uses: actions/checkout@v2 |     - uses: actions/checkout@v2 | ||||||
|   | |||||||
							
								
								
									
										83
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										83
									
								
								README.md
									
									
									
									
									
								
							| @@ -1,20 +1,83 @@ | |||||||
| # Setting up your build machine | # OpenWiFi AP NOS | ||||||
|  |  | ||||||
| Requires a recent linux installation. Older systems without python 3.7 will have trouble.  See this link for details: https://openwrt.org/docs/guide-developer/quickstart-build-images | OpenWrt-based access point network operating system (AP NOS) for TIP OpenWiFi. | ||||||
|  | Read more at [openwifi.tip.build](https://openwifi.tip.build/). | ||||||
|  |  | ||||||
| Install build packages:  sudo apt install build-essential libncurses5-dev gawk git libssl-dev gettext zlib1g-dev swig unzip time rsync python3 python3-setuptools python3-yaml. | ## Building | ||||||
|  |  | ||||||
| # Doing a native build on Linux | ### Setting up your build machine | ||||||
| First we need to clone and setup our tree. This will result in an openwrt/. |  | ||||||
|  | Building requires a recent Linux installation. Older systems without Python 3.7 | ||||||
|  | will have trouble. See this guide for details: | ||||||
|  | https://openwrt.org/docs/guide-developer/toolchain/beginners-build-guide | ||||||
|  |  | ||||||
|  | Install build packages on Debian/Ubuntu (or see above guide for other systems): | ||||||
| ``` | ``` | ||||||
| ./setup.py --setup | sudo apt install build-essential libncurses5-dev gawk git libssl-dev gettext zlib1g-dev swig unzip time rsync python3 python3-setuptools python3-yaml | ||||||
| ``` | ``` | ||||||
| Next we need to select the profile and base package selection. This setup will install the feeds, packages and generate the .config file. |  | ||||||
|  | ### Doing a native build on Linux | ||||||
|  |  | ||||||
|  | Use `./build.sh <target>`, or follow the manual steps below: | ||||||
|  |  | ||||||
|  | 1. Clone and set up the tree. This will create an `openwrt/` directory. | ||||||
|  | ```shell | ||||||
|  | ./setup.py --setup    # for subsequent builds, use --rebase instead | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | 2. Select the profile and base package selection. This setup will install the | ||||||
|  |    feeds and packages and generate the `.config` file. | ||||||
|  | ```shell | ||||||
| cd openwrt | cd openwrt | ||||||
| ./scripts/gen_config.py linksys_ea8300 | ./scripts/gen_config.py linksys_ea8300 | ||||||
| ``` | ``` | ||||||
| Finally we can build the tree. |  | ||||||
| ``` | 3. Build the tree (replace `-j 8` with the number of cores to use). | ||||||
| make -j X V=s | ```shell | ||||||
|  | make -j 8 V=s | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
|  | ### Build output | ||||||
|  |  | ||||||
|  | The build results are located in the `openwrt/bin/` directory: | ||||||
|  |  | ||||||
|  | | Type             | Path                                                 | | ||||||
|  | | ---------------- | ---------------------------------------------------- | | ||||||
|  | | Firmware images  | `openwrt/bin/targets/<target>/<subtarget>/`          | | ||||||
|  | | Kernel modules   | `openwrt/bin/targets/<target>/<subtarget>/packages/` | | ||||||
|  | | Package binaries | `openwrt/bin/packages/<platform>/<feed>/`            | | ||||||
|  |  | ||||||
|  | ## Developer Notes | ||||||
|  |  | ||||||
|  | ### Branching model | ||||||
|  |  | ||||||
|  | - `main` - Stable dev branch | ||||||
|  | - `next` - Integration branch | ||||||
|  | - `staging-*` - Feature/bug branches | ||||||
|  | - `release/v#.#.#` - Release branches (*major.minor.patch*) | ||||||
|  |  | ||||||
|  | ### Repository structure | ||||||
|  |  | ||||||
|  | Build files: | ||||||
|  | - `Makefile` - Calls Docker environment per target | ||||||
|  | - `dock-run.sh` - Dockerized build environment | ||||||
|  | - `docker/Dockerfile` - Dockerfile for build image | ||||||
|  | - `build.sh` - Build script | ||||||
|  | - `setup.py` - Clone and set up the tree | ||||||
|  | - `config.yml` - Specifies OpenWrt version and patches to apply | ||||||
|  |  | ||||||
|  | Directories: | ||||||
|  | - `feeds/` - OpenWiFi feeds | ||||||
|  | - `patches/` - OpenWiFi patches applied during builds | ||||||
|  | - `profiles/` - Per-target kernel configs, packages, and feeds | ||||||
|  |     - [wifi-ax](profiles/wifi-ax.yml): Wi-Fi AX packages | ||||||
|  |     - [ucentral-ap](profiles/ucentral-ap.yml): uCentral packages | ||||||
|  |     - [x64_vm](profiles/x64_vm.yml): x86-64 VM image | ||||||
|  |  | ||||||
|  | ### uCentral packages | ||||||
|  |  | ||||||
|  | AP-NOS packages implementing the uCentral protocol include the following | ||||||
|  | repositories (refer to the [ucentral](feeds/ucentral/) feed for a full list): | ||||||
|  | - ucentral-client: https://github.com/Telecominfraproject/wlan-ucentral-client | ||||||
|  | - ucentral-schema: https://github.com/Telecominfraproject/wlan-ucentral-schema | ||||||
|  | - ucentral-wifi: https://github.com/blogic/ucentral-wifi | ||||||
|   | |||||||
| @@ -34,6 +34,11 @@ edgecore,eap104) | |||||||
|         ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:wifi5" "phy1tpt" |         ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:wifi5" "phy1tpt" | ||||||
| 	ucidef_set_led_netdev "wan" "wan" "yellow:uplink" "eth0" | 	ucidef_set_led_netdev "wan" "wan" "yellow:uplink" "eth0" | ||||||
| 	;; | 	;; | ||||||
|  | liteon,wpx8324) | ||||||
|  | 	ucidef_set_led_wlan "wlan2g" "WLAN2G" "orange:wifi2" "phy0tpt" | ||||||
|  | 	ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:wifi5" "phy1tpt" | ||||||
|  | 	ucidef_set_led_netdev "wan" "wan" "blue:uplink" "eth0" | ||||||
|  | 	;; | ||||||
| hfcl,ion4xi|\ | hfcl,ion4xi|\ | ||||||
| hfcl,ion4xe) | hfcl,ion4xe) | ||||||
|         ucidef_set_led_wlan "wlan5g" "WLAN5G" "blue:wifi5" "phy0tpt" |         ucidef_set_led_wlan "wlan5g" "WLAN5G" "blue:wifi5" "phy0tpt" | ||||||
|   | |||||||
| @@ -31,6 +31,9 @@ qcom_setup_interfaces() | |||||||
| 	cig,wf194c|\ | 	cig,wf194c|\ | ||||||
| 	cig,wf194c4|\ | 	cig,wf194c4|\ | ||||||
| 	edgecore,eap106|\ | 	edgecore,eap106|\ | ||||||
|  | 	indio,um-310ax-v1|\ | ||||||
|  | 	indio,um-510axp-v1|\ | ||||||
|  | 	indio,um-510axm-v1|\ | ||||||
| 	qcom,ipq5018-mp03.3|\ | 	qcom,ipq5018-mp03.3|\ | ||||||
| 	yuncore,ax840|\ | 	yuncore,ax840|\ | ||||||
| 	motorola,q14|\ | 	motorola,q14|\ | ||||||
| @@ -47,6 +50,7 @@ qcom_setup_interfaces() | |||||||
| 		;; | 		;; | ||||||
| 	edgecore,eap102|\ | 	edgecore,eap102|\ | ||||||
| 	edgecore,eap104|\ | 	edgecore,eap104|\ | ||||||
|  | 	liteon,wpx8324|\ | ||||||
| 	wallys,dr6018|\ | 	wallys,dr6018|\ | ||||||
| 	cig,wf188n|\ | 	cig,wf188n|\ | ||||||
| 	cig,wf196) | 	cig,wf196) | ||||||
| @@ -81,13 +85,24 @@ qcom_setup_macs() | |||||||
|  |  | ||||||
| 	case $board in | 	case $board in | ||||||
| 	cig,wf194c|\ | 	cig,wf194c|\ | ||||||
| 	cig,wf194c4|\ | 	cig,wf194c4) | ||||||
| 	cig,wf196) |  | ||||||
| 		mac=$(grep BaseMacAddress= /dev/mtd14 | cut -dx -f2) | 		mac=$(grep BaseMacAddress= /dev/mtd14 | cut -dx -f2) | ||||||
| 		wan_mac=$(macaddr_canonicalize $mac) | 		wan_mac=$(macaddr_canonicalize $mac) | ||||||
| 		lan_mac=$(macaddr_add "$wan_mac" 1) | 		lan_mac=$(macaddr_add "$wan_mac" 1) | ||||||
| 		ucidef_set_network_device_mac eth0 $lan_mac | 		ucidef_set_network_device_mac eth0 $lan_mac | ||||||
| 		ucidef_set_network_device_mac eth1 $wan_mac | 		ucidef_set_network_device_mac eth1 $wan_mac | ||||||
|  | 		ip link set eth0 address $lan_mac | ||||||
|  | 		ip link set eth1 address $wan_mac | ||||||
|  | 		ucidef_set_label_macaddr $wan_mac | ||||||
|  | 		;; | ||||||
|  | 	cig,wf196) | ||||||
|  | 		mac=$(grep BaseMacAddress= /dev/mtd14 | cut -dx -f2) | ||||||
|  | 		wan_mac=$(macaddr_canonicalize $mac) | ||||||
|  | 		lan_mac=$(macaddr_add "$wan_mac" 1) | ||||||
|  | 		ucidef_set_network_device_mac eth1 $lan_mac | ||||||
|  | 		ucidef_set_network_device_mac eth0 $wan_mac | ||||||
|  | 		ip link set eth0 address $wan_mac | ||||||
|  | 		ip link set eth1 address $lan_mac | ||||||
| 		ucidef_set_label_macaddr $wan_mac | 		ucidef_set_label_macaddr $wan_mac | ||||||
| 		;; | 		;; | ||||||
| 	cybertan,eww622-a1) | 	cybertan,eww622-a1) | ||||||
| @@ -99,6 +114,9 @@ qcom_setup_macs() | |||||||
| 		ucidef_set_network_device_mac eth1 $lan_mac | 		ucidef_set_network_device_mac eth1 $lan_mac | ||||||
| 		ucidef_set_label_macaddr $wan_mac | 		ucidef_set_label_macaddr $wan_mac | ||||||
| 		;; | 		;; | ||||||
|  | 	indio,um-310ax-v1|\ | ||||||
|  | 	indio,um-510axp-v1|\ | ||||||
|  | 	indio,um-510axm-v1|\ | ||||||
| 	yuncore,ax840) | 	yuncore,ax840) | ||||||
| 		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) | ||||||
|   | |||||||
| @@ -86,6 +86,9 @@ case "$FIRMWARE" in | |||||||
| 	cig,wf196|\ | 	cig,wf196|\ | ||||||
| 	edgecore,eap102 |\ | 	edgecore,eap102 |\ | ||||||
| 	edgecore,eap106 |\ | 	edgecore,eap106 |\ | ||||||
|  | 	indio,um-310ax-v1|\ | ||||||
|  | 	indio,um-510axp-v1|\ | ||||||
|  | 	indio,um-510axm-v1|\ | ||||||
| 	qcom,ipq807x-hk01|\ | 	qcom,ipq807x-hk01|\ | ||||||
| 	qcom,ipq807x-hk14|\ | 	qcom,ipq807x-hk14|\ | ||||||
| 	tplink,ex227|\ | 	tplink,ex227|\ | ||||||
| @@ -121,6 +124,7 @@ ath11k/IPQ5018/hw1.0/caldata.bin) | |||||||
| 	case "$board" in | 	case "$board" in | ||||||
| 	cybertan,eww622-a1|\ | 	cybertan,eww622-a1|\ | ||||||
| 	edgecore,eap104|\ | 	edgecore,eap104|\ | ||||||
|  | 	liteon,wpx8324|\ | ||||||
| 	motorola,q14|\ | 	motorola,q14|\ | ||||||
| 	qcom,ipq5018-mp03.1) | 	qcom,ipq5018-mp03.1) | ||||||
|                 caldata_extract "0:ART" 0x1000 0x20000   |                 caldata_extract "0:ART" 0x1000 0x20000   | ||||||
| @@ -137,7 +141,8 @@ 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 | ||||||
| 	motorola,q14|\ | 	motorola,q14|\ | ||||||
| 	edgecore,eap104) | 	edgecore,eap104|\ | ||||||
|  | 	liteon,wpx8324) | ||||||
|                 caldata_extract "0:ART" 0x4c000 0x20000   |                 caldata_extract "0:ART" 0x4c000 0x20000   | ||||||
| 		;; | 		;; | ||||||
| 	esac | 	esac | ||||||
| @@ -173,6 +178,9 @@ ath11k-macs) | |||||||
| 	yuncore,ax840|\ | 	yuncore,ax840|\ | ||||||
| 	edgecore,eap102|\ | 	edgecore,eap102|\ | ||||||
| 	edgecore,eap106|\ | 	edgecore,eap106|\ | ||||||
|  | 	indio,um-310ax-v1|\ | ||||||
|  | 	indio,um-510axp-v1|\ | ||||||
|  | 	indio,um-510axm-v1|\ | ||||||
| 	cig,wf188n) | 	cig,wf188n) | ||||||
| 		ath11k_generate_macs | 		ath11k_generate_macs | ||||||
| 		;; | 		;; | ||||||
|   | |||||||
| @@ -76,11 +76,15 @@ platform_check_image() { | |||||||
| 	cybertan,eww622-a1|\ | 	cybertan,eww622-a1|\ | ||||||
| 	glinet,ax1800|\ | 	glinet,ax1800|\ | ||||||
| 	glinet,axt1800|\ | 	glinet,axt1800|\ | ||||||
|  | 	indio,um-310ax-v1|\ | ||||||
|  | 	indio,um-510axp-v1|\ | ||||||
|  | 	indio,um-510axm-v1|\ | ||||||
| 	wallys,dr6018|\ | 	wallys,dr6018|\ | ||||||
| 	wallys,dr6018-v4|\ | 	wallys,dr6018-v4|\ | ||||||
| 	edgecore,eap101|\ | 	edgecore,eap101|\ | ||||||
| 	edgecore,eap102|\ | 	edgecore,eap102|\ | ||||||
| 	edgecore,eap104|\ | 	edgecore,eap104|\ | ||||||
|  | 	liteon,wpx8324|\ | ||||||
| 	edgecore,eap106|\ | 	edgecore,eap106|\ | ||||||
| 	hfcl,ion4xi|\ | 	hfcl,ion4xi|\ | ||||||
| 	hfcl,ion4xe|\ | 	hfcl,ion4xe|\ | ||||||
| @@ -118,9 +122,11 @@ platform_do_upgrade() { | |||||||
| 	cig,wf194c4|\ | 	cig,wf194c4|\ | ||||||
| 	cig,wf196|\ | 	cig,wf196|\ | ||||||
| 	cybertan,eww622-a1|\ | 	cybertan,eww622-a1|\ | ||||||
| 	edgecore,eap104|\ |  | ||||||
| 	glinet,ax1800|\ | 	glinet,ax1800|\ | ||||||
| 	glinet,axt1800|\ | 	glinet,axt1800|\ | ||||||
|  | 	indio,um-310ax-v1|\ | ||||||
|  | 	indio,um-510axp-v1|\ | ||||||
|  | 	indio,um-510axm-v1|\ | ||||||
| 	qcom,ipq6018-cp01|\ | 	qcom,ipq6018-cp01|\ | ||||||
| 	qcom,ipq807x-hk01|\ | 	qcom,ipq807x-hk01|\ | ||||||
| 	qcom,ipq807x-hk14|\ | 	qcom,ipq807x-hk14|\ | ||||||
| @@ -145,6 +151,8 @@ platform_do_upgrade() { | |||||||
| 		fi | 		fi | ||||||
| 		nand_upgrade_tar "$1" | 		nand_upgrade_tar "$1" | ||||||
| 		;; | 		;; | ||||||
|  | 	edgecore,eap104|\ | ||||||
|  | 	liteon,wpx8324|\ | ||||||
| 	edgecore,eap106) | 	edgecore,eap106) | ||||||
| 		CI_UBIPART="rootfs1" | 		CI_UBIPART="rootfs1" | ||||||
| 		[ "$(find_mtd_chardev rootfs)" ] && CI_UBIPART="rootfs" | 		[ "$(find_mtd_chardev rootfs)" ] && CI_UBIPART="rootfs" | ||||||
|   | |||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | /* | ||||||
|  |  * 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 "../../../arm64/boot/dts/qcom/qcom-ipq5018-liteon-wpx8324.dts" | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	pmuv8: pmu { | ||||||
|  | 		compatible = "arm,cortex-a7-pmu"; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,18 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (c) 2019, 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 "../../../arm64/boot/dts/qcom/qcom-ipq6018-indio-um-310ax-v1.dts" | ||||||
|  | #include "qcom-ipq6018.dtsi" | ||||||
| @@ -0,0 +1,18 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (c) 2019, 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 "../../../arm64/boot/dts/qcom/qcom-ipq6018-indio-um-510axm-v1.dts" | ||||||
|  | #include "qcom-ipq6018.dtsi" | ||||||
| @@ -0,0 +1,18 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (c) 2019, 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 "../../../arm64/boot/dts/qcom/qcom-ipq6018-indio-um-510axp-v1.dts" | ||||||
|  | #include "qcom-ipq6018.dtsi" | ||||||
| @@ -0,0 +1,812 @@ | |||||||
|  | /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 "qcom-ipq5018.dtsi" | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	#address-cells = <0x2>; | ||||||
|  | 	#size-cells = <0x2>; | ||||||
|  | 	model = "Liteon WPX8324"; | ||||||
|  | 	compatible = "liteon,wpx8324", "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"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	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 { | ||||||
|  | 		serial@78af000 { | ||||||
|  | 			status = "ok"; | ||||||
|  | 		}; | ||||||
|  | 		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; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		spi_2: spi@78b7000 { /* BLSP1 QUP2 */ | ||||||
|  | 			pinctrl-0 = <&blsp2_spi0_pins>; | ||||||
|  | 			pinctrl-names = "default"; | ||||||
|  | 			cs-select = <0>; | ||||||
|  | 			status = "ok"; | ||||||
|  |  | ||||||
|  | 			tpm0: slb9670@0 { | ||||||
|  | 				#address-cells = <1>; | ||||||
|  | 				#size-cells = <1>; | ||||||
|  | 				reg = <1>;	/* CE1 */ | ||||||
|  | 				compatible = "infineon,slb9670"; | ||||||
|  | 				linux,modalias = "slb9670", "slb9670a11"; | ||||||
|  | 				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 26 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"; | ||||||
|  | 				}; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 		wifi0: wifi@c000000 { | ||||||
|  | 			status = "ok"; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		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"; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	thermal-zones { | ||||||
|  | 		status = "ok"; | ||||||
|  | 	}; | ||||||
|  | 	leds { | ||||||
|  | 		compatible = "gpio-leds"; | ||||||
|  | 		pinctrl-0 = <&leds_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		led_blue: led@19 { | ||||||
|  | 			label = "blue:uplink"; | ||||||
|  | 			gpios = <&tlmm 19 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			default-state = "on"; | ||||||
|  | 		}; | ||||||
|  | 		led_orange: led@18 { | ||||||
|  | 			label = "orange:wifi2"; | ||||||
|  | 			gpios = <&tlmm 18 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			default-state = "on"; | ||||||
|  | 		}; | ||||||
|  | 		led_green: led@39 { | ||||||
|  | 			label = "green:wifi5"; | ||||||
|  | 			gpios = <&tlmm 39 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			default-state = "on"; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &tlmm { | ||||||
|  | 	pinctrl-0 = <&blsp0_uart_pins &phy_led_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 	leds_pins: leds_pins { | ||||||
|  | 		led_blue { | ||||||
|  | 			pins = "gpio19"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		led_orange { | ||||||
|  | 			pins = "gpio18"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		led_green { | ||||||
|  | 			pins = "gpio39"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | 	blsp0_uart_pins: uart_pins { | ||||||
|  | 		blsp0_uart_rx_tx { | ||||||
|  | 			pins = "gpio20", "gpio21"; | ||||||
|  | 			function = "blsp0_uart0"; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	blsp0_spi_pins: blsp0_spi_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio10", "gpio11", "gpio12", "gpio13"; | ||||||
|  | 			function = "blsp0_spi"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	blsp2_spi0_pins: blsp2_spi0_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio31", "gpio32", "gpio33", "gpio34"; | ||||||
|  | 			function = "blsp2_spi0"; | ||||||
|  | 			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 = "gpio18", "gpio19", "gpio39"; | ||||||
|  | 			/* function = "led0"; */ | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			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 { | ||||||
|  | 		wps_button { | ||||||
|  | 			pins = "gpio29"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &soc { | ||||||
|  | 	gpio_keys { | ||||||
|  | 		compatible = "gpio-keys"; | ||||||
|  | 		pinctrl-0 = <&button_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		button@1 { | ||||||
|  | 			label = "wps"; | ||||||
|  | 			linux,code = <KEY_WPS_BUTTON>; | ||||||
|  | 			gpios = <&tlmm 29 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb3 { | ||||||
|  | 	status = "ok"; | ||||||
|  | 	device-power-gpio = <&tlmm 28 0>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &eud { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie_x1 { | ||||||
|  | 	status = "disabled"; | ||||||
|  | 	perst-gpio = <&tlmm 18 1>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie_x2 { | ||||||
|  | 	status = "disabled"; | ||||||
|  | 	perst-gpio = <&tlmm 15 1>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &dwc_0 { | ||||||
|  | 	/delete-property/ #phy-cells; | ||||||
|  | 	/delete-property/ phys; | ||||||
|  | 	/delete-property/ phy-names; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &hs_m31phy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie_x1phy { | ||||||
|  | 	status = "disabled"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie_x2phy { | ||||||
|  | 	status = "disabled"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &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 >; | ||||||
|  |  | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qfprom { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &tsens { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qcom_q6v5_wcss { | ||||||
|  | 	qcom,multipd_arch; | ||||||
|  | 	memory-region = <&q6_mem_regions>; | ||||||
|  | 	qcom,share_bootargs; | ||||||
|  | 	qcom,bootargs_smem = <507>; | ||||||
|  | 	boot-args = <0x1 0x4 0x3 0x0F 0x0 0x0>, | ||||||
|  | 			<0x2 0x4 0x2 0x12 0x0 0x0>; | ||||||
|  | 	/* IPQ5018 */ | ||||||
|  | 	q6v5_wcss_userpd1 { | ||||||
|  | 		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"; | ||||||
|  | 		qcom,smem-states = <&wcss_smp2p_out 8>, | ||||||
|  | 			<&wcss_smp2p_out 9>, | ||||||
|  | 			<&wcss_smp2p_out 10>; | ||||||
|  | 		qcom,smem-state-names = "shutdown", | ||||||
|  | 			"stop", | ||||||
|  | 			"spawn"; | ||||||
|  | 		qca,asid = <1>; | ||||||
|  | 		qca,auto-restart; | ||||||
|  | 		qca,int_radio; | ||||||
|  | 		#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 | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/* QCN6122 6G */ | ||||||
|  | 	q6v5_wcss_userpd2 { | ||||||
|  | 		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"; | ||||||
|  | 		qca,asid = <2>; | ||||||
|  | 		qca,auto-restart; | ||||||
|  | 		#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 | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/* QCN6122 5G */ | ||||||
|  | 	q6v5_wcss_userpd3 { | ||||||
|  | 		m3_firmware = "qcn6122/m3_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"; | ||||||
|  | 		qca,asid = <3>; | ||||||
|  | 		qca,auto-restart; | ||||||
|  | 		#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 | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qgic_msi_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qgic_msi_1 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &wifi0 { | ||||||
|  | 	/* IPQ5018 */ | ||||||
|  | 	qcom,multipd_arch; | ||||||
|  | 	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>; | ||||||
|  | 	qcom,bdf-addr = <0x4C400000 0x4C400000 0x4C400000 0x0 0x0>; | ||||||
|  | #ifdef __CNSS2__ | ||||||
|  | 	qcom,caldb-addr = <0x4D400000 0x4D400000 0 0 0>; | ||||||
|  | #else | ||||||
|  | 	qcom,caldb-addr = <0x4D400000>; | ||||||
|  | 	m3-dump-addr = <0x4D200000>; | ||||||
|  | #endif | ||||||
|  | 	qcom,caldb-size = <0x200000>; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &wifi1 { | ||||||
|  | 	/* QCN6122 5G */ | ||||||
|  | 	qcom,multipd_arch; | ||||||
|  | 	qcom,userpd-subsys-name = "q6v5_wcss_userpd3"; | ||||||
|  | #ifdef __IPQ_MEM_PROFILE_256_MB__ | ||||||
|  | 	qcom,tgt-mem-mode = <2>; | ||||||
|  | #else | ||||||
|  | 	qcom,tgt-mem-mode = <1>; | ||||||
|  | #endif | ||||||
|  | 	qcom,board_id = <0x60>; | ||||||
|  | 	qcom,bdf-addr = <0x4ED00000 0x4ED00000 0x4E400000 0x0 0x0>; | ||||||
|  | #ifdef __CNSS2__ | ||||||
|  | 	qcom,caldb-addr = <0x4FF00000 0x4FF00000 0 0 0>; | ||||||
|  | #else | ||||||
|  | 	qcom,caldb-addr = <0x4FF00000>; | ||||||
|  | 	m3-dump-addr = <0x4FD00000>; | ||||||
|  | #endif | ||||||
|  | 	qcom,caldb-size = <0x500000>; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,379 @@ | |||||||
|  | // SPDX-License-Identifier: GPL-2.0-or-later OR MIT | ||||||
|  | /dts-v1/; | ||||||
|  |  | ||||||
|  | #include "qcom-ipq6018.dtsi" | ||||||
|  | #include "qcom-ipq6018-rpm-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cpr-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cp-cpu.dtsi" | ||||||
|  | #include <dt-bindings/input/input.h> | ||||||
|  | #include <dt-bindings/gpio/gpio.h> | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "Indio UM-310AX V1"; | ||||||
|  | 	compatible = "indio,um-310ax-v1", "qcom,ipq6018-cp03", "qcom,ipq6018"; | ||||||
|  |  | ||||||
|  | 	#address-cells = <0x2>; | ||||||
|  | 	#size-cells = <0x2>; | ||||||
|  | 	interrupt-parent = <&intc>; | ||||||
|  |  | ||||||
|  | 	aliases { | ||||||
|  | 		/* Aliases as required by u-boot to patch MAC addresses */ | ||||||
|  | 		ethernet0 = "/soc/dp2"; | ||||||
|  | 		ethernet1 = "/soc/dp1"; | ||||||
|  |  | ||||||
|  | 		serial0 = &blsp1_uart3; | ||||||
|  | 		serial1 = &blsp1_uart2; | ||||||
|  |  | ||||||
|  | 		led-boot = &led_system; | ||||||
|  | 		led-failsafe = &led_system; | ||||||
|  | 		led-running = &led_system; | ||||||
|  | 		led-upgrade = &led_system; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	chosen { | ||||||
|  | 		bootargs = "console=ttyMSM0,115200,n8 rw init=/init"; | ||||||
|  | 		bootargs-append = " swiotlb=1 coherent_pool=2M"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | /* TZAPP is enabled only in default memory profile */ | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
|  | 	reserved-memory { | ||||||
|  | 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x49B00000 0x0 0x00600000>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | #endif | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &tlmm { | ||||||
|  | 	uart_pins: uart_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio44", "gpio45"; | ||||||
|  | 			function = "blsp2_uart"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	spi_0_pins: spi_0_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio38", "gpio39", "gpio40", "gpio41"; | ||||||
|  | 			function = "blsp0_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	qpic_pins: qpic_pins { | ||||||
|  | 		data_0 { | ||||||
|  | 			pins = "gpio15"; | ||||||
|  | 			function = "qpic_pad0"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_1 { | ||||||
|  | 			pins = "gpio12"; | ||||||
|  | 			function = "qpic_pad1"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_2 { | ||||||
|  | 			pins = "gpio13"; | ||||||
|  | 			function = "qpic_pad2"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_3 { | ||||||
|  | 			pins = "gpio14"; | ||||||
|  | 			function = "qpic_pad3"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_4 { | ||||||
|  | 			pins = "gpio5"; | ||||||
|  | 			function = "qpic_pad4"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_5 { | ||||||
|  | 			pins = "gpio6"; | ||||||
|  | 			function = "qpic_pad5"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_6 { | ||||||
|  | 			pins = "gpio7"; | ||||||
|  | 			function = "qpic_pad6"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_7 { | ||||||
|  | 			pins = "gpio8"; | ||||||
|  | 			function = "qpic_pad7"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		qpic_pad { | ||||||
|  | 			pins = "gpio1",  "gpio3",  "gpio4", | ||||||
|  | 			       "gpio10", "gpio11", "gpio17"; | ||||||
|  | 			function = "qpic_pad"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	button_pins: button_pins { | ||||||
|  | 		rst_button { | ||||||
|  | 			pins = "gpio19"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	mdio_pins: mdio_pinmux { | ||||||
|  | 		mux_0 { | ||||||
|  | 			pins = "gpio64"; | ||||||
|  | 			function = "mdc"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mux_1 { | ||||||
|  | 			pins = "gpio65"; | ||||||
|  | 			function = "mdio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mux_2 { | ||||||
|  | 			pins = "gpio75"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	modem_power_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio27"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 			output-high; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds_pins: leds_pins { | ||||||
|  | 		led_blue { | ||||||
|  | 			pins = "gpio35"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_green { | ||||||
|  | 			pins = "gpio37"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_red { | ||||||
|  | 			pins = "gpio32"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &soc { | ||||||
|  | 	mdio: mdio@90000 { | ||||||
|  | 		status = "ok"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&mdio_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		phy-reset-gpio = <&tlmm 75 0>; | ||||||
|  |  | ||||||
|  | 		ethernet-phy@0 { | ||||||
|  | 			reg = <0x03>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		ethernet-phy@1 { | ||||||
|  | 			reg = <0x04>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	ess-switch@3a000000 { | ||||||
|  | 		switch_cpu_bmp =   <0x01>; /* cpu port bitmap */ | ||||||
|  | 		switch_lan_bmp =   <0x10>; /* lan port bitmap */ | ||||||
|  | 		switch_wan_bmp =   <0x20>; /* wan port bitmap */ | ||||||
|  | 		switch_inner_bmp = <0x80>; /*inner port bitmap*/ | ||||||
|  | 		switch_mac_mode =  <0x00>; /* mac mode for uniphy instance0*/ | ||||||
|  | 		switch_mac_mode1 = <0xff>; /* mac mode for uniphy instance1*/ | ||||||
|  | 		switch_mac_mode2 = <0xff>; /* mac mode for uniphy instance2*/ | ||||||
|  |  | ||||||
|  | 		qcom,port_phyinfo { | ||||||
|  | 			port@3 { | ||||||
|  | 				port_id = <0x04>; | ||||||
|  | 				phy_address = <0x03>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			port@4 { | ||||||
|  | 				port_id = <0x05>; | ||||||
|  | 				phy_address = <0x04>; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	dp1 { | ||||||
|  | 		device_type = "network"; | ||||||
|  | 		compatible = "qcom,nss-dp"; | ||||||
|  | 		qcom,id = <0x04>; | ||||||
|  | 		reg = <0x3a001600 0x200>; | ||||||
|  | 		qcom,mactype = <0x00>; | ||||||
|  | 		local-mac-address = [00 00 00 00 00 00]; | ||||||
|  | 		qcom,link-poll = <0x01>; | ||||||
|  | 		qcom,phy-mdio-addr = <0x03>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	dp2 { | ||||||
|  | 		device_type = "network"; | ||||||
|  | 		compatible = "qcom,nss-dp"; | ||||||
|  | 		qcom,id = <0x05>; | ||||||
|  | 		reg = <0x3a001800 0x200>; | ||||||
|  | 		qcom,mactype = <0x00>; | ||||||
|  | 		local-mac-address = [00 00 00 00 00 00]; | ||||||
|  | 		qcom,link-poll = <0x01>; | ||||||
|  | 		qcom,phy-mdio-addr = <0x04>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	gpio_keys { | ||||||
|  | 		compatible = "gpio-keys"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&button_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		reset { | ||||||
|  | 			label = "reset"; | ||||||
|  | 			linux,code = <KEY_RESTART>; | ||||||
|  | 			gpios = <&tlmm 19 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds { | ||||||
|  | 		compatible = "gpio-leds"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&leds_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		led_system: system { | ||||||
|  | 			label = "green:system"; | ||||||
|  | 			gpio = <&tlmm 37 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		wlan2g { | ||||||
|  | 			label = "blue:wlan2g"; | ||||||
|  | 			gpio = <&tlmm 35 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		wlan5g { | ||||||
|  | 			label = "red:wlan5g"; | ||||||
|  | 			gpio = <&tlmm 32 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &blsp1_uart3 { | ||||||
|  | 	pinctrl-0 = <&uart_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &spi_0 { | ||||||
|  | 	pinctrl-0 = <&spi_0_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; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qpic_bam { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nand { | ||||||
|  | 	pinctrl-0 = <&qpic_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nss_crypto { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &cpu0_opp_table { | ||||||
|  | 	compatible = "operating-points-v2"; | ||||||
|  | 	opp-shared; | ||||||
|  |  | ||||||
|  | 	opp03 { | ||||||
|  | 		opp-hz = /bits/ 64 <1200000000>; | ||||||
|  | 		opp-microvolt = <3>; | ||||||
|  | 		clock-latency-ns = <200000>; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/delete-node/ opp04; | ||||||
|  | 	/delete-node/ opp05; | ||||||
|  | 	/delete-node/ opp06; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* TZAPP is enabled in default memory profile only */ | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
|  | &qseecom { | ||||||
|  | 	mem-start = <0x49B00000>; | ||||||
|  | 	mem-size = <0x600000>; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | &ssphy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_1 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb2 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb3 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,379 @@ | |||||||
|  | // SPDX-License-Identifier: GPL-2.0-or-later OR MIT | ||||||
|  | /dts-v1/; | ||||||
|  |  | ||||||
|  | #include "qcom-ipq6018.dtsi" | ||||||
|  | #include "qcom-ipq6018-rpm-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cpr-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cp-cpu.dtsi" | ||||||
|  | #include <dt-bindings/input/input.h> | ||||||
|  | #include <dt-bindings/gpio/gpio.h> | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "Indio UM-510AXM V1"; | ||||||
|  | 	compatible = "indio,um-510axm-v1", "qcom,ipq6018-cp03", "qcom,ipq6018"; | ||||||
|  |  | ||||||
|  | 	#address-cells = <0x2>; | ||||||
|  | 	#size-cells = <0x2>; | ||||||
|  | 	interrupt-parent = <&intc>; | ||||||
|  |  | ||||||
|  | 	aliases { | ||||||
|  | 		/* Aliases as required by u-boot to patch MAC addresses */ | ||||||
|  | 		ethernet0 = "/soc/dp2"; | ||||||
|  | 		ethernet1 = "/soc/dp1"; | ||||||
|  |  | ||||||
|  | 		serial0 = &blsp1_uart3; | ||||||
|  | 		serial1 = &blsp1_uart2; | ||||||
|  |  | ||||||
|  | 		led-boot = &led_system; | ||||||
|  | 		led-failsafe = &led_system; | ||||||
|  | 		led-running = &led_system; | ||||||
|  | 		led-upgrade = &led_system; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	chosen { | ||||||
|  | 		bootargs = "console=ttyMSM0,115200,n8 rw init=/init"; | ||||||
|  | 		bootargs-append = " swiotlb=1 coherent_pool=2M"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | /* TZAPP is enabled only in default memory profile */ | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
|  | 	reserved-memory { | ||||||
|  | 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x49B00000 0x0 0x00600000>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | #endif | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &tlmm { | ||||||
|  | 	uart_pins: uart_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio44", "gpio45"; | ||||||
|  | 			function = "blsp2_uart"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	spi_0_pins: spi_0_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio38", "gpio39", "gpio40", "gpio41"; | ||||||
|  | 			function = "blsp0_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	qpic_pins: qpic_pins { | ||||||
|  | 		data_0 { | ||||||
|  | 			pins = "gpio15"; | ||||||
|  | 			function = "qpic_pad0"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_1 { | ||||||
|  | 			pins = "gpio12"; | ||||||
|  | 			function = "qpic_pad1"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_2 { | ||||||
|  | 			pins = "gpio13"; | ||||||
|  | 			function = "qpic_pad2"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_3 { | ||||||
|  | 			pins = "gpio14"; | ||||||
|  | 			function = "qpic_pad3"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_4 { | ||||||
|  | 			pins = "gpio5"; | ||||||
|  | 			function = "qpic_pad4"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_5 { | ||||||
|  | 			pins = "gpio6"; | ||||||
|  | 			function = "qpic_pad5"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_6 { | ||||||
|  | 			pins = "gpio7"; | ||||||
|  | 			function = "qpic_pad6"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_7 { | ||||||
|  | 			pins = "gpio8"; | ||||||
|  | 			function = "qpic_pad7"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		qpic_pad { | ||||||
|  | 			pins = "gpio1",  "gpio3",  "gpio4", | ||||||
|  | 			       "gpio10", "gpio11", "gpio17"; | ||||||
|  | 			function = "qpic_pad"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	button_pins: button_pins { | ||||||
|  | 		rst_button { | ||||||
|  | 			pins = "gpio19"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	mdio_pins: mdio_pinmux { | ||||||
|  | 		mux_0 { | ||||||
|  | 			pins = "gpio64"; | ||||||
|  | 			function = "mdc"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mux_1 { | ||||||
|  | 			pins = "gpio65"; | ||||||
|  | 			function = "mdio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mux_2 { | ||||||
|  | 			pins = "gpio75"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	modem_power_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio27"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 			output-high; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds_pins: leds_pins { | ||||||
|  | 		led_blue { | ||||||
|  | 			pins = "gpio35"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_green { | ||||||
|  | 			pins = "gpio37"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_red { | ||||||
|  | 			pins = "gpio32"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &soc { | ||||||
|  | 	mdio: mdio@90000 { | ||||||
|  | 		status = "ok"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&mdio_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		phy-reset-gpio = <&tlmm 75 0>; | ||||||
|  |  | ||||||
|  | 		ethernet-phy@0 { | ||||||
|  | 			reg = <0x03>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		ethernet-phy@1 { | ||||||
|  | 			reg = <0x04>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	ess-switch@3a000000 { | ||||||
|  | 		switch_cpu_bmp =   <0x01>; /* cpu port bitmap */ | ||||||
|  | 		switch_lan_bmp =   <0x10>; /* lan port bitmap */ | ||||||
|  | 		switch_wan_bmp =   <0x20>; /* wan port bitmap */ | ||||||
|  | 		switch_inner_bmp = <0x80>; /*inner port bitmap*/ | ||||||
|  | 		switch_mac_mode =  <0x00>; /* mac mode for uniphy instance0*/ | ||||||
|  | 		switch_mac_mode1 = <0xff>; /* mac mode for uniphy instance1*/ | ||||||
|  | 		switch_mac_mode2 = <0xff>; /* mac mode for uniphy instance2*/ | ||||||
|  |  | ||||||
|  | 		qcom,port_phyinfo { | ||||||
|  | 			port@3 { | ||||||
|  | 				port_id = <0x04>; | ||||||
|  | 				phy_address = <0x03>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			port@4 { | ||||||
|  | 				port_id = <0x05>; | ||||||
|  | 				phy_address = <0x04>; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	dp1 { | ||||||
|  | 		device_type = "network"; | ||||||
|  | 		compatible = "qcom,nss-dp"; | ||||||
|  | 		qcom,id = <0x04>; | ||||||
|  | 		reg = <0x3a001600 0x200>; | ||||||
|  | 		qcom,mactype = <0x00>; | ||||||
|  | 		local-mac-address = [00 00 00 00 00 00]; | ||||||
|  | 		qcom,link-poll = <0x01>; | ||||||
|  | 		qcom,phy-mdio-addr = <0x03>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	dp2 { | ||||||
|  | 		device_type = "network"; | ||||||
|  | 		compatible = "qcom,nss-dp"; | ||||||
|  | 		qcom,id = <0x05>; | ||||||
|  | 		reg = <0x3a001800 0x200>; | ||||||
|  | 		qcom,mactype = <0x00>; | ||||||
|  | 		local-mac-address = [00 00 00 00 00 00]; | ||||||
|  | 		qcom,link-poll = <0x01>; | ||||||
|  | 		qcom,phy-mdio-addr = <0x04>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	gpio_keys { | ||||||
|  | 		compatible = "gpio-keys"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&button_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		reset { | ||||||
|  | 			label = "reset"; | ||||||
|  | 			linux,code = <KEY_RESTART>; | ||||||
|  | 			gpios = <&tlmm 19 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds { | ||||||
|  | 		compatible = "gpio-leds"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&leds_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		led_system: system { | ||||||
|  | 			label = "green:system"; | ||||||
|  | 			gpio = <&tlmm 37 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		wlan2g { | ||||||
|  | 			label = "blue:wlan2g"; | ||||||
|  | 			gpio = <&tlmm 35 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		wlan5g { | ||||||
|  | 			label = "red:wlan5g"; | ||||||
|  | 			gpio = <&tlmm 32 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &blsp1_uart3 { | ||||||
|  | 	pinctrl-0 = <&uart_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &spi_0 { | ||||||
|  | 	pinctrl-0 = <&spi_0_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; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qpic_bam { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nand { | ||||||
|  | 	pinctrl-0 = <&qpic_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nss_crypto { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &cpu0_opp_table { | ||||||
|  | 	compatible = "operating-points-v2"; | ||||||
|  | 	opp-shared; | ||||||
|  |  | ||||||
|  | 	opp03 { | ||||||
|  | 		opp-hz = /bits/ 64 <1200000000>; | ||||||
|  | 		opp-microvolt = <3>; | ||||||
|  | 		clock-latency-ns = <200000>; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/delete-node/ opp04; | ||||||
|  | 	/delete-node/ opp05; | ||||||
|  | 	/delete-node/ opp06; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* TZAPP is enabled in default memory profile only */ | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
|  | &qseecom { | ||||||
|  | 	mem-start = <0x49B00000>; | ||||||
|  | 	mem-size = <0x600000>; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | &ssphy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_1 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb2 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb3 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,379 @@ | |||||||
|  | // SPDX-License-Identifier: GPL-2.0-or-later OR MIT | ||||||
|  | /dts-v1/; | ||||||
|  |  | ||||||
|  | #include "qcom-ipq6018.dtsi" | ||||||
|  | #include "qcom-ipq6018-rpm-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cpr-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cp-cpu.dtsi" | ||||||
|  | #include <dt-bindings/input/input.h> | ||||||
|  | #include <dt-bindings/gpio/gpio.h> | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "Indio UM-510AXP V1"; | ||||||
|  | 	compatible = "indio,um-510axp-v1", "qcom,ipq6018-cp03", "qcom,ipq6018"; | ||||||
|  |  | ||||||
|  | 	#address-cells = <0x2>; | ||||||
|  | 	#size-cells = <0x2>; | ||||||
|  | 	interrupt-parent = <&intc>; | ||||||
|  |  | ||||||
|  | 	aliases { | ||||||
|  | 		/* Aliases as required by u-boot to patch MAC addresses */ | ||||||
|  | 		ethernet0 = "/soc/dp2"; | ||||||
|  | 		ethernet1 = "/soc/dp1"; | ||||||
|  |  | ||||||
|  | 		serial0 = &blsp1_uart3; | ||||||
|  | 		serial1 = &blsp1_uart2; | ||||||
|  |  | ||||||
|  | 		led-boot = &led_system; | ||||||
|  | 		led-failsafe = &led_system; | ||||||
|  | 		led-running = &led_system; | ||||||
|  | 		led-upgrade = &led_system; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	chosen { | ||||||
|  | 		bootargs = "console=ttyMSM0,115200,n8 rw init=/init"; | ||||||
|  | 		bootargs-append = " swiotlb=1 coherent_pool=2M"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | /* TZAPP is enabled only in default memory profile */ | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
|  | 	reserved-memory { | ||||||
|  | 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x49B00000 0x0 0x00600000>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | #endif | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &tlmm { | ||||||
|  | 	uart_pins: uart_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio44", "gpio45"; | ||||||
|  | 			function = "blsp2_uart"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	spi_0_pins: spi_0_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio38", "gpio39", "gpio40", "gpio41"; | ||||||
|  | 			function = "blsp0_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	qpic_pins: qpic_pins { | ||||||
|  | 		data_0 { | ||||||
|  | 			pins = "gpio15"; | ||||||
|  | 			function = "qpic_pad0"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_1 { | ||||||
|  | 			pins = "gpio12"; | ||||||
|  | 			function = "qpic_pad1"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_2 { | ||||||
|  | 			pins = "gpio13"; | ||||||
|  | 			function = "qpic_pad2"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_3 { | ||||||
|  | 			pins = "gpio14"; | ||||||
|  | 			function = "qpic_pad3"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_4 { | ||||||
|  | 			pins = "gpio5"; | ||||||
|  | 			function = "qpic_pad4"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_5 { | ||||||
|  | 			pins = "gpio6"; | ||||||
|  | 			function = "qpic_pad5"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_6 { | ||||||
|  | 			pins = "gpio7"; | ||||||
|  | 			function = "qpic_pad6"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		data_7 { | ||||||
|  | 			pins = "gpio8"; | ||||||
|  | 			function = "qpic_pad7"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		qpic_pad { | ||||||
|  | 			pins = "gpio1",  "gpio3",  "gpio4", | ||||||
|  | 			       "gpio10", "gpio11", "gpio17"; | ||||||
|  | 			function = "qpic_pad"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	button_pins: button_pins { | ||||||
|  | 		rst_button { | ||||||
|  | 			pins = "gpio19"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	mdio_pins: mdio_pinmux { | ||||||
|  | 		mux_0 { | ||||||
|  | 			pins = "gpio64"; | ||||||
|  | 			function = "mdc"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mux_1 { | ||||||
|  | 			pins = "gpio65"; | ||||||
|  | 			function = "mdio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mux_2 { | ||||||
|  | 			pins = "gpio75"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	modem_power_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio27"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 			output-high; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds_pins: leds_pins { | ||||||
|  | 		led_blue { | ||||||
|  | 			pins = "gpio35"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_green { | ||||||
|  | 			pins = "gpio37"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_red { | ||||||
|  | 			pins = "gpio32"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &soc { | ||||||
|  | 	mdio: mdio@90000 { | ||||||
|  | 		status = "ok"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&mdio_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		phy-reset-gpio = <&tlmm 75 0>; | ||||||
|  |  | ||||||
|  | 		ethernet-phy@0 { | ||||||
|  | 			reg = <0x03>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		ethernet-phy@1 { | ||||||
|  | 			reg = <0x04>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	ess-switch@3a000000 { | ||||||
|  | 		switch_cpu_bmp =   <0x01>; /* cpu port bitmap */ | ||||||
|  | 		switch_lan_bmp =   <0x10>; /* lan port bitmap */ | ||||||
|  | 		switch_wan_bmp =   <0x20>; /* wan port bitmap */ | ||||||
|  | 		switch_inner_bmp = <0x80>; /*inner port bitmap*/ | ||||||
|  | 		switch_mac_mode =  <0x00>; /* mac mode for uniphy instance0*/ | ||||||
|  | 		switch_mac_mode1 = <0xff>; /* mac mode for uniphy instance1*/ | ||||||
|  | 		switch_mac_mode2 = <0xff>; /* mac mode for uniphy instance2*/ | ||||||
|  |  | ||||||
|  | 		qcom,port_phyinfo { | ||||||
|  | 			port@3 { | ||||||
|  | 				port_id = <0x04>; | ||||||
|  | 				phy_address = <0x03>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			port@4 { | ||||||
|  | 				port_id = <0x05>; | ||||||
|  | 				phy_address = <0x04>; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	dp1 { | ||||||
|  | 		device_type = "network"; | ||||||
|  | 		compatible = "qcom,nss-dp"; | ||||||
|  | 		qcom,id = <0x04>; | ||||||
|  | 		reg = <0x3a001600 0x200>; | ||||||
|  | 		qcom,mactype = <0x00>; | ||||||
|  | 		local-mac-address = [00 00 00 00 00 00]; | ||||||
|  | 		qcom,link-poll = <0x01>; | ||||||
|  | 		qcom,phy-mdio-addr = <0x03>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	dp2 { | ||||||
|  | 		device_type = "network"; | ||||||
|  | 		compatible = "qcom,nss-dp"; | ||||||
|  | 		qcom,id = <0x05>; | ||||||
|  | 		reg = <0x3a001800 0x200>; | ||||||
|  | 		qcom,mactype = <0x00>; | ||||||
|  | 		local-mac-address = [00 00 00 00 00 00]; | ||||||
|  | 		qcom,link-poll = <0x01>; | ||||||
|  | 		qcom,phy-mdio-addr = <0x04>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	gpio_keys { | ||||||
|  | 		compatible = "gpio-keys"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&button_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		reset { | ||||||
|  | 			label = "reset"; | ||||||
|  | 			linux,code = <KEY_RESTART>; | ||||||
|  | 			gpios = <&tlmm 19 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds { | ||||||
|  | 		compatible = "gpio-leds"; | ||||||
|  |  | ||||||
|  | 		pinctrl-0 = <&leds_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		led_system: system { | ||||||
|  | 			label = "green:system"; | ||||||
|  | 			gpio = <&tlmm 37 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		wlan2g { | ||||||
|  | 			label = "blue:wlan2g"; | ||||||
|  | 			gpio = <&tlmm 35 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		wlan5g { | ||||||
|  | 			label = "red:wlan5g"; | ||||||
|  | 			gpio = <&tlmm 32 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &blsp1_uart3 { | ||||||
|  | 	pinctrl-0 = <&uart_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &spi_0 { | ||||||
|  | 	pinctrl-0 = <&spi_0_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; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qpic_bam { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nand { | ||||||
|  | 	pinctrl-0 = <&qpic_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nss_crypto { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &cpu0_opp_table { | ||||||
|  | 	compatible = "operating-points-v2"; | ||||||
|  | 	opp-shared; | ||||||
|  |  | ||||||
|  | 	opp03 { | ||||||
|  | 		opp-hz = /bits/ 64 <1200000000>; | ||||||
|  | 		opp-microvolt = <3>; | ||||||
|  | 		clock-latency-ns = <200000>; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/delete-node/ opp04; | ||||||
|  | 	/delete-node/ opp05; | ||||||
|  | 	/delete-node/ opp06; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* TZAPP is enabled in default memory profile only */ | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
|  | &qseecom { | ||||||
|  | 	mem-start = <0x49B00000>; | ||||||
|  | 	mem-size = <0x600000>; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | &ssphy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_1 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb2 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb3 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
| @@ -18,6 +18,15 @@ define Device/edgecore_eap104 | |||||||
| endef | endef | ||||||
| TARGET_DEVICES += edgecore_eap104 | TARGET_DEVICES += edgecore_eap104 | ||||||
|  |  | ||||||
|  | define Device/liteon_wpx8324 | ||||||
|  |   DEVICE_TITLE := Liteon WPX8324 | ||||||
|  |   DEVICE_DTS := qcom-ipq5018-liteon-wpx8324 | ||||||
|  |   SUPPORTED_DEVICES := liteon,wpx8324 | ||||||
|  |   DEVICE_PACKAGES := ath11k-wifi-liteon-wpx8324 ath11k-firmware-ipq50xx-spruce ath11k-firmware-qcn6122 | ||||||
|  |   DEVICE_DTS_CONFIG := config@mp03.5-c1 | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += liteon_wpx8324 | ||||||
|  |  | ||||||
| define Device/motorola_q14 | define Device/motorola_q14 | ||||||
|   DEVICE_TITLE := Motorola Q14 |   DEVICE_TITLE := Motorola Q14 | ||||||
|   DEVICE_DTS := qcom-ipq5018-q14 |   DEVICE_DTS := qcom-ipq5018-q14 | ||||||
|   | |||||||
| @@ -38,6 +38,33 @@ define Device/edgecore_eap101 | |||||||
| endef | endef | ||||||
| TARGET_DEVICES += edgecore_eap101 | TARGET_DEVICES += edgecore_eap101 | ||||||
|  |  | ||||||
|  | define Device/indio_um-310ax-v1 | ||||||
|  |   DEVICE_TITLE := Indio UM-310AX V1 | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-indio-um-310ax-v1 | ||||||
|  |   DEVICE_DTS_CONFIG := config@cp03-c1 | ||||||
|  |   SUPPORTED_DEVICES := indio,um-310ax-v1 | ||||||
|  |   DEVICE_PACKAGES := ath11k-wifi-indio-um-310ax-v1 uboot-env | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += indio_um-310ax-v1 | ||||||
|  |  | ||||||
|  | define Device/indio_um-510axp-v1 | ||||||
|  |   DEVICE_TITLE := Indio UM-510AXP V1 | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-indio-um-510axp-v1 | ||||||
|  |   DEVICE_DTS_CONFIG := config@cp03-c1 | ||||||
|  |   SUPPORTED_DEVICES := indio,um-510axp-v1 | ||||||
|  |   DEVICE_PACKAGES := ath11k-wifi-indio-um-510axp-v1 uboot-env | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += indio_um-510axp-v1 | ||||||
|  |  | ||||||
|  | define Device/indio_um-510axm-v1 | ||||||
|  |   DEVICE_TITLE := Indio UM-510AXM V1 | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-indio-um-510axm-v1 | ||||||
|  |   DEVICE_DTS_CONFIG := config@cp03-c1 | ||||||
|  |   SUPPORTED_DEVICES := indio,um-510axm-v1 | ||||||
|  |   DEVICE_PACKAGES := ath11k-wifi-indio-um-510axm-v1 uboot-env | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += indio_um-510axm-v1 | ||||||
|  |  | ||||||
| define Device/wallys_dr6018 | define Device/wallys_dr6018 | ||||||
|   DEVICE_TITLE := Wallys DR6018 |   DEVICE_TITLE := Wallys DR6018 | ||||||
|   DEVICE_DTS := qcom-ipq6018-wallys-dr6018 |   DEVICE_DTS := qcom-ipq6018-wallys-dr6018 | ||||||
|   | |||||||
| @@ -0,0 +1,315 @@ | |||||||
|  | From: Jiri Pirko <jiri@mellanox.com> | ||||||
|  | Date: Thu, 21 Jul 2016 12:03:11 +0200 | ||||||
|  | Subject: [PATCH] net/sched: introduce Match-all classifier | ||||||
|  |  | ||||||
|  | The matchall classifier matches every packet and allows the user to apply | ||||||
|  | actions on it. This filter is very useful in usecases where every packet | ||||||
|  | should be matched, for example, packet mirroring (SPAN) can be setup very | ||||||
|  | easily using that filter. | ||||||
|  |  | ||||||
|  | Signed-off-by: Jiri Pirko <jiri@mellanox.com> | ||||||
|  | Signed-off-by: Yotam Gigi <yotamg@mellanox.com> | ||||||
|  | Signed-off-by: David S. Miller <davem@davemloft.net> | ||||||
|  | --- | ||||||
|  |  create mode 100644 net/sched/cls_matchall.c | ||||||
|  |  | ||||||
|  | --- a/include/uapi/linux/pkt_cls.h | ||||||
|  | +++ b/include/uapi/linux/pkt_cls.h | ||||||
|  | @@ -427,6 +427,17 @@ enum { | ||||||
|  |   | ||||||
|  |  #define TCA_FLOWER_MAX (__TCA_FLOWER_MAX - 1) | ||||||
|  |   | ||||||
|  | +/* Match-all classifier */ | ||||||
|  | + | ||||||
|  | +enum { | ||||||
|  | +	TCA_MATCHALL_UNSPEC, | ||||||
|  | +	TCA_MATCHALL_CLASSID, | ||||||
|  | +	TCA_MATCHALL_ACT, | ||||||
|  | +	__TCA_MATCHALL_MAX, | ||||||
|  | +}; | ||||||
|  | + | ||||||
|  | +#define TCA_MATCHALL_MAX (__TCA_MATCHALL_MAX - 1) | ||||||
|  | + | ||||||
|  |  /* Extended Matches */ | ||||||
|  |   | ||||||
|  |  struct tcf_ematch_tree_hdr { | ||||||
|  | --- /dev/null | ||||||
|  | +++ b/net/sched/cls_matchall.c | ||||||
|  | @@ -0,0 +1,248 @@ | ||||||
|  | +/* | ||||||
|  | + * net/sched/cls_matchll.c		Match-all classifier | ||||||
|  | + * | ||||||
|  | + * Copyright (c) 2016 Jiri Pirko <jiri@mellanox.com> | ||||||
|  | + * | ||||||
|  | + * This program is free software; you can redistribute it and/or modify | ||||||
|  | + * it under the terms of the GNU General Public License as published by | ||||||
|  | + * the Free Software Foundation; either version 2 of the License, or | ||||||
|  | + * (at your option) any later version. | ||||||
|  | + */ | ||||||
|  | + | ||||||
|  | +#include <linux/kernel.h> | ||||||
|  | +#include <linux/init.h> | ||||||
|  | +#include <linux/module.h> | ||||||
|  | + | ||||||
|  | +#include <net/sch_generic.h> | ||||||
|  | +#include <net/pkt_cls.h> | ||||||
|  | + | ||||||
|  | +struct cls_mall_filter { | ||||||
|  | +	struct tcf_exts exts; | ||||||
|  | +	struct tcf_result res; | ||||||
|  | +	u32 handle; | ||||||
|  | +	struct rcu_head	rcu; | ||||||
|  | +}; | ||||||
|  | + | ||||||
|  | +struct cls_mall_head { | ||||||
|  | +	struct cls_mall_filter *filter; | ||||||
|  | +	struct rcu_head	rcu; | ||||||
|  | +}; | ||||||
|  | + | ||||||
|  | +static int mall_classify(struct sk_buff *skb, const struct tcf_proto *tp, | ||||||
|  | +			 struct tcf_result *res) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_head *head = rcu_dereference_bh(tp->root); | ||||||
|  | +	struct cls_mall_filter *f = head->filter; | ||||||
|  | + | ||||||
|  | +	return tcf_exts_exec(skb, &f->exts, res); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static int mall_init(struct tcf_proto *tp) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_head *head; | ||||||
|  | + | ||||||
|  | +	head = kzalloc(sizeof(*head), GFP_KERNEL); | ||||||
|  | +	if (!head) | ||||||
|  | +		return -ENOBUFS; | ||||||
|  | + | ||||||
|  | +	rcu_assign_pointer(tp->root, head); | ||||||
|  | + | ||||||
|  | +	return 0; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static void mall_destroy_filter(struct rcu_head *head) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_filter *f = container_of(head, struct cls_mall_filter, rcu); | ||||||
|  | + | ||||||
|  | +	tcf_exts_destroy(&f->exts); | ||||||
|  | +	kfree(f); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static bool mall_destroy(struct tcf_proto *tp, bool force) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_head *head = rtnl_dereference(tp->root); | ||||||
|  | + | ||||||
|  | +	if (!force && head->filter) | ||||||
|  | +		return false; | ||||||
|  | + | ||||||
|  | +	if (head->filter) | ||||||
|  | +		call_rcu(&head->filter->rcu, mall_destroy_filter); | ||||||
|  | +	RCU_INIT_POINTER(tp->root, NULL); | ||||||
|  | +	kfree_rcu(head, rcu); | ||||||
|  | +	return true; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static unsigned long mall_get(struct tcf_proto *tp, u32 handle) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_head *head = rtnl_dereference(tp->root); | ||||||
|  | +	struct cls_mall_filter *f = head->filter; | ||||||
|  | + | ||||||
|  | +	if (f && f->handle == handle) | ||||||
|  | +		return (unsigned long) f; | ||||||
|  | +	return 0; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static const struct nla_policy mall_policy[TCA_MATCHALL_MAX + 1] = { | ||||||
|  | +	[TCA_MATCHALL_UNSPEC]		= { .type = NLA_UNSPEC }, | ||||||
|  | +	[TCA_MATCHALL_CLASSID]		= { .type = NLA_U32 }, | ||||||
|  | +}; | ||||||
|  | + | ||||||
|  | +static int mall_set_parms(struct net *net, struct tcf_proto *tp, | ||||||
|  | +			  struct cls_mall_filter *f, | ||||||
|  | +			  unsigned long base, struct nlattr **tb, | ||||||
|  | +			  struct nlattr *est, bool ovr) | ||||||
|  | +{ | ||||||
|  | +	struct tcf_exts e; | ||||||
|  | +	int err; | ||||||
|  | + | ||||||
|  | +	tcf_exts_init(&e, TCA_MATCHALL_ACT, 0); | ||||||
|  | +	err = tcf_exts_validate(net, tp, tb, est, &e, ovr); | ||||||
|  | +	if (err < 0) | ||||||
|  | +		return err; | ||||||
|  | + | ||||||
|  | +	if (tb[TCA_MATCHALL_CLASSID]) { | ||||||
|  | +		f->res.classid = nla_get_u32(tb[TCA_MATCHALL_CLASSID]); | ||||||
|  | +		tcf_bind_filter(tp, &f->res, base); | ||||||
|  | +	} | ||||||
|  | + | ||||||
|  | +	tcf_exts_change(tp, &f->exts, &e); | ||||||
|  | + | ||||||
|  | +	return 0; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static int mall_change(struct net *net, struct sk_buff *in_skb, | ||||||
|  | +		       struct tcf_proto *tp, unsigned long base, | ||||||
|  | +		       u32 handle, struct nlattr **tca, | ||||||
|  | +		       unsigned long *arg, bool ovr) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_head *head = rtnl_dereference(tp->root); | ||||||
|  | +	struct cls_mall_filter *fold = (struct cls_mall_filter *) *arg; | ||||||
|  | +	struct cls_mall_filter *f; | ||||||
|  | +	struct nlattr *tb[TCA_MATCHALL_MAX + 1]; | ||||||
|  | +	int err; | ||||||
|  | + | ||||||
|  | +	if (!tca[TCA_OPTIONS]) | ||||||
|  | +		return -EINVAL; | ||||||
|  | + | ||||||
|  | +	if (head->filter) | ||||||
|  | +		return -EBUSY; | ||||||
|  | + | ||||||
|  | +	if (fold) | ||||||
|  | +		return -EINVAL; | ||||||
|  | + | ||||||
|  | +	err = nla_parse_nested(tb, TCA_MATCHALL_MAX, | ||||||
|  | +			       tca[TCA_OPTIONS], mall_policy); | ||||||
|  | +	if (err < 0) | ||||||
|  | +		return err; | ||||||
|  | + | ||||||
|  | +	f = kzalloc(sizeof(*f), GFP_KERNEL); | ||||||
|  | +	if (!f) | ||||||
|  | +		return -ENOBUFS; | ||||||
|  | + | ||||||
|  | +	tcf_exts_init(&f->exts, TCA_MATCHALL_ACT, 0); | ||||||
|  | + | ||||||
|  | +	if (!handle) | ||||||
|  | +		handle = 1; | ||||||
|  | +	f->handle = handle; | ||||||
|  | + | ||||||
|  | +	err = mall_set_parms(net, tp, f, base, tb, tca[TCA_RATE], ovr); | ||||||
|  | +	if (err) | ||||||
|  | +		goto errout; | ||||||
|  | + | ||||||
|  | +	*arg = (unsigned long) f; | ||||||
|  | +	rcu_assign_pointer(head->filter, f); | ||||||
|  | + | ||||||
|  | +	return 0; | ||||||
|  | + | ||||||
|  | +errout: | ||||||
|  | +	kfree(f); | ||||||
|  | +	return err; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static int mall_delete(struct tcf_proto *tp, unsigned long arg) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_head *head = rtnl_dereference(tp->root); | ||||||
|  | +	struct cls_mall_filter *f = (struct cls_mall_filter *) arg; | ||||||
|  | + | ||||||
|  | +	RCU_INIT_POINTER(head->filter, NULL); | ||||||
|  | +	tcf_unbind_filter(tp, &f->res); | ||||||
|  | +	call_rcu(&f->rcu, mall_destroy_filter); | ||||||
|  | +	return 0; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static void mall_walk(struct tcf_proto *tp, struct tcf_walker *arg) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_head *head = rtnl_dereference(tp->root); | ||||||
|  | +	struct cls_mall_filter *f = head->filter; | ||||||
|  | + | ||||||
|  | +	if (arg->count < arg->skip) | ||||||
|  | +		goto skip; | ||||||
|  | +	if (arg->fn(tp, (unsigned long) f, arg) < 0) | ||||||
|  | +		arg->stop = 1; | ||||||
|  | +skip: | ||||||
|  | +	arg->count++; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static int mall_dump(struct net *net, struct tcf_proto *tp, unsigned long fh, | ||||||
|  | +		     struct sk_buff *skb, struct tcmsg *t) | ||||||
|  | +{ | ||||||
|  | +	struct cls_mall_filter *f = (struct cls_mall_filter *) fh; | ||||||
|  | +	struct nlattr *nest; | ||||||
|  | + | ||||||
|  | +	if (!f) | ||||||
|  | +		return skb->len; | ||||||
|  | + | ||||||
|  | +	t->tcm_handle = f->handle; | ||||||
|  | + | ||||||
|  | +	nest = nla_nest_start(skb, TCA_OPTIONS); | ||||||
|  | +	if (!nest) | ||||||
|  | +		goto nla_put_failure; | ||||||
|  | + | ||||||
|  | +	if (f->res.classid && | ||||||
|  | +	    nla_put_u32(skb, TCA_MATCHALL_CLASSID, f->res.classid)) | ||||||
|  | +		goto nla_put_failure; | ||||||
|  | + | ||||||
|  | +	if (tcf_exts_dump(skb, &f->exts)) | ||||||
|  | +		goto nla_put_failure; | ||||||
|  | + | ||||||
|  | +	nla_nest_end(skb, nest); | ||||||
|  | + | ||||||
|  | +	if (tcf_exts_dump_stats(skb, &f->exts) < 0) | ||||||
|  | +		goto nla_put_failure; | ||||||
|  | + | ||||||
|  | +	return skb->len; | ||||||
|  | + | ||||||
|  | +nla_put_failure: | ||||||
|  | +	nla_nest_cancel(skb, nest); | ||||||
|  | +	return -1; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static struct tcf_proto_ops cls_mall_ops __read_mostly = { | ||||||
|  | +	.kind		= "matchall", | ||||||
|  | +	.classify	= mall_classify, | ||||||
|  | +	.init		= mall_init, | ||||||
|  | +	.destroy	= mall_destroy, | ||||||
|  | +	.get		= mall_get, | ||||||
|  | +	.change		= mall_change, | ||||||
|  | +	.delete		= mall_delete, | ||||||
|  | +	.walk		= mall_walk, | ||||||
|  | +	.dump		= mall_dump, | ||||||
|  | +	.owner		= THIS_MODULE, | ||||||
|  | +}; | ||||||
|  | + | ||||||
|  | +static int __init cls_mall_init(void) | ||||||
|  | +{ | ||||||
|  | +	return register_tcf_proto_ops(&cls_mall_ops); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static void __exit cls_mall_exit(void) | ||||||
|  | +{ | ||||||
|  | +	unregister_tcf_proto_ops(&cls_mall_ops); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +module_init(cls_mall_init); | ||||||
|  | +module_exit(cls_mall_exit); | ||||||
|  | + | ||||||
|  | +MODULE_AUTHOR("Jiri Pirko <jiri@mellanox.com>"); | ||||||
|  | +MODULE_DESCRIPTION("Match-all classifier"); | ||||||
|  | +MODULE_LICENSE("GPL v2"); | ||||||
|  | --- a/net/sched/Kconfig | ||||||
|  | +++ b/net/sched/Kconfig | ||||||
|  | @@ -526,6 +526,16 @@ config NET_CLS_FLOWER | ||||||
|  |  	  To compile this code as a module, choose M here: the module will | ||||||
|  |  	  be called cls_flower. | ||||||
|  |   | ||||||
|  | +config NET_CLS_MATCHALL | ||||||
|  | +	tristate "Match-all classifier" | ||||||
|  | +	select NET_CLS | ||||||
|  | +	---help--- | ||||||
|  | +	  If you say Y here, you will be able to classify packets based on | ||||||
|  | +	  nothing. Every packet will match. | ||||||
|  | + | ||||||
|  | +	  To compile this code as a module, choose M here: the module will | ||||||
|  | +	  be called cls_matchall. | ||||||
|  | + | ||||||
|  |  config NET_EMATCH | ||||||
|  |  	bool "Extended Matches" | ||||||
|  |  	select NET_CLS | ||||||
|  | --- a/net/sched/Makefile | ||||||
|  | +++ b/net/sched/Makefile | ||||||
|  | @@ -58,6 +58,7 @@ obj-$(CONFIG_NET_CLS_FLOW)	+= cls_flow.o | ||||||
|  |  obj-$(CONFIG_NET_CLS_CGROUP)	+= cls_cgroup.o | ||||||
|  |  obj-$(CONFIG_NET_CLS_BPF)	+= cls_bpf.o | ||||||
|  |  obj-$(CONFIG_NET_CLS_FLOWER)	+= cls_flower.o | ||||||
|  | +obj-$(CONFIG_NET_CLS_MATCHALL)	+= cls_matchall.o | ||||||
|  |  obj-$(CONFIG_NET_EMATCH)	+= ematch.o | ||||||
|  |  obj-$(CONFIG_NET_EMATCH_CMP)	+= em_cmp.o | ||||||
|  |  obj-$(CONFIG_NET_EMATCH_NBYTE)	+= em_nbyte.o | ||||||
| @@ -11,9 +11,9 @@ include $(INCLUDE_DIR)/kernel.mk | |||||||
| PKG_NAME:=qosify | PKG_NAME:=qosify | ||||||
| PKG_SOURCE_URL=$(PROJECT_GIT)/project/qosify.git | PKG_SOURCE_URL=$(PROJECT_GIT)/project/qosify.git | ||||||
| PKG_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_DATE:=2022-04-08 | PKG_SOURCE_DATE:=2022-09-26 | ||||||
| PKG_SOURCE_VERSION:=ef82defaae26619e5b2ebddfdd86e9de61c399f1 | PKG_SOURCE_VERSION:=9c625ae96f2d204f7417d6c9b7092b9e4ac653a8 | ||||||
| PKG_MIRROR_HASH:=8e4ca65d23a85aad774af51dc62cfaa4615111ffd2c7922258ac8f026a62b013 | PKG_MIRROR_HASH:=f7cd52b6749d0dc81d6d710ee5f85597a3ff084a78e2622336c16dc138fdc854 | ||||||
| PKG_RELEASE:=$(AUTORELEASE) | PKG_RELEASE:=$(AUTORELEASE) | ||||||
|  |  | ||||||
| PKG_LICENSE:=GPL-2.0 | PKG_LICENSE:=GPL-2.0 | ||||||
|   | |||||||
| @@ -3,11 +3,11 @@ | |||||||
| [ "${INTERFACE:0:4}" == "wlan" ] || exit 0 | [ "${INTERFACE:0:4}" == "wlan" ] || exit 0 | ||||||
|  |  | ||||||
| [ "$ACTION" == remove ] && { | [ "$ACTION" == remove ] && { | ||||||
| 	ratelimit deliface $INTERFACE | 	[ -f /tmp/run/hostapd-cli-$INTERFACE.pid ] && kill "$(cat /tmp/run/hostapd-cli-$INTERFACE.pid)" | ||||||
| 	exit 0 | 	exit 0 | ||||||
| } | } | ||||||
|  |  | ||||||
| [ "$ACTION" == add ] && { | [ "$ACTION" == add ] && { | ||||||
| 	ratelimit waitiface $INTERFACE & | 	/usr/libexec/ratelimit-wait.sh $INTERFACE & | ||||||
| 	exit 0 | 	exit 0 | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										37
									
								
								feeds/ucentral/ratelimit/files/etc/init.d/ratelimit
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										37
									
								
								feeds/ucentral/ratelimit/files/etc/init.d/ratelimit
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | #!/bin/sh /etc/rc.common | ||||||
|  |  | ||||||
|  | START=80 | ||||||
|  |  | ||||||
|  | USE_PROCD=1 | ||||||
|  | PROG=/usr/bin/ratelimit | ||||||
|  |  | ||||||
|  | add_rate() { | ||||||
|  | 	local cfg="$1" | ||||||
|  | 	config_get ssid "$cfg" ssid | ||||||
|  | 	config_get ingress "$cfg" ingress | ||||||
|  | 	config_get egress "$cfg" egress | ||||||
|  | 	ubus call ratelimit defaults_set '{"name": "'$ssid'", "rate_ingress": "'$ingress'mbit", "rate_egress": "'$egress'mbit" }' | ||||||
|  | } | ||||||
|  |  | ||||||
|  | reload_service() { | ||||||
|  | 	logger ratelimit reload | ||||||
|  | 	config_load ratelimit | ||||||
|  | 	config_foreach add_rate rate | ||||||
|  | } | ||||||
|  |  | ||||||
|  | service_triggers() { | ||||||
|  | 	procd_add_reload_trigger ratelimit | ||||||
|  | } | ||||||
|  |  | ||||||
|  | start_service() { | ||||||
|  | 	procd_open_instance | ||||||
|  | 	procd_set_param command "$PROG" | ||||||
|  | 	procd_set_param respawn | ||||||
|  | 	procd_close_instance | ||||||
|  | } | ||||||
|  |  | ||||||
|  | service_started() { | ||||||
|  | 	ubus -t 10 wait_for ratelimit | ||||||
|  | 	[ $? = 0 ] && reload_service | ||||||
|  | } | ||||||
|  |  | ||||||
| @@ -1,174 +1,337 @@ | |||||||
| #!/bin/sh | #!/usr/bin/env ucode | ||||||
|  | 'use strict'; | ||||||
|  |  | ||||||
| . /lib/functions.sh | import { basename, popen } from 'fs'; | ||||||
|  | import * as ubus from 'ubus'; | ||||||
|  | import * as uloop from 'uloop'; | ||||||
|  |  | ||||||
| wrapper() { | let defaults = {}; | ||||||
| 	echo calling $* | let devices = {}; | ||||||
| 	$* |  | ||||||
|  | function cmd(command, ignore_error) { | ||||||
|  | //	if (ignore_error) | ||||||
|  | //		command += "> /dev/null 2>&1"; | ||||||
|  | 	warn(`> ${command}\n`); | ||||||
|  | 	let rc = system(command); | ||||||
|  | 	return ignore_error || rc == 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| TC() { | function qdisc_add_leaf(iface, id, opts) { | ||||||
| 	wrapper tc $* | 	opts ??= ""; | ||||||
|  | 	return cmd(`tc class replace dev ${iface} parent 1:1 classid 1:${id} htb rate 1mbit ${opts} burst 2k prio 1`) && | ||||||
|  | 	       cmd(`tc qdisc replace dev ${iface} parent 1:${id} handle ${id}: fq_codel flows 128 limit 800 quantum 300 noecn`); | ||||||
| } | } | ||||||
|  |  | ||||||
| IP() { | function qdisc_del_leaf(iface, id) { | ||||||
| 	wrapper ip $* | 	cmd(`tc class del dev ${iface} parent 1:1 classid 1:${id}`, true); | ||||||
| } | } | ||||||
|  |  | ||||||
| get_id() { | function qdisc_add(iface) { | ||||||
| 	addr=$1 | 	return cmd(`tc qdisc add dev ${iface} root handle 1: htb default 2`) && | ||||||
| 	hashval="0x$(echo "$addr" | md5sum | head -c8)" | 	       cmd(`tc class add dev ${iface} parent 1: classid 1:1 htb rate 1000mbit burst 6k`) && | ||||||
| 	mask=0x4ff | 	       qdisc_add_leaf(iface, 2, "ceil 1000mbit"); | ||||||
| 	echo $(($hashval & $mask)) |  | ||||||
| } | } | ||||||
|  |  | ||||||
| delclient() { | function qdisc_del(iface) { | ||||||
| 	local ifb=rateifb$1 | 	cmd(`tc qdisc del dev ${iface} root`, true); | ||||||
| 	local iface=$1 |  | ||||||
| 	local mac=$2 |  | ||||||
| 	local id=$3 |  | ||||||
| 	 |  | ||||||
| 	logger "ratelimit: delete old client entries $1 $2" |  | ||||||
|  |  | ||||||
| 	id=$(get_id ${mac//:}) |  | ||||||
|  |  | ||||||
| 	TC filter del dev $iface protocol all parent 1: prio 1 u32 match ether dst $mac flowid 1:$id |  | ||||||
| 	 |  | ||||||
| 	TC filter del dev $ifb protocol all parent 1: prio 1 u32 match ether src $mac flowid 1:$id |  | ||||||
| } | } | ||||||
|  |  | ||||||
| ingress=0 | function ifb_dev(iface) { | ||||||
| egress=0 | 	return "ifb-" + iface; | ||||||
|  |  | ||||||
| getrate() { |  | ||||||
| 	config_get ssid $1 ssid |  | ||||||
| 	[ "$ssid" == "$2" ] || return |  | ||||||
| 	config_get ingress $1 ingress |  | ||||||
| 	config_get egress $1 egress |  | ||||||
| } | } | ||||||
|  |  | ||||||
| addclient() { | function ifb_add(iface, ifbdev) { | ||||||
| 	local ifb=rateifb$1 | 	return cmd(`ip link add ${ifbdev} type ifb`) && | ||||||
| 	local iface=$1 | 	       cmd(`ip link set ${ifbdev} up`) && | ||||||
| 	local mac=$2 | 	       cmd(`tc qdisc add dev ${iface} clsact`, true) && | ||||||
| 	local ssid=$(cat /tmp/ratelimit.$iface) | 	       cmd(`tc filter add dev ${iface} ingress protocol all prio 512 matchall action mirred egress redirect dev ${ifbdev}`); | ||||||
|  | } | ||||||
|  |  | ||||||
| 	egress=$3 | function ifb_del(iface, ifbdev) { | ||||||
| 	ingress=$4 | 	cmd(`tc filter del dev ${iface} ingress protocol all prio 512`); | ||||||
|  | 	cmd(`ip link set ${ifbdev} down`, true); | ||||||
|  | 	cmd(`ip link del ${ifbdev}`, true); | ||||||
|  | } | ||||||
|  |  | ||||||
| 	logger "ratelimit: adding client" | function macfilter_add(iface, id, type, mac) { | ||||||
|  | 	return cmd(`tc filter add dev ${iface} protocol all parent 1: prio 1 handle 800::${id} u32 match ether ${type} ${mac} flowid 1:${id}`); | ||||||
|  | } | ||||||
|  |  | ||||||
| 	[ "$egress" -eq 0 -o $ingress -eq 0 ] && { | function macfilter_del(iface, id) { | ||||||
| 		config_load ratelimit | 	cmd(`tc filter del dev ${iface} protocol all parent 1: prio 1 handle 800::${id} u32`, true); | ||||||
| 		config_foreach getrate rate $ssid | } | ||||||
|  |  | ||||||
|  | function linux_client_del(device, client) { | ||||||
|  | 	let ifbdev = ifb_dev(device.name); | ||||||
|  | 	let id = client.id + 3; | ||||||
|  |  | ||||||
|  | 	macfilter_del(device.name, id); | ||||||
|  | 	qdisc_del_leaf(device.name, id); | ||||||
|  | 	macfilter_del(ifbdev, id); | ||||||
|  | 	qdisc_del_leaf(ifbdev, id); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function linux_client_set(device, client) { | ||||||
|  | 	let ifbdev = ifb_dev(device.name); | ||||||
|  | 	let id = client.id + 3; | ||||||
|  |  | ||||||
|  | 	linux_client_del(device, client); | ||||||
|  |  | ||||||
|  | 	let ret = qdisc_add_leaf(device.name, id, `ceil ${client.data.rate_egress}`) && | ||||||
|  | 		  macfilter_add(device.name, id, "dst", client.address) && | ||||||
|  | 		  qdisc_add_leaf(ifbdev, id, `ceil ${client.data.rate_ingress}`) && | ||||||
|  | 		  macfilter_add(ifbdev, id, "src", client.address); | ||||||
|  |  | ||||||
|  | 	if (!ret) | ||||||
|  | 		linux_client_del(device, client); | ||||||
|  |  | ||||||
|  | 	return ret; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | let ops = { | ||||||
|  | 	device: { | ||||||
|  | 		add: function(name) { | ||||||
|  | 			let ifbdev = ifb_dev(name); | ||||||
|  |  | ||||||
|  | 			qdisc_del(name); | ||||||
|  | 			ifb_del(name, ifbdev); | ||||||
|  |  | ||||||
|  | 			let ret = qdisc_add(name) && | ||||||
|  | 				  ifb_add(name, ifbdev) && | ||||||
|  | 				  qdisc_add(ifbdev); | ||||||
|  |  | ||||||
|  | 			if (!ret) { | ||||||
|  | 				qdisc_del(name); | ||||||
|  | 				ifb_del(name, ifbdev); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			return ret; | ||||||
|  | 		}, | ||||||
|  | 		remove: function(name) { | ||||||
|  | 			let ifbdev = ifb_dev(name); | ||||||
|  | 			qdisc_del(name); | ||||||
|  | 			ifb_del(name, ifbdev); | ||||||
|  | 		} | ||||||
|  | 	}, | ||||||
|  | 	client: { | ||||||
|  | 		set: function(device, client) { | ||||||
|  | 			return linux_client_set(device, client); | ||||||
|  | 		}, | ||||||
|  | 		remove: function(device, client) { | ||||||
|  | 			linux_client_del(device, client); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | function get_device(devices, name) { | ||||||
|  | 	let device = devices[name]; | ||||||
|  |  | ||||||
|  | 	if (device) | ||||||
|  | 		return device; | ||||||
|  |  | ||||||
|  | 	if (!ops.device.add(name)) | ||||||
|  | 		return null; | ||||||
|  |  | ||||||
|  | 	device = { | ||||||
|  | 		name: name, | ||||||
|  | 		clients: {}, | ||||||
|  | 		client_order: [], | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	devices[name] = device; | ||||||
|  |  | ||||||
|  | 	return device; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function del_device(name) { | ||||||
|  | 	if (!devices[name]) | ||||||
|  | 		return; | ||||||
|  | 	ops.device.remove(name); | ||||||
|  | 	delete devices[name]; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function get_free_idx(list) { | ||||||
|  | 	for (let i = 0; i < length(list); i++) | ||||||
|  | 		if (list[i] == null) | ||||||
|  | 			return i; | ||||||
|  |  | ||||||
|  | 	return length(list); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function del_client(device, address) { | ||||||
|  | 	let client = device.clients[address]; | ||||||
|  |  | ||||||
|  | 	if (!client) | ||||||
|  | 		return false; | ||||||
|  |  | ||||||
|  | 	delete device.clients[address]; | ||||||
|  | 	device.client_order[client.id] = null; | ||||||
|  |  | ||||||
|  | 	ops.client.remove(device, client); | ||||||
|  | 	return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function get_client(device, address) { | ||||||
|  | 	let client = device.clients[address]; | ||||||
|  |  | ||||||
|  | 	if (client) | ||||||
|  | 		return client; | ||||||
|  |  | ||||||
|  | 	let i = get_free_idx(device.client_order); | ||||||
|  | 	client = {}; | ||||||
|  | 	client.address = address; | ||||||
|  | 	client.id = i; | ||||||
|  | 	client.data = {}; | ||||||
|  |  | ||||||
|  | 	device.clients[address] = client; | ||||||
|  | 	device.client_order[i] = client; | ||||||
|  |  | ||||||
|  | 	return client; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function set_client(device, client, data) { | ||||||
|  | 	let update = false; | ||||||
|  |  | ||||||
|  | 	for (let key in data) { | ||||||
|  | 		if (client.data[key] != data[key]) | ||||||
|  | 			update = true; | ||||||
|  |  | ||||||
|  | 		client.data[key] = data[key]; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	[ "$egress" -eq 0 -o $ingress -eq 0 ] && { | 	if (update && !ops.client.set(device, client)) { | ||||||
| 		logger "ratelimit: no valid rates" | 		del_client(device, client.address); | ||||||
| 		exit 1 | 		return false; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	local id=$(get_id ${mac//:}) | 	return true; | ||||||
|  |  | ||||||
| 	logger "ratelimit: add new client entries for $1 $2 $egress $ingress" |  | ||||||
|  |  | ||||||
| 	TC class add dev $iface parent 1:1 classid 1:$id htb rate 1mbit ceil ${egress}mbit burst 2k prio 1 |  | ||||||
| 	TC qdisc add dev $iface parent 1:$id handle $id: sfq perturb 10 |  | ||||||
| 	TC filter add dev $iface protocol all parent 1: prio 1 u32 match ether dst $mac flowid 1:$id |  | ||||||
| 	 |  | ||||||
| 	TC class add dev $ifb parent 1:1 classid 1:$id htb rate 1mbit ceil ${ingress}mbit burst 2k prio 1 |  | ||||||
| 	TC filter add dev $ifb protocol all parent 1: prio 1 u32 match ether src $mac flowid 1:$id |  | ||||||
| } | } | ||||||
|  |  | ||||||
| deliface() { | function run_service() { | ||||||
| 	local ifb=rateifb$1 | 	let uctx = ubus.connect(); | ||||||
| 	local iface=$1 |  | ||||||
|  |  | ||||||
| 	[ -d /sys/class/net/$ifb/ ] || return 0 | 	uctx.publish("ratelimit", { | ||||||
|  | 		defaults_set: { | ||||||
|  | 			call: function(req) { | ||||||
|  | 				let r_i = req.args.rate_ingress ?? req.args.rate; | ||||||
|  | 				let r_e = req.args.rate_egress ?? req.args.rate; | ||||||
|  | 				let name = req.args.name; | ||||||
|  |  | ||||||
| 	logger "ratelimit: deleting old iface settings" | 				if (!name || !r_i || !r_e) | ||||||
|  | 					return ubus.STATUS_INVALID_ARGUMENT; | ||||||
|  |  | ||||||
| 	IP link set $ifb down | 				defaults[name] = [ r_e, r_i ]; | ||||||
| 	IP link del $ifb |  | ||||||
|  |  | ||||||
| 	TC qdisc del dev $iface root &2> /dev/null | 				return 0; | ||||||
|  | 			}, | ||||||
|  | 			args: { | ||||||
|  | 				name:"", | ||||||
|  | 				rate:"", | ||||||
|  | 				rate_ingress:"", | ||||||
|  | 				rate_egress:"", | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		client_set: { | ||||||
|  | 			call: function(req) { | ||||||
|  | 				let r_i = req.args.rate_ingress ?? req.args.rate; | ||||||
|  | 				let r_e = req.args.rate_egress ?? req.args.rate; | ||||||
|  |  | ||||||
| 	rm -f /tmp/ratelimit.$iface | 				if (req.args.defaults && defaults[req.args.defaults]) { | ||||||
| 	[ -f /tmp/run/hostapd-cli-$iface.pid ] && kill "$(cat /tmp/run/hostapd-cli-$iface.pid)" | 					let def = defaults[req.args.defaults]; | ||||||
| } |  | ||||||
|  |  | ||||||
| found=0 | 					r_e ??= def[0]; | ||||||
| find_ssid() { | 					r_i ??= def[1]; | ||||||
| 	local ssid | 				} | ||||||
| 	config_get ssid $1 ssid |  | ||||||
| 	[ "$ssid" == "$2" ] || return |  | ||||||
| 	found=1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| addiface() { | 				if (!req.args.device || !req.args.address || !r_i || !r_e) | ||||||
| 	local ifb=rateifb$1 | 					return ubus.STATUS_INVALID_ARGUMENT; | ||||||
| 	local iface=$1 |  | ||||||
| 	local ssid |  | ||||||
|  |  | ||||||
|  | 				let device = get_device(devices, req.args.device); | ||||||
|  | 				if (!device) | ||||||
|  | 					return ubus.STATUS_INVALID_ARGUMENT; | ||||||
|  |  | ||||||
| 	[ -f /tmp/ratelimit.$iface -o -d /sys/class/net/$ifb/ ] && { | 				let client = get_client(device, req.args.address); | ||||||
| 		return 0 | 				if (!client) | ||||||
|  | 					return ubus.STATUS_INVALID_ARGUMENT; | ||||||
|  |  | ||||||
|  | 				let data = { | ||||||
|  | 					rate_ingress: r_i, | ||||||
|  | 					rate_egress: r_e | ||||||
|  | 				}; | ||||||
|  |  | ||||||
|  | 				if (!set_client(device, client, data)) | ||||||
|  | 					return ubus.STATUS_UNKNOWN_ERROR; | ||||||
|  |  | ||||||
|  | 				return 0; | ||||||
|  | 			}, | ||||||
|  | 			args: { | ||||||
|  | 				device:"", | ||||||
|  | 				defaults:"", | ||||||
|  | 				address:"", | ||||||
|  | 				rate:"", | ||||||
|  | 				rate_ingress:"", | ||||||
|  | 				rate_egress:"", | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		client_delete: { | ||||||
|  | 			call: function(req) { | ||||||
|  | 				if (!req.args.address) | ||||||
|  | 					return ubus.STATUS_INVALID_ARGUMENT; | ||||||
|  |  | ||||||
|  | 				if (req.args.device) { | ||||||
|  | 					let device = devices[req.args.device]; | ||||||
|  | 					if (!device) | ||||||
|  | 						return ubus.STATUS_NOT_FOUND; | ||||||
|  |  | ||||||
|  | 					if (!del_client(device, req.args.address)) | ||||||
|  | 						return ubus.STATUS_NOT_FOUND; | ||||||
|  | 				} else { | ||||||
|  | 					for (let dev in devices) { | ||||||
|  | 						let device = devices[dev]; | ||||||
|  |  | ||||||
|  | 						del_client(device, req.args.address); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  |  | ||||||
|  | 				return 0; | ||||||
|  | 			}, | ||||||
|  | 			args: { | ||||||
|  | 				device:"", | ||||||
|  | 				address:"", | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		device_delete: { | ||||||
|  | 			call: function(req) { | ||||||
|  | 				let name = req.args.device; | ||||||
|  |  | ||||||
|  | 				if (!name) | ||||||
|  | 					return ubus.STATUS_INVALID_ARGUMENT; | ||||||
|  |  | ||||||
|  | 				if (!devices[name]) | ||||||
|  | 					return ubus.STATUS_NOT_FOUND; | ||||||
|  |  | ||||||
|  | 				del_device(name); | ||||||
|  |  | ||||||
|  | 				return 0; | ||||||
|  | 			}, | ||||||
|  | 			args: { | ||||||
|  | 				device:"", | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}); | ||||||
|  |  | ||||||
|  | 	try { | ||||||
|  | 		uloop.run(); | ||||||
|  | 	} catch (e) { | ||||||
|  | 		warn(`Error: ${e}\n${e.stacktrace[0].context}`); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	echo -n startup > /tmp/ratelimit.$iface | 	for (let dev in devices) { | ||||||
|  | 		del_device(dev); | ||||||
| 	sleep 2 |  | ||||||
| 	ssid=$(ubus call hostapd.$iface get_status | jsonfilter -e '@.ssid') |  | ||||||
| 	[ -z "$ssid" ] && { |  | ||||||
| 		rm /tmp/ratelimit.$iface |  | ||||||
| 		logger "ratelimit: failed to lookup ssid" |  | ||||||
| 		exit 1 |  | ||||||
| 	} | 	} | ||||||
| 	config_load ratelimit |  | ||||||
| 	config_foreach find_ssid rate $ssid |  | ||||||
| 	[ "$found" -eq 0 ] && { |  | ||||||
| 		rm /tmp/ratelimit.$iface |  | ||||||
| 		exit 0 |  | ||||||
| 	} |  | ||||||
| 	logger "ratelimit: adding new iface settings" |  | ||||||
|  |  | ||||||
| 	echo -n $ssid > /tmp/ratelimit.$iface |  | ||||||
|  |  | ||||||
| 	IP link add name $ifb type ifb |  | ||||||
| 	IP link set $ifb up |  | ||||||
|  |  | ||||||
| 	sleep 1 |  | ||||||
|  |  | ||||||
| 	TC qdisc add dev $iface root handle 1: htb default 30 |  | ||||||
| 	TC class add dev $iface parent 1: classid 1:1 htb rate 1000mbit burst 6k |  | ||||||
| 	TC qdisc add dev $iface ingress |  | ||||||
| 	TC filter add dev $iface parent ffff: protocol all prio 10 u32 match u32 0 0 flowid 1:1 action mirred egress redirect dev $ifb |  | ||||||
|  |  | ||||||
| 	TC qdisc add dev $ifb root handle 1: htb default 10 |  | ||||||
| 	TC class add dev $ifb parent 1: classid 1:1 htb rate 100mbit |  | ||||||
| 	hostapd_cli -a /usr/libexec/ratelimit.sh -i $iface -P /tmp/run/hostapd-cli-$iface.pid -B |  | ||||||
|         |  | ||||||
| 	for sta in $(ubus call wifi station | jsonfilter -e '@[*][*].mac'); do |  | ||||||
| 		addclient $iface $sta |  | ||||||
| 	done |  | ||||||
| } | } | ||||||
|  |  | ||||||
| waitiface() { | uloop.init(); | ||||||
| 	local iface=$1 | run_service(); | ||||||
|  | uloop.done(); | ||||||
| 	ubus -t 120 wait_for hostapd.$1 |  | ||||||
|  |  | ||||||
| 	[ $? -eq 0 ] || exit 0 |  | ||||||
|  |  | ||||||
| 	addiface $iface |  | ||||||
| } |  | ||||||
|  |  | ||||||
| flush() { |  | ||||||
| 	for a in `ls /sys/class/net/ | grep rateifb`; do |  | ||||||
| 		deliface ${a:7} |  | ||||||
| 	done |  | ||||||
| } |  | ||||||
|  |  | ||||||
| cmd=$1 |  | ||||||
| shift |  | ||||||
| $cmd $@ |  | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								feeds/ucentral/ratelimit/files/usr/libexec/ratelimit-wait.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										4
									
								
								feeds/ucentral/ratelimit/files/usr/libexec/ratelimit-wait.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | [ -f /tmp/run/hostapd-cli-$1.pid ] && kill "$(cat /tmp/run/hostapd-cli-$1.pid)" | ||||||
|  | ubus -t 120 wait_for hostapd.$1 | ||||||
|  | [ $? = 0 ] && hostapd_cli -a /usr/libexec/ratelimit.sh -i $1 -P /tmp/run/hostapd-cli-$1.pid -B | ||||||
| @@ -2,9 +2,16 @@ | |||||||
|  |  | ||||||
| case $2 in | case $2 in | ||||||
| AP-STA-CONNECTED) | AP-STA-CONNECTED) | ||||||
| 	ratelimit addclient $1 $3 $4 $5 | 	[ $4 = 0 -o $5 = 0 ] && { | ||||||
|  | 		ubus call ratelimit client_set '{"device": "'$1'", "address": "'$3'", "defaults": "'$(ubus call wifi iface | jsonfilter -e "@.$1.ssid")'" }' | ||||||
|  | 		logger ratelimit addclient $1 $3 $ssid | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 	ubus call ratelimit client_set '{"device": "'$1'", "address": "'$3'", "rate_ingress": "'$4'mbit", "rate_egress": "'$5'mbit" }' | ||||||
|  | 	logger ratelimit addclient $1 $3 $4 $5 | ||||||
| 	;; | 	;; | ||||||
| AP-STA-DISCONNECTED) | AP-STA-DISCONNECTED) | ||||||
| 	ratelimit delclient $1 $3 | 	ubus call ratelimit client_delete '{ "address": "'$3'" }' | ||||||
|  | 	logger ratelimit delclient $3 | ||||||
| 	;; | 	;; | ||||||
| esac | esac | ||||||
|   | |||||||
| @@ -65,6 +65,7 @@ static void __client_free(struct interface *iface, struct client *cl) | |||||||
| 		avl_delete(&iface->client_ids, &cl->id_node); | 		avl_delete(&iface->client_ids, &cl->id_node); | ||||||
| 	avl_delete(&iface->clients, &cl->node); | 	avl_delete(&iface->clients, &cl->node); | ||||||
| 	kvlist_free(&cl->kvdata); | 	kvlist_free(&cl->kvdata); | ||||||
|  | 	free(cl->device); | ||||||
| 	spotfilter_bpf_set_client(iface, &cl->key, NULL); | 	spotfilter_bpf_set_client(iface, &cl->key, NULL); | ||||||
| 	free(cl); | 	free(cl); | ||||||
| } | } | ||||||
| @@ -97,7 +98,8 @@ static void client_set_id(struct interface *iface, struct client *cl, const char | |||||||
| } | } | ||||||
|  |  | ||||||
| int client_set(struct interface *iface, const void *addr, const char *id, | int client_set(struct interface *iface, const void *addr, const char *id, | ||||||
| 	       int state, int dns_state, int accounting, struct blob_attr *data) | 	       int state, int dns_state, int accounting, struct blob_attr *data, | ||||||
|  | 	       const char *device, bool flush) | ||||||
| { | { | ||||||
| 	struct cache_entry *c; | 	struct cache_entry *c; | ||||||
| 	struct blob_attr *cur; | 	struct blob_attr *cur; | ||||||
| @@ -142,12 +144,23 @@ int client_set(struct interface *iface, const void *addr, const char *id, | |||||||
|  |  | ||||||
| 		kvlist_set(&cl->kvdata, blobmsg_name(cur), cur); | 		kvlist_set(&cl->kvdata, blobmsg_name(cur), cur); | ||||||
| 	} | 	} | ||||||
|  | 	if (device) { | ||||||
|  | 		free(cl->device); | ||||||
|  | 		cl->device = strdup(device); | ||||||
|  | 	} | ||||||
| 	if (state >= 0) | 	if (state >= 0) | ||||||
| 		cl->data.cur_class = state; | 		cl->data.cur_class = state; | ||||||
| 	if (dns_state >= 0) | 	if (dns_state >= 0) | ||||||
| 		cl->data.dns_class = dns_state; | 		cl->data.dns_class = dns_state; | ||||||
| 	if (accounting >= 0) | 	if (accounting >= 0) | ||||||
| 		cl->data.flags = accounting; | 		cl->data.flags = accounting; | ||||||
|  | 	if (flush) { | ||||||
|  | 		kvlist_free(&cl->kvdata); | ||||||
|  | 		cl->data.packets_ul = 0; | ||||||
|  | 		cl->data.packets_dl = 0; | ||||||
|  | 		cl->data.bytes_ul = 0; | ||||||
|  | 		cl->data.bytes_dl = 0; | ||||||
|  | 	} | ||||||
| 	spotfilter_bpf_set_client(iface, &cl->key, &cl->data); | 	spotfilter_bpf_set_client(iface, &cl->key, &cl->data); | ||||||
|  |  | ||||||
| 	if (new_client) | 	if (new_client) | ||||||
|   | |||||||
| @@ -17,10 +17,12 @@ struct client { | |||||||
|  |  | ||||||
| 	struct spotfilter_client_key key; | 	struct spotfilter_client_key key; | ||||||
| 	struct spotfilter_client_data data; | 	struct spotfilter_client_data data; | ||||||
|  | 	char *device; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| int client_set(struct interface *iface, const void *addr, const char *id, | int client_set(struct interface *iface, const void *addr, const char *id, | ||||||
| 	       int state, int dns_state, int accounting, struct blob_attr *data); | 	       int state, int dns_state, int accounting, struct blob_attr *data, | ||||||
|  | 	       const char *device, bool flush); | ||||||
| void client_free(struct interface *iface, struct client *cl); | void client_free(struct interface *iface, struct client *cl); | ||||||
| void client_set_ipaddr(const void *mac, const void *addr, bool ipv6); | void client_set_ipaddr(const void *mac, const void *addr, bool ipv6); | ||||||
| void client_init_interface(struct interface *iface); | void client_init_interface(struct interface *iface); | ||||||
|   | |||||||
| @@ -32,12 +32,6 @@ void interface_free(struct interface *iface) | |||||||
| 	free(iface); | 	free(iface); | ||||||
| } | } | ||||||
|  |  | ||||||
| static inline const char * |  | ||||||
| device_name(struct device *dev) |  | ||||||
| { |  | ||||||
| 	return dev->node.avl.key; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static void | static void | ||||||
| interface_check_device(struct interface *iface, struct device *dev) | interface_check_device(struct interface *iface, struct device *dev) | ||||||
| { | { | ||||||
|   | |||||||
| @@ -64,6 +64,11 @@ static inline const char *interface_name(struct interface *iface) | |||||||
| 	return iface->node.key; | 	return iface->node.key; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static inline const char *device_name(struct device *dev) | ||||||
|  | { | ||||||
|  | 	return dev->node.avl.key; | ||||||
|  | } | ||||||
|  |  | ||||||
| void interface_add(const char *name, struct blob_attr *config, | void interface_add(const char *name, struct blob_attr *config, | ||||||
| 		   struct blob_attr *devices); | 		   struct blob_attr *devices); | ||||||
| void interface_free(struct interface *iface); | void interface_free(struct interface *iface); | ||||||
|   | |||||||
| @@ -147,6 +147,7 @@ nl80211_device_update(struct interface *iface, struct device *dev) | |||||||
|  |  | ||||||
| 	nl_send_auto_complete(genl, msg); | 	nl_send_auto_complete(genl, msg); | ||||||
| 	nlmsg_free(msg); | 	nlmsg_free(msg); | ||||||
|  | 	nl_wait_for_ack(genl); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void | static void | ||||||
| @@ -155,14 +156,12 @@ nl80211_interface_update(struct interface *iface) | |||||||
| 	struct client *cl, *tmp; | 	struct client *cl, *tmp; | ||||||
| 	struct device *dev; | 	struct device *dev; | ||||||
|  |  | ||||||
| 	if (!iface->client_autoremove) |  | ||||||
| 		return; |  | ||||||
|  |  | ||||||
| 	avl_for_each_element_safe(&iface->clients, cl, node, tmp) { | 	avl_for_each_element_safe(&iface->clients, cl, node, tmp) { | ||||||
| 		if (cl->idle++ < iface->client_timeout) | 		if (cl->idle++ < iface->client_timeout) | ||||||
| 			continue; | 			continue; | ||||||
|  |  | ||||||
| 		client_free(iface, cl); | 		if (iface->client_autoremove) | ||||||
|  | 			client_free(iface, cl); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	vlist_for_each_element(&iface->devices, dev, node) | 	vlist_for_each_element(&iface->devices, dev, node) | ||||||
| @@ -218,7 +217,7 @@ found: | |||||||
| 	if (cl) | 	if (cl) | ||||||
| 		cl->idle = 0; | 		cl->idle = 0; | ||||||
| 	else if (iface->client_autocreate) | 	else if (iface->client_autocreate) | ||||||
| 		client_set(iface, addr, NULL, -1, -1, -1, NULL); | 		client_set(iface, addr, NULL, -1, -1, -1, NULL, device_name(dev), false); | ||||||
|  |  | ||||||
| 	return NL_SKIP; | 	return NL_SKIP; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -158,9 +158,9 @@ int spotfilter_out(struct __sk_buff *skb) | |||||||
| 		return TC_ACT_UNSPEC; | 		return TC_ACT_UNSPEC; | ||||||
|  |  | ||||||
| 	cl = bpf_map_lookup_elem(&client, eth->h_dest); | 	cl = bpf_map_lookup_elem(&client, eth->h_dest); | ||||||
| 	if (cl) { | 	if (cl && (cl->flags & SPOTFILTER_CLIENT_F_ACCT_DL)) { | ||||||
| 		if (cl->flags & SPOTFILTER_CLIENT_F_ACCT_DL) | 		cl->packets_dl++; | ||||||
| 			cl->bytes_dl += skb->len; | 		cl->bytes_dl += skb->len; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	skb_parse_vlan(&info); | 	skb_parse_vlan(&info); | ||||||
| @@ -204,8 +204,10 @@ int spotfilter_in(struct __sk_buff *skb) | |||||||
| 	cl = bpf_map_lookup_elem(&client, eth->h_source); | 	cl = bpf_map_lookup_elem(&client, eth->h_source); | ||||||
| 	if (cl) { | 	if (cl) { | ||||||
| 		cldata = *cl; | 		cldata = *cl; | ||||||
| 		if (cl->flags & SPOTFILTER_CLIENT_F_ACCT_UL) | 		if (cl->flags & SPOTFILTER_CLIENT_F_ACCT_UL) { | ||||||
|  | 			cl->packets_ul++; | ||||||
| 			cl->bytes_ul += skb->len; | 			cl->bytes_ul += skb->len; | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	has_vlan = !!skb_parse_vlan(&info); | 	has_vlan = !!skb_parse_vlan(&info); | ||||||
|   | |||||||
| @@ -19,6 +19,8 @@ struct spotfilter_client_data { | |||||||
| 	uint8_t dns_class; | 	uint8_t dns_class; | ||||||
| 	uint8_t flags; | 	uint8_t flags; | ||||||
|  |  | ||||||
|  | 	uint64_t packets_ul; | ||||||
|  | 	uint64_t packets_dl; | ||||||
| 	uint64_t bytes_ul; | 	uint64_t bytes_ul; | ||||||
| 	uint64_t bytes_dl; | 	uint64_t bytes_dl; | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -88,6 +88,7 @@ enum { | |||||||
| 	CLIENT_ATTR_DNS_STATE, | 	CLIENT_ATTR_DNS_STATE, | ||||||
| 	CLIENT_ATTR_ACCOUNTING, | 	CLIENT_ATTR_ACCOUNTING, | ||||||
| 	CLIENT_ATTR_DATA, | 	CLIENT_ATTR_DATA, | ||||||
|  | 	CLIENT_ATTR_FLUSH, | ||||||
| 	__CLIENT_ATTR_MAX | 	__CLIENT_ATTR_MAX | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -99,6 +100,7 @@ static const struct blobmsg_policy client_policy[__CLIENT_ATTR_MAX] = { | |||||||
| 	[CLIENT_ATTR_DNS_STATE] = { "dns_state", BLOBMSG_TYPE_INT32 }, | 	[CLIENT_ATTR_DNS_STATE] = { "dns_state", BLOBMSG_TYPE_INT32 }, | ||||||
| 	[CLIENT_ATTR_ACCOUNTING] = { "accounting", BLOBMSG_TYPE_ARRAY }, | 	[CLIENT_ATTR_ACCOUNTING] = { "accounting", BLOBMSG_TYPE_ARRAY }, | ||||||
| 	[CLIENT_ATTR_DATA] = { "data", BLOBMSG_TYPE_TABLE }, | 	[CLIENT_ATTR_DATA] = { "data", BLOBMSG_TYPE_TABLE }, | ||||||
|  | 	[CLIENT_ATTR_FLUSH] = { "flush", BLOBMSG_TYPE_BOOL }, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static int | static int | ||||||
| @@ -176,6 +178,7 @@ client_ubus_update(struct ubus_context *ctx, struct ubus_object *obj, | |||||||
| 	const char *id = NULL; | 	const char *id = NULL; | ||||||
| 	int state = -1, dns_state = -1; | 	int state = -1, dns_state = -1; | ||||||
| 	int accounting = -1; | 	int accounting = -1; | ||||||
|  | 	bool flush = false; | ||||||
| 	int ret; | 	int ret; | ||||||
|  |  | ||||||
| 	ret = client_ubus_init(msg, tb, &iface, &addr, &id, &cl); | 	ret = client_ubus_init(msg, tb, &iface, &addr, &id, &cl); | ||||||
| @@ -203,8 +206,11 @@ client_ubus_update(struct ubus_context *ctx, struct ubus_object *obj, | |||||||
| 	if (!addr) | 	if (!addr) | ||||||
| 		return UBUS_STATUS_INVALID_ARGUMENT; | 		return UBUS_STATUS_INVALID_ARGUMENT; | ||||||
|  |  | ||||||
|  | 	if (tb[CLIENT_ATTR_FLUSH]) | ||||||
|  | 		flush = blobmsg_get_bool(tb[CLIENT_ATTR_FLUSH]); | ||||||
|  |  | ||||||
| 	client_set(iface, addr, id, state, dns_state, accounting, | 	client_set(iface, addr, id, state, dns_state, accounting, | ||||||
| 		   tb[CLIENT_ATTR_DATA]); | 		   tb[CLIENT_ATTR_DATA], NULL, flush); | ||||||
|  |  | ||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| @@ -241,8 +247,10 @@ static void client_dump(struct interface *iface, struct client *cl) | |||||||
|  |  | ||||||
| 	spotfilter_bpf_get_client(iface, &cl->key, &cl->data); | 	spotfilter_bpf_get_client(iface, &cl->key, &cl->data); | ||||||
|  |  | ||||||
| 	if (iface->client_autoremove) | 	if (cl->device) | ||||||
| 		blobmsg_add_u32(&b, "idle", cl->idle); | 		blobmsg_add_string(&b, "device", cl->device); | ||||||
|  |  | ||||||
|  | 	blobmsg_add_u32(&b, "idle", cl->idle); | ||||||
|  |  | ||||||
| 	blobmsg_add_u32(&b, "state", cl->data.cur_class); | 	blobmsg_add_u32(&b, "state", cl->data.cur_class); | ||||||
| 	blobmsg_add_u32(&b, "dns_state", cl->data.dns_class); | 	blobmsg_add_u32(&b, "dns_state", cl->data.dns_class); | ||||||
| @@ -281,6 +289,8 @@ static void client_dump(struct interface *iface, struct client *cl) | |||||||
| 	interface_dump_action(&b, iface, cl->data.dns_class); | 	interface_dump_action(&b, iface, cl->data.dns_class); | ||||||
| 	blobmsg_close_table(&b, c); | 	blobmsg_close_table(&b, c); | ||||||
|  |  | ||||||
|  | 	blobmsg_add_u64(&b, "packets_ul", cl->data.packets_ul); | ||||||
|  | 	blobmsg_add_u64(&b, "packets_dl", cl->data.packets_dl); | ||||||
| 	blobmsg_add_u64(&b, "bytes_ul", cl->data.bytes_ul); | 	blobmsg_add_u64(&b, "bytes_ul", cl->data.bytes_ul); | ||||||
| 	blobmsg_add_u64(&b, "bytes_dl", cl->data.bytes_dl); | 	blobmsg_add_u64(&b, "bytes_dl", cl->data.bytes_dl); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -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:=cc453333a37f79a42d036187f8c23dc977ff2467dd7b7ae24d025b560076288c | PKG_MIRROR_HASH:=c2f41ed2506e3cc1a31c9180d567e68a39c30cae0c4421ca1dc8b58e82ab3ed1 | ||||||
| PKG_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_DATE:=2022-06-22 | PKG_SOURCE_DATE:=2022-06-22 | ||||||
| PKG_SOURCE_VERSION:=90d276feb03bcda38c48f114021b78e7d62b7a6f | PKG_SOURCE_VERSION:=154e31dfffba8733895ed2cf87433809b0d19b03 | ||||||
|  |  | ||||||
| PKG_LICENSE:=BSD-3-Clause | PKG_LICENSE:=BSD-3-Clause | ||||||
| PKG_MAINTAINER:=John Crispin <john@phrozen.org> | PKG_MAINTAINER:=John Crispin <john@phrozen.org> | ||||||
|   | |||||||
| @@ -4,10 +4,10 @@ PKG_NAME:=ucentral-schema | |||||||
| PKG_RELEASE:=1 | PKG_RELEASE:=1 | ||||||
|  |  | ||||||
| PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-schema.git | PKG_SOURCE_URL=https://github.com/Telecominfraproject/wlan-ucentral-schema.git | ||||||
| PKG_MIRROR_HASH:=16cac9b483aa0ab14b2f1d5ab450307b8357baf351c18695046078c9f52661bf | PKG_MIRROR_HASH:=ebad6fff601a64d3d87778a7413cdd308ed5d4a5187a7ed81070c7899d1b7013 | ||||||
| PKG_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_DATE:=2022-05-29 | PKG_SOURCE_DATE:=2022-05-29 | ||||||
| PKG_SOURCE_VERSION:=b27df6432c75b05f1721a8afde36f3181362e55b | PKG_SOURCE_VERSION:=329dffaf4327bea8ffaa5b59d7bda918e5786150 | ||||||
|  |  | ||||||
| PKG_MAINTAINER:=John Crispin <john@phrozen.org> | PKG_MAINTAINER:=John Crispin <john@phrozen.org> | ||||||
| PKG_LICENSE:=BSD-3-Clause | PKG_LICENSE:=BSD-3-Clause | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								feeds/ucentral/ucentral-schema/files/etc/board.d/04-regdm
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										22
									
								
								feeds/ucentral/ucentral-schema/files/etc/board.d/04-regdm
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | . /lib/functions/uci-defaults.sh | ||||||
|  |  | ||||||
|  | board_config_update | ||||||
|  |  | ||||||
|  | board=$(board_name) | ||||||
|  |  | ||||||
|  | case "$board" in | ||||||
|  | cig,wf188n|\ | ||||||
|  | cig,wf194c4|\ | ||||||
|  | cig,wf194c|\ | ||||||
|  | cig,wf610d|\ | ||||||
|  | cig,wf808|\ | ||||||
|  | cig,wf196) | ||||||
|  | 	ucidef_set_wifi_country 'US' | ||||||
|  | 	;; | ||||||
|  | esac | ||||||
|  |  | ||||||
|  | board_config_flush | ||||||
|  |  | ||||||
|  | exit 0 | ||||||
| @@ -12,9 +12,10 @@ PKG_RELEASE:=1 | |||||||
|  |  | ||||||
| PKG_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_URL=https://github.com/jow-/ucode.git | PKG_SOURCE_URL=https://github.com/jow-/ucode.git | ||||||
| PKG_MIRROR_HASH:=98303ef9d5fa7eca04042792abaf8a2e66082237a23a89a7f5e72e4409714a72 | PKG_MIRROR_HASH:=413a08ee63c30c44d6f0a5de14b1c84787f9bd1fe8b125c8e4956aa2884cc933 | ||||||
|  | #PKG_MIRROR_HASH:=98303ef9d5fa7eca04042792abaf8a2e66082237a23a89a7f5e72e4409714a72 | ||||||
| PKG_SOURCE_DATE:=2022-04-07 | PKG_SOURCE_DATE:=2022-04-07 | ||||||
| PKG_SOURCE_VERSION:=456d3f1811aaf864ac0071232e6783ae1779c32a | PKG_SOURCE_VERSION:=7fa59ce44b9347528b0e4e44ebcfb04a08479f3f | ||||||
| PKG_MAINTAINER:=Jo-Philipp Wich <jo@mein.io> | PKG_MAINTAINER:=Jo-Philipp Wich <jo@mein.io> | ||||||
| PKG_LICENSE:=ISC | PKG_LICENSE:=ISC | ||||||
|  |  | ||||||
|   | |||||||
| @@ -100,15 +100,3 @@ Index: ucode-2022-04-07-33f1e0b0/lib/nl80211.c | |||||||
|  static const uc_nl_nested_spec_t nl80211_sta_info_nla = { |  static const uc_nl_nested_spec_t nl80211_sta_info_nla = { | ||||||
|  	.headsize = 0, |  	.headsize = 0, | ||||||
|  	.nattrs = 35, |  	.nattrs = 35, | ||||||
| Index: ucode-2022-04-07-33f1e0b0/lib/rtnl.c |  | ||||||
| =================================================================== |  | ||||||
| --- ucode-2022-04-07-33f1e0b0.orig/lib/rtnl.c |  | ||||||
| +++ ucode-2022-04-07-33f1e0b0/lib/rtnl.c |  | ||||||
| @@ -682,6 +682,7 @@ static const uc_nl_nested_spec_t link_ms |  | ||||||
|  		{ IFLA_UNSPEC, "type", DT_U16, 0, MEMBER(ifinfomsg, ifi_type) }, |  | ||||||
|  		{ IFLA_UNSPEC, "dev", DT_NETDEV, 0, MEMBER(ifinfomsg, ifi_index) }, |  | ||||||
|  		{ IFLA_UNSPEC, "flags", DT_FLAGS, 0, MEMBER(ifinfomsg, ifi_flags) }, |  | ||||||
| +		{ IFLA_UNSPEC, "change", DT_FLAGS, 0, MEMBER(ifinfomsg, ifi_change) }, |  | ||||||
|  		{ IFLA_ADDRESS, "address", DT_LLADDR, 0, NULL }, |  | ||||||
|  		{ IFLA_BROADCAST, "broadcast", DT_LLADDR, 0, NULL }, |  | ||||||
|  		{ IFLA_TXQLEN, "txqlen", DT_U32, 0, NULL }, |  | ||||||
|   | |||||||
| @@ -5,9 +5,9 @@ PKG_RELEASE:=1 | |||||||
|  |  | ||||||
| PKG_SOURCE_PROTO:=git | PKG_SOURCE_PROTO:=git | ||||||
| PKG_SOURCE_URL=https://github.com/blogic/udevmand.git | PKG_SOURCE_URL=https://github.com/blogic/udevmand.git | ||||||
| PKG_MIRROR_HASH:=25e47c7f3d454cc5eba4e9c19fc9da8431e3c2b1b97b8f0f49798f51c2722df7 | PKG_MIRROR_HASH:=51bcf59754ef87913c40f2f1c708c8d2d2eb0ad5fc128a5c891e54ea4b3b035e | ||||||
| PKG_SOURCE_DATE:=20220112 | PKG_SOURCE_DATE:=20220112 | ||||||
| PKG_SOURCE_VERSION:=065f75cb88aa317441adffeddc8d5302cfaafc8a | PKG_SOURCE_VERSION:=3d2b67b180679a6f5687e8d318a66a7cbad3fa7b | ||||||
| CMAKE_INSTALL:=1 | CMAKE_INSTALL:=1 | ||||||
|  |  | ||||||
| PKG_LICENSE:=LGPL-2.1 | PKG_LICENSE:=LGPL-2.1 | ||||||
|   | |||||||
| @@ -49,6 +49,7 @@ const char *dhcpsnoop_parse_ipv4(const void *buf, size_t len, uint16_t port, uin | |||||||
| 			break; | 			break; | ||||||
| 		case DHCPV4_OPT_LEASETIME: | 		case DHCPV4_OPT_LEASETIME: | ||||||
| 			if (opt[1] != 4) | 			if (opt[1] != 4) | ||||||
|  | 				continue; | ||||||
| 			leasetime = *((uint32_t *) &opt[2]); | 			leasetime = *((uint32_t *) &opt[2]); | ||||||
| 			break; | 			break; | ||||||
| 		case DHCPV4_OPT_REBIND: | 		case DHCPV4_OPT_REBIND: | ||||||
| @@ -71,7 +72,8 @@ const char *dhcpsnoop_parse_ipv4(const void *buf, size_t len, uint16_t port, uin | |||||||
| 	else if (leasetime) | 	else if (leasetime) | ||||||
| 		*expire = leasetime; | 		*expire = leasetime; | ||||||
| 	else | 	else | ||||||
| 		*expire = 24 * 60; | 		*expire = 24 * 60 * 60; | ||||||
|  | 	*expire = ntohl(*expire); | ||||||
|  |  | ||||||
| 	switch(type) { | 	switch(type) { | ||||||
| 	case DHCPV4_MSG_ACK: | 	case DHCPV4_MSG_ACK: | ||||||
|   | |||||||
| @@ -18,7 +18,7 @@ endef | |||||||
|  |  | ||||||
| define Package/uspot/install | define Package/uspot/install | ||||||
| 	$(INSTALL_DIR) $(1)/usr/bin/ $(1)/usr/lib/ucode | 	$(INSTALL_DIR) $(1)/usr/bin/ $(1)/usr/lib/ucode | ||||||
| 	$(INSTALL_BIN) $(PKG_BUILD_DIR)/radius-client $(1)/usr/bin | 	$(INSTALL_BIN) $(PKG_BUILD_DIR)/radius-client $(1)/usr/bin/radius-client | ||||||
| 	$(INSTALL_DATA) $(PKG_BUILD_DIR)/libuam.so $(1)/usr/lib/ucode/uam.so | 	$(INSTALL_DATA) $(PKG_BUILD_DIR)/libuam.so $(1)/usr/lib/ucode/uam.so | ||||||
| 	$(CP) ./files/* $(1) | 	$(CP) ./files/* $(1) | ||||||
| endef | endef | ||||||
|   | |||||||
| @@ -1,25 +1,6 @@ | |||||||
| config uspot config | config uspot config | ||||||
| 	#option auth_mode 'uam' |  | ||||||
| 	#option auth_mode 'radius' |  | ||||||
| 	#option auth_mode 'credentials' |  | ||||||
| 	option auth_mode 'click-to-continue' |  | ||||||
|  |  | ||||||
| config radius radius | config radius radius | ||||||
| #	option auth_server 212.24.98.232 |  | ||||||
| #	option auth_port 1812 |  | ||||||
| #	option auth_secret secret |  | ||||||
|  |  | ||||||
| config uam uam | config uam uam | ||||||
| #	option port 3990 |  | ||||||
| #	option nasid AlmondLabs |  | ||||||
| #	option nasmac 903cb3bb25e3 |  | ||||||
| #	option server https://customer.hotspotsystem.com/customer/hotspotlogin.php |  | ||||||
| #	option secret hotsys123 |  | ||||||
|  |  | ||||||
| #config credential |  | ||||||
| #	option username abc |  | ||||||
| #	option password def |  | ||||||
|  |  | ||||||
| #config credential |  | ||||||
| #	option username 123 |  | ||||||
| #	option password 456 |  | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								feeds/ucentral/uspot/files/etc/init.d/uspot
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										13
									
								
								feeds/ucentral/uspot/files/etc/init.d/uspot
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,13 @@ | |||||||
|  | #!/bin/sh /etc/rc.common | ||||||
|  |  | ||||||
|  | START=80 | ||||||
|  |  | ||||||
|  | USE_PROCD=1 | ||||||
|  | PROG=/usr/share/uspot/accounting.uc | ||||||
|  |  | ||||||
|  | start_service() { | ||||||
|  | 	procd_open_instance | ||||||
|  | 	procd_set_param command "$PROG" | ||||||
|  | 	procd_set_param respawn | ||||||
|  | 	procd_close_instance | ||||||
|  | } | ||||||
							
								
								
									
										53
									
								
								feeds/ucentral/uspot/files/usr/bin/captive
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										53
									
								
								feeds/ucentral/uspot/files/usr/bin/captive
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,53 @@ | |||||||
|  | #!/usr/bin/ucode | ||||||
|  |  | ||||||
|  | let ubus = require('ubus').connect(); | ||||||
|  | let uci = require('uci').cursor(); | ||||||
|  |  | ||||||
|  | function restart() { | ||||||
|  | 	system('/etc/init.d/spotfilter restart'); | ||||||
|  | 	system('/etc/init.d/uhttpd restart'); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | switch(ARGV[0]) { | ||||||
|  | case 'dump': | ||||||
|  | 	let clients = ubus.call('spotfilter', 'client_list', { interface: 'hotspot'}); | ||||||
|  | 	printf('%.J\n', clients); | ||||||
|  | 	break; | ||||||
|  | case 'clients': | ||||||
|  | 	let clients = ubus.call('spotfilter', 'client_list', { interface: 'hotspot'}); | ||||||
|  | 	let res = {}; | ||||||
|  | 	let t = time(); | ||||||
|  |  | ||||||
|  | 	for (let c, val in clients) { | ||||||
|  | 		res[c] = { | ||||||
|  | 			status: val.state ? 'Authenticated' : 'Garden', | ||||||
|  |                         idle: val.idle || 0, | ||||||
|  | 			time: val.data.connect ? t - val.data.connect : 0, | ||||||
|  | 			ip4addr: val.ip4addr || '', | ||||||
|  | 			ip6addr: val.ip6addr || '', | ||||||
|  | 			packets_ul: val.packets_ul || 0, | ||||||
|  | 			bytes_ul: val.bytes_ul || 0, | ||||||
|  | 			packets_dl: val.packets_dl || 0, | ||||||
|  | 			bytes_dl: val.bytes_dl || 0, | ||||||
|  | 		}; | ||||||
|  | 	} | ||||||
|  | 	printf('%.J\n', res); | ||||||
|  | 	break; | ||||||
|  | case 'remove': | ||||||
|  | 	ubus.call('spotfilter', 'client_remove', { interface: 'hotspot', address: ARGV[1] || ''}); | ||||||
|  | 	break; | ||||||
|  | case 'restart': | ||||||
|  | 	restart(); | ||||||
|  | 	break; | ||||||
|  | case 'log': | ||||||
|  | 	system('logread -f | grep uspot:'); | ||||||
|  | 	break; | ||||||
|  | case 'debugon': | ||||||
|  | case 'debugoff': | ||||||
|  | 	uci.set('uspot', 'config', 'debug', 1); | ||||||
|  | 	uci.commit(); | ||||||
|  | 	restart(); | ||||||
|  | 	break; | ||||||
|  | default: | ||||||
|  | 	break; | ||||||
|  | } | ||||||
							
								
								
									
										234
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/accounting.uc
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										234
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/accounting.uc
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,234 @@ | |||||||
|  | #!/usr/bin/ucode | ||||||
|  |  | ||||||
|  | 'use strict'; | ||||||
|  |  | ||||||
|  | let fs = require('fs'); | ||||||
|  | let uloop = require('uloop'); | ||||||
|  | let ubus = require('ubus').connect(); | ||||||
|  | let uci = require('uci').cursor(); | ||||||
|  | let config = uci.get_all('uspot'); | ||||||
|  | let clients = {}; | ||||||
|  |  | ||||||
|  | let acct_interval = config.radius?.acct_interval || 600; | ||||||
|  | let idle_timeout = config.config.idle_timeout || 600; | ||||||
|  | let session_timeout = config.config.session_timeout || 0; | ||||||
|  |  | ||||||
|  | function syslog(mac, msg) { | ||||||
|  | 	let log = sprintf('uspot: %s %s', mac, msg); | ||||||
|  |  | ||||||
|  | 	system('logger ' + log); | ||||||
|  | 	warn(log + '\n'); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function debug(mac, msg) { | ||||||
|  | 	if (config.config.debug) | ||||||
|  | 		syslog(mac, msg); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function get_idle_timeout(mac) { | ||||||
|  | 	if (clients[mac]) | ||||||
|  | 		return clients[mac].idle; | ||||||
|  | 	return idle_timeout; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function get_session_timeout(mac) { | ||||||
|  | 	if (clients[mac]?.session) | ||||||
|  | 		return clients[mac].session; | ||||||
|  | 	return session_timeout; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_available(mac) { | ||||||
|  | 	return !!clients[mac]?.radius; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_init(mac, payload) { | ||||||
|  | 	for (let key in [ 'server', 'acct_server', 'acct_session', 'client_ip', 'called_station', 'calling_station', 'nas_ip', 'nas_id', 'username' ]) | ||||||
|  | 		if (clients[mac].radius[key]) | ||||||
|  | 			payload[key] = clients[mac].radius[key]; | ||||||
|  | 	return payload; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_call(mac, payload) { | ||||||
|  | 	let cfg = fs.open('/tmp/acct' + mac + '.json', 'w'); | ||||||
|  | 	cfg.write(payload); | ||||||
|  | 	cfg.close(); | ||||||
|  |  | ||||||
|  | 	system('/usr/bin/radius-client /tmp/acct' + mac + '.json'); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_stop(mac) { | ||||||
|  | 	if (!radius_available(mac)) | ||||||
|  | 		return; | ||||||
|  | 	debug(mac, 'stopping accounting'); | ||||||
|  |  | ||||||
|  | 	let payload = { | ||||||
|  | 		acct: true, | ||||||
|  | 		acct_type: 8, | ||||||
|  | 		terminate_cause: 0, | ||||||
|  | 	}; | ||||||
|  | 	radius_init(mac, payload); | ||||||
|  | 	radius_call(mac, payload); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_acct(mac, payload) { | ||||||
|  | 	let state = ubus.call('spotfilter', 'client_get', { | ||||||
|  | 		interface: 'hotspot', | ||||||
|  | 		address: mac | ||||||
|  | 	}); | ||||||
|  | 	if (!state) { | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	payload = radius_init(mac, payload); | ||||||
|  | 	payload.acct = true; | ||||||
|  | 	payload.session_time = time() - state.data.connect; | ||||||
|  | 	payload.output_octets = state.bytes_dl & 0xffffffff; | ||||||
|  | 	payload.input_octets = state.bytes_ul & 0xffffffff; | ||||||
|  | 	payload.output_gigawords = state.bytes_dl >> 32; | ||||||
|  | 	payload.input_gigawords = state.bytes_ul >> 32; | ||||||
|  | 	payload.output_packets = state.packets_dl; | ||||||
|  | 	payload.input_packets = state.packets_ul; | ||||||
|  |  | ||||||
|  | 	radius_call(mac, payload); | ||||||
|  | 	return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_idle_time(mac) { | ||||||
|  | 	if (!radius_available(mac)) | ||||||
|  | 		return; | ||||||
|  | 	let payload = { | ||||||
|  | 		acct_type: 2, | ||||||
|  | 		terminate_cause: 4, | ||||||
|  | 	}; | ||||||
|  | 	radius_acct(mac, payload); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_session_time(mac) { | ||||||
|  | 	if (!radius_available(mac)) | ||||||
|  | 		return; | ||||||
|  | 	let payload = { | ||||||
|  | 		acct_type: 2, | ||||||
|  | 		terminate_cause: 5, | ||||||
|  | 	}; | ||||||
|  | 	radius_acct(mac, payload); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_disconnect(mac) { | ||||||
|  | 	if (!radius_available(mac)) | ||||||
|  | 		return; | ||||||
|  | 	let payload = { | ||||||
|  | 		acct_type: 2, | ||||||
|  | 		terminate_cause: 1, | ||||||
|  | 	}; | ||||||
|  | 	radius_acct(mac, payload); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function radius_interim(mac) { | ||||||
|  | 	if (!radius_available(mac)) | ||||||
|  | 		return; | ||||||
|  | 	let payload = { | ||||||
|  | 		acct_type: 3, | ||||||
|  | 	}; | ||||||
|  | 	if (radius_acct(mac, payload)) | ||||||
|  | 		debug(mac, 'iterim acct call'); | ||||||
|  | 	else | ||||||
|  | 		syslog(mac, 'failed to sent interim accounting frame\n'); | ||||||
|  | 	clients[mac].timeout.set(clients[mac].interval); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function client_add(mac, state) { | ||||||
|  | 	if (state.state != 1) | ||||||
|  | 		return; | ||||||
|  |  | ||||||
|  | 	let interval = acct_interval * 1000; | ||||||
|  | 	let idle = idle_timeout; | ||||||
|  | 	let session = session_timeout; | ||||||
|  | 	let accounting = (config.radius?.acct_server && config.radius?.acct_secret); | ||||||
|  |  | ||||||
|  | 	if (state.data?.radius?.reply) { | ||||||
|  | 		interval = (state.data?.radius?.reply['Acct-Interim-Interval'] || acct_interval) * 1000; | ||||||
|  | 		idle = (state.data?.radius?.reply['Idle-Timeout'] || idle_timeout); | ||||||
|  | 		session = (state.data?.radius?.reply['Session-Timeout'] || session_timeout); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	clients[mac] = { | ||||||
|  | 		accounting, | ||||||
|  | 		interval, | ||||||
|  | 		session, | ||||||
|  | 		idle, | ||||||
|  | 	}; | ||||||
|  | 	if (state.data?.radius?.request) | ||||||
|  | 		clients[mac].radius= state.data.radius.request; | ||||||
|  | 	syslog(mac, 'adding client'); | ||||||
|  | 	if (accounting) | ||||||
|  | 		clients[mac].timeout = uloop.timer(interval, () => radius_interim(mac)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function client_remove(mac, reason) { | ||||||
|  | 	syslog(mac, reason); | ||||||
|  | 	if (clients[mac]) { | ||||||
|  | 		radius_stop(mac); | ||||||
|  | 		if (clients[mac].accounting) | ||||||
|  | 			clients[mac].timeout.cancel(); | ||||||
|  | 		delete clients[mac]; | ||||||
|  | 	} | ||||||
|  | 	ubus.call('spotfilter', 'client_remove', { | ||||||
|  | 			interface: "hotspot", | ||||||
|  | 			address: mac | ||||||
|  | 		}); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function client_timeout(mac) { | ||||||
|  | 	syslog(mac, 'session timeout'); | ||||||
|  | 	if (clients[mac]) { | ||||||
|  | 		radius_stop(mac); | ||||||
|  | 		if (clients[mac].accounting) | ||||||
|  | 			clients[mac].timeout.cancel(); | ||||||
|  | 		delete clients[mac]; | ||||||
|  | 	} | ||||||
|  | 	ubus.call('spotfilter', 'client_set', { | ||||||
|  | 			interface: "hotspot", | ||||||
|  | 			state: 0, | ||||||
|  | 			dns_state: 1, | ||||||
|  | 			address: mac, | ||||||
|  | 			accounting: [], | ||||||
|  | 			flush: true, | ||||||
|  | 		}); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | uloop.init(); | ||||||
|  |  | ||||||
|  | uloop.timer(1000, function() { | ||||||
|  | 	let list = ubus.call('spotfilter', 'client_list', { interface: 'hotspot'}); | ||||||
|  | 	let t = time(); | ||||||
|  |  | ||||||
|  | 	for (let k, v in list) | ||||||
|  | 		if (!clients[k]) | ||||||
|  | 			client_add(k, v); | ||||||
|  |  | ||||||
|  | 	for (let k, v in clients) | ||||||
|  | 		if (!list[k] || !list[k].state) { | ||||||
|  | 			radius_disconnect(k); | ||||||
|  | 			client_remove(k, 'disconnect event'); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 	for (let k, v in list) { | ||||||
|  | 		if (v.idle > get_idle_timeout(k)) { | ||||||
|  | 			if (clients[k]) | ||||||
|  | 				radius_idle_time(k); | ||||||
|  | 			client_remove(k, 'idle event'); | ||||||
|  |  | ||||||
|  | 		} | ||||||
|  | 		let timeout = get_session_timeout(k); | ||||||
|  | 		if (timeout && ((t - v.data.connect) > timeout)) { | ||||||
|  | 			if (clients[k]) | ||||||
|  | 				radius_session_time(k); | ||||||
|  | 			client_timeout(k); | ||||||
|  |  | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	this.set(5000); | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | uloop.run(); | ||||||
| @@ -26,6 +26,45 @@ return { | |||||||
| 	header, | 	header, | ||||||
| 	footer, | 	footer, | ||||||
|  |  | ||||||
|  | 	// syslog helper | ||||||
|  | 	syslog: function(ctx, msg) { | ||||||
|  | 		warn('uspot: ' + ctx.env.REMOTE_ADDR + ' - ' + msg + '\n'); | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	debug: function(ctx, msg) { | ||||||
|  | 		if (config.config.debug) | ||||||
|  | 			this.syslog(ctx, msg); | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	// mac re-formater | ||||||
|  | 	format_mac: function(mac) { | ||||||
|  | 		switch(config.uam.mac_format) { | ||||||
|  | 		case 'aabbccddeeff': | ||||||
|  | 		case 'AABBCCDDEEFF': | ||||||
|  | 			mac = replace(mac, ':', ''); | ||||||
|  | 			break; | ||||||
|  | 		case 'aa-bb-cc-dd-ee-ff': | ||||||
|  | 		case 'AA-BB-CC-DD-EE-FF': | ||||||
|  | 			mac = replace(mac, ':', '-'); | ||||||
|  | 			break; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		switch(config.uam.mac_format) { | ||||||
|  | 		case 'aabbccddeeff': | ||||||
|  | 		case 'aa-bb-cc-dd-ee-ff': | ||||||
|  | 		case 'aa:bb:cc:dd:ee:ff': | ||||||
|  | 			mac = lc(mac); | ||||||
|  | 			break; | ||||||
|  | 		case 'AABBCCDDEEFF': | ||||||
|  | 		case 'AA:BB:CC:DD:EE:FF': | ||||||
|  | 		case 'AA-BB-CC-DD-EE-FF': | ||||||
|  | 			mac = uc(mac); | ||||||
|  | 			break; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		return mac; | ||||||
|  | 	}, | ||||||
|  |  | ||||||
| 	// wrapper for scraping external tools stdout | 	// wrapper for scraping external tools stdout | ||||||
| 	fs_popen: function(cmd) { | 	fs_popen: function(cmd) { | ||||||
| 		let stdout = fs.popen(cmd); | 		let stdout = fs.popen(cmd); | ||||||
| @@ -43,45 +82,79 @@ return { | |||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	// give a client access to the internet | 	// give a client access to the internet | ||||||
| 	allow_client: function(ctx) { | 	allow_client: function(ctx, data) { | ||||||
|  | 		this.syslog(ctx, 'allow client to pass traffic'); | ||||||
| 		ctx.ubus.call('spotfilter', 'client_set', { | 		ctx.ubus.call('spotfilter', 'client_set', { | ||||||
| 			"interface": "hotspot", | 			"interface": "hotspot", | ||||||
| 			"address": replace(ctx.mac, '-', ':'), | 			"address": ctx.mac, | ||||||
| 			"state": 1, | 			"state": 1, | ||||||
| 			"dns_state": 1, | 			"dns_state": 1, | ||||||
| 			"accounting": [ "dl", "ul"], | 			"accounting": [ "dl", "ul"], | ||||||
| 			"data": { | 			"data": { | ||||||
| 				"connect": time() | 				... data || {}, | ||||||
|  | 				"connect": time(), | ||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
| 		if (ctx.query_string.userurl) | 		if (ctx.query_string.userurl) | ||||||
| 			include('redir.uc', { redir_location: ctx.query_string.userurl }); | 			include('redir.uc', { redir_location: ctx.query_string.userurl }); | ||||||
| 		else | 		else | ||||||
| 			include('allow.uc', ctx); | 			include('allow.uc', ctx); | ||||||
|  | 		//data.radius.reply['WISPr-Bandwidth-Max-Up'] = "20000000"; | ||||||
|  | 		//data.radius.reply['WISPr-Bandwidth-Max-Down'] = "10000000"; | ||||||
|  | 		if (data?.radius?.reply && (+data.radius.reply['WISPr-Bandwidth-Max-Up'] && +data.radius.reply['WISPr-Bandwidth-Max-Down'])) | ||||||
|  | 			ctx.ubus.call('ratelimit', 'client_set', { | ||||||
|  | 				device: ctx.device, | ||||||
|  | 				address: ctx.mac, | ||||||
|  | 				rate_egress: sprintf('%s', data.radius.reply['WISPr-Bandwidth-Max-Down']), | ||||||
|  | 				rate_ingress: sprintf('%s', data.radius.reply['WISPr-Bandwidth-Max-Up']), | ||||||
|  | 			 }); | ||||||
|  | 	}, | ||||||
|  |  | ||||||
|  | 	// put a client back into pre-auth state | ||||||
|  | 	logoff: function(ctx, data) { | ||||||
|  | 		this.syslog(ctx, 'logging client off'); | ||||||
|  | 		ctx.ubus.call('spotfilter', 'client_set', { | ||||||
|  | 			interface: 'hotspot', | ||||||
|  | 			address: ctx.mac, | ||||||
|  | 			state: 0, | ||||||
|  | 			dns_state: 1, | ||||||
|  | 			accounting: [], | ||||||
|  | 			flush: true, | ||||||
|  | 		}); | ||||||
|  | 		include('logoff.uc', ctx); | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	// generate the default radius auth payload | 	// generate the default radius auth payload | ||||||
| 	radius_init: function(ctx) { | 	radius_init: function(ctx, acct_session) { | ||||||
|  | 		let math = require('math'); | ||||||
|  | 		if (!acct_session) { | ||||||
|  | 			acct_session = ''; | ||||||
|  |  | ||||||
|  | 			for (let i = 0; i < 16; i++) | ||||||
|  | 			        acct_session += sprintf('%d', math.rand() % 10); | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		return { | 		return { | ||||||
| 			server: sprintf('%s:%s:%s', this.config.radius.auth_server, this.config.radius.auth_port, this.config.radius.auth_secret), | 			server: sprintf('%s:%s:%s', this.config.radius.auth_server, this.config.radius.auth_port, this.config.radius.auth_secret), | ||||||
| 			acct_session: "0123456789", | 			acct_server: sprintf('%s:%s:%s', this.config.radius.acct_server, this.config.radius.acct_port, this.config.radius.acct_secret), | ||||||
|  | 			acct_session, | ||||||
| 			client_ip: ctx.env.REMOTE_ADDR, | 			client_ip: ctx.env.REMOTE_ADDR, | ||||||
| 			called_station: ctx.mac, | 			called_station: this.config.uam.nasmac + ':' + ctx.ssid, | ||||||
| 			calling_station: this.config.uam.nasmac, | 			calling_station: this.format_mac(ctx.mac), | ||||||
| 			nas_ip: ctx.env.SERVER_ADDR, | 			nas_ip: ctx.env.SERVER_ADDR, | ||||||
| 			nas_id: this.config.uam.nasid | 			nas_id: this.config.uam.nasid | ||||||
| 		}; | 		}; | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	radius_call: function(ctx, payload) { | 	radius_call: function(ctx, payload) { | ||||||
| 		let cfg = fs.open('/tmp/' + ctx.mac + '.json', 'w'); | 		let cfg = fs.open('/tmp/auth' + ctx.mac + '.json', 'w'); | ||||||
| 		cfg.write(payload); | 		cfg.write(payload); | ||||||
| 		cfg.close(); | 		cfg.close(); | ||||||
|  |  | ||||||
| 		return this.fs_popen('/usr/bin/radius-client /tmp/' + ctx.mac + '.json'); | 		return this.fs_popen('/usr/bin/radius-client /tmp/auth' + ctx.mac + '.json'); | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	handle_request: function(env) { | 	handle_request: function(env, uam) { | ||||||
| 		let mac; | 		let mac; | ||||||
| 		let form_data = {}; | 		let form_data = {}; | ||||||
| 		let query_string = {}; | 		let query_string = {}; | ||||||
| @@ -91,25 +164,39 @@ return { | |||||||
| 		// lookup the peers MAC | 		// lookup the peers MAC | ||||||
| 		let macs = this.rtnl.request(this.rtnl.const.RTM_GETNEIGH, this.rtnl.const.NLM_F_DUMP, { }); | 		let macs = this.rtnl.request(this.rtnl.const.RTM_GETNEIGH, this.rtnl.const.NLM_F_DUMP, { }); | ||||||
| 		for (let m in macs) | 		for (let m in macs) | ||||||
| 			if (m.dst == env.REMOTE_HOST) | 			if (m.dst == env.REMOTE_HOST && m.lladdr) | ||||||
| 				ctx.mac = replace(m.lladdr, ':', '-'); | 				ctx.mac = m.lladdr; | ||||||
|  |  | ||||||
| 		// if the MAC lookup failed, go to the error page | 		// if the MAC lookup failed, go to the error page | ||||||
| 		if (!ctx.mac) { | 		if (!ctx.mac) { | ||||||
|  | 			this.syslog(ctx, 'failed to look up mac'); | ||||||
| 			include('error.uc', ctx); | 			include('error.uc', ctx); | ||||||
| 			return NULL; | 			return NULL; | ||||||
| 		} | 		} | ||||||
|  | 		ctx.format_mac = this.format_mac(ctx.mac); | ||||||
|  |  | ||||||
| 		// check if a client is already connected | 		// check if a client is already connected | ||||||
| 		ctx.ubus = ubus.connect(); | 		ctx.ubus = ubus.connect(); | ||||||
| 		let connected = ctx.ubus.call('spotfilter', 'client_get', { | 		let connected = ctx.ubus.call('spotfilter', 'client_get', { | ||||||
| 			'interface': 'hotspot', | 			interface: 'hotspot', | ||||||
| 			'address': ctx.mac | 			address: ctx.mac, | ||||||
| 		}); | 		}); | ||||||
| 		if (connected?.state) { | 		if (!uam && connected?.state) { | ||||||
| 			include('connected.uc', ctx); | 			include('connected.uc', ctx); | ||||||
| 			return NULL; | 			return NULL; | ||||||
| 		} | 		} | ||||||
|  | 		if (!connected.data.ssid) { | ||||||
|  | 			let hapd = ctx.ubus.call('hostapd.' + connected.device, 'get_status'); | ||||||
|  | 			ctx.ubus.call('spotfilter', 'client_set', { | ||||||
|  | 				interface: 'hotspot', | ||||||
|  | 				address: ctx.mac, | ||||||
|  | 				data: { | ||||||
|  | 					ssid: hapd.ssid || 'unknown' | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  | 		ctx.device = connected.device; | ||||||
|  | 		ctx.ssid = connected.data.ssid; | ||||||
|  |  | ||||||
| 		// split QUERY_STRING | 		// split QUERY_STRING | ||||||
| 		if (env.QUERY_STRING) | 		if (env.QUERY_STRING) | ||||||
|   | |||||||
| @@ -1,14 +1,4 @@ | |||||||
| Status: 200 OK | Status: 302 Found | ||||||
|  | Location: http://{{env.SERVER_ADDR}}/hotspot/?redir={{env.headers.host}} | ||||||
| Content-Type: text/html | Content-Type: text/html | ||||||
|  |  | ||||||
| <?xml version="1.0" encoding="utf-8"?> |  | ||||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> |  | ||||||
| <html xmlns="http://www.w3.org/1999/xhtml"> |  | ||||||
| <head> |  | ||||||
| <meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" /> |  | ||||||
| <meta http-equiv="refresh" content="0; URL=http://{{env.SERVER_ADDR}}/hotspot/?redir={{env.headers.host}}" /> |  | ||||||
| </head> |  | ||||||
| <body style="background-color: white"> |  | ||||||
| <a style="color: black; font-family: arial, helvetica, sans-serif;" href="http://{{env.SERVER_ADDR}}/hotspot">HotSpot Login</a> |  | ||||||
| </body> |  | ||||||
| </html> |  | ||||||
|   | |||||||
| @@ -3,14 +3,18 @@ Content-Type: text/html | |||||||
|  |  | ||||||
| {{ header }} | {{ header }} | ||||||
| {% if (error): %} | {% if (error): %} | ||||||
| <h1> Invalid credentials </h1> | <h2> Invalid credentials </h2> | ||||||
| {% endif %} | {% endif %} | ||||||
|  |  | ||||||
| <form action="/hotspot" method="POST"> | <form action="/hotspot" method="POST"> | ||||||
| <label for="fname">Username:</label> | 	<table> | ||||||
| <input type="text" name="username"><br> | 		<tr><td><label for="fname">Username:</label></td> | ||||||
| <label for="fname">Password:</label> | 			<td><input type="text" name="username"></td> | ||||||
| <input type="password" name="password"> | 		</tr> | ||||||
|  | 		<tr><td><label for="fname">Password:</label></td> | ||||||
|  | 			<td><input type="password" name="password"></td> | ||||||
|  | 		</tr> | ||||||
|  | 	</table> | ||||||
| <input type="hidden" name="action" value="credentials"> | <input type="hidden" name="action" value="credentials"> | ||||||
| <input type="submit" value="Login" class="btn btn-primary btn-block"> | <input type="submit" value="Login" class="btn btn-primary btn-block"> | ||||||
| </form> | </form> | ||||||
|   | |||||||
| @@ -3,6 +3,7 @@ Content-Type: text/html | |||||||
|  |  | ||||||
| {{ header }} | {{ header }} | ||||||
|  |  | ||||||
| <h1> An Error occured, please try again </h1> | <h2> An Error occured </h2> | ||||||
|  | <h2> Please try again </h2> | ||||||
|  |  | ||||||
| {{ footer }} | {{ footer }} | ||||||
|   | |||||||
| @@ -2,7 +2,12 @@ | |||||||
|  |  | ||||||
| 'use strict'; | 'use strict'; | ||||||
|  |  | ||||||
|  | let uci = require('uci').cursor(); | ||||||
|  | let config = uci.get_all('uspot'); | ||||||
|  |  | ||||||
| global.handle_request = function(env) { | global.handle_request = function(env) { | ||||||
|  | 	if (env.REMOTE_ADDR && config.config.debug) | ||||||
|  | 		warn('uspot: ' + env.REMOTE_ADDR + ' - CPD redirect\n'); | ||||||
| 	include('cpd.uc', { env }); | 	include('cpd.uc', { env }); | ||||||
| }; | }; | ||||||
| %} | %} | ||||||
|   | |||||||
| @@ -12,10 +12,10 @@ function auth_client(ctx) { | |||||||
| 	let password; | 	let password; | ||||||
| 	let payload = portal.radius_init(ctx); | 	let payload = portal.radius_init(ctx); | ||||||
|  |  | ||||||
|  | 	payload.logoff_url = sprintf('http://%s:3990/logoff', ctx.env.SERVER_ADDR); | ||||||
| 	if (ctx.query_string.username && ctx.query_string.response) { | 	if (ctx.query_string.username && ctx.query_string.response) { | ||||||
| 		let challenge = uam.md5(portal.config.uam.challenge, ctx.mac); | 		let challenge = uam.md5(portal.config.uam.challenge, ctx.format_mac); | ||||||
|  |  | ||||||
| 		payload.type = 'uam-chap-auth'; |  | ||||||
| 		payload.username = ctx.query_string.username; | 		payload.username = ctx.query_string.username; | ||||||
| 		payload.chap_password = ctx.query_string.response; | 		payload.chap_password = ctx.query_string.response; | ||||||
| 		if (portal.config.uam.secret) | 		if (portal.config.uam.secret) | ||||||
| @@ -23,24 +23,44 @@ function auth_client(ctx) { | |||||||
| 		else | 		else | ||||||
| 			payload.chap_challenge = challenge; | 			payload.chap_challenge = challenge; | ||||||
| 	} else if (ctx.query_string.username && ctx.query_string.password) { | 	} else if (ctx.query_string.username && ctx.query_string.password) { | ||||||
| 		payload.type = 'uam-auth'; | 		payload.username = ctx.query_string.username; | ||||||
| 		payload.username = ctx.mac; | 		payload.password = uam.password(uam.md5(portal.config.uam.challenge, ctx.format_mac), ctx.query_string.password, portal.config.uam.uam_secret); | ||||||
| 		payload.password = uam.password(uam.md5(portal.config.uam.challenge, ctx.mac), ctx.query_string.password, portal.config.uam.uam_secret); | 	} else | ||||||
| 	} | 		include('error.uc', ctx); | ||||||
|  |  | ||||||
|         let reply = portal.radius_call(ctx, payload); |         let radius = portal.radius_call(ctx, payload); | ||||||
| 	if (reply['access-accept']) { | 	if (radius['access-accept']) { | ||||||
|                 portal.allow_client(ctx); | 		portal.allow_client(ctx, { radius: { reply: radius.reply, request: payload } } ); | ||||||
|                 return; |  | ||||||
|         } | 		payload = portal.radius_init(ctx, payload.acct_session); | ||||||
|  | 		payload.acct = true; | ||||||
|  | 		payload.username = ctx.query_string.username; | ||||||
|  | 		payload.acct_type = 1; | ||||||
|  | 		portal.radius_call(ctx, payload); | ||||||
|  | 		return; | ||||||
|  | 	} | ||||||
| 	include('error.uc', ctx); | 	include('error.uc', ctx); | ||||||
| } | } | ||||||
|  |  | ||||||
| global.handle_request = function(env) { | // disconnect client | ||||||
| 	let ctx = portal.handle_request(env); | function deauth_client(ctx) { | ||||||
|  | 	portal.logoff(ctx); | ||||||
|  | } | ||||||
|  |  | ||||||
| 	if (ctx) | global.handle_request = function(env) { | ||||||
|  | 	let ctx = portal.handle_request(env, true); | ||||||
|  |  | ||||||
|  | 	switch (split(ctx.env.REQUEST_URI, '?')[0] || '') { | ||||||
|  | 	case '/logon': | ||||||
| 		auth_client(ctx); | 		auth_client(ctx); | ||||||
|  | 		break; | ||||||
|  | 	case '/logoff': | ||||||
|  | 		deauth_client(ctx); | ||||||
|  | 		break; | ||||||
|  | 	default: | ||||||
|  | 		include('error.uc', ctx); | ||||||
|  | 		break; | ||||||
|  | 	} | ||||||
| }; | }; | ||||||
|  |  | ||||||
| %} | %} | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ let portal = require('common'); | |||||||
|  |  | ||||||
| // delegate an initial connection to the correct handler | // delegate an initial connection to the correct handler | ||||||
| function request_start(ctx) { | function request_start(ctx) { | ||||||
|  | 	portal.debug(ctx, 'start ' + (portal.config?.config?.auth_mode || '') + ' flow'); | ||||||
| 	switch (portal.config?.config?.auth_mode) { | 	switch (portal.config?.config?.auth_mode) { | ||||||
| 	case 'click-to-continue': | 	case 'click-to-continue': | ||||||
| 		include('click.uc', ctx); | 		include('click.uc', ctx); | ||||||
| @@ -22,12 +23,14 @@ function request_start(ctx) { | |||||||
| 			'?res=notyet' + | 			'?res=notyet' + | ||||||
| 			'&uamip=' + ctx.env.SERVER_ADDR + | 			'&uamip=' + ctx.env.SERVER_ADDR + | ||||||
| 			'&uamport=' + portal.config.uam.uam_port + | 			'&uamport=' + portal.config.uam.uam_port + | ||||||
| 			'&challenge=' + portal.uam.md5(portal.config.uam.challenge, ctx.mac) + | 			'&challenge=' + portal.uam.md5(portal.config.uam.challenge, ctx.format_mac) + | ||||||
| 			'&mac=' + replace(ctx.mac, ':', '-') + | 			'&mac=' + ctx.format_mac + | ||||||
| 			'&ip=' + ctx.env.REMOTE_ADDR + | 			'&ip=' + ctx.env.REMOTE_ADDR + | ||||||
| 			'&called=' + portal.config.uam.nasmac + | 			'&called=' + portal.config.uam.nasmac + | ||||||
| 			'&nasid=' + portal.config.uam.nasid; | 			'&nasid=' + portal.config.uam.nasid + | ||||||
| 		ctx.redir_location += '&md=' + portal.uam.md5(ctx.uam_location, portal.config.uam.uam_secret); | 			'&ssid=' + ctx.ssid; | ||||||
|  | 		if (portal.config.uam.uam_secret) | ||||||
|  | 			ctx.redir_location += '&md=' + portal.uam.md5(ctx.redir_location, portal.config.uam.uam_secret); | ||||||
| 		include('redir.uc', ctx); | 		include('redir.uc', ctx); | ||||||
| 		return; | 		return; | ||||||
| 	default: | 	default: | ||||||
| @@ -46,6 +49,7 @@ function request_click(ctx) { | |||||||
|  |  | ||||||
| 	// check if a username and password was provided | 	// check if a username and password was provided | ||||||
| 	if (ctx.form_data.accept_terms != 'clicked') { | 	if (ctx.form_data.accept_terms != 'clicked') { | ||||||
|  | 		portal.debug(ctx, 'user did not accept conditions'); | ||||||
| 		request_start({ ...ctx, error: 1 }); | 		request_start({ ...ctx, error: 1 }); | ||||||
|                 return; |                 return; | ||||||
| 	} | 	} | ||||||
| @@ -55,13 +59,14 @@ function request_click(ctx) { | |||||||
| // delegate a local username/password authentication | // delegate a local username/password authentication | ||||||
| function request_credentials(ctx) { | function request_credentials(ctx) { | ||||||
| 	// make sure this is the right auth_mode | 	// make sure this is the right auth_mode | ||||||
| 	if (portal/config?.config?.auth_mode != 'credentials') { | 	if (portal.config?.config?.auth_mode != 'credentials') { | ||||||
| 		include('error.uc', ctx); | 		include('error.uc', ctx); | ||||||
|                 return; |                 return; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// check if a username and password was provided | 	// check if a username and password was provided | ||||||
| 	if (!ctx.form_data.username || !ctx.form_data.password) { | 	if (!ctx.form_data.username || !ctx.form_data.password) { | ||||||
|  | 		portal.debug(ctx, 'missing credentials\n'); | ||||||
| 		request_start({ ...ctx, error: 1 }); | 		request_start({ ...ctx, error: 1 }); | ||||||
|                 return; |                 return; | ||||||
| 	} | 	} | ||||||
| @@ -76,11 +81,12 @@ function request_credentials(ctx) { | |||||||
| 		    ctx.form_data.password != cred.password) | 		    ctx.form_data.password != cred.password) | ||||||
| 			continue; | 			continue; | ||||||
|  |  | ||||||
| 		portal.allow_client(ctx); | 		portal.allow_client(ctx, { username: ctx.form_data.username }); | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// auth failed | 	// auth failed | ||||||
|  | 	portal.debug(ctx, 'invalid credentials\n'); | ||||||
| 	request_start({ ...ctx, error: 1 }); | 	request_start({ ...ctx, error: 1 }); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -94,23 +100,25 @@ function request_radius(ctx) { | |||||||
|  |  | ||||||
| 	// check if a username and password was provided | 	// check if a username and password was provided | ||||||
| 	if (!ctx.form_data.username || !ctx.form_data.password) { | 	if (!ctx.form_data.username || !ctx.form_data.password) { | ||||||
|  | 		portal.debug(ctx, 'missing credentials\n'); | ||||||
| 		request_start({ ...ctx, error: 1 }); | 		request_start({ ...ctx, error: 1 }); | ||||||
|                 return; |                 return; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// trigger the radius auth | 	// trigger the radius auth | ||||||
| 	let payload = radius_init(ctx); | 	let payload = portal.radius_init(ctx); | ||||||
| 	payload.type = 'auth'; | 	payload.type = 'auth'; | ||||||
| 	payload.username = ctx.form_data.username; | 	payload.username = ctx.form_data.username; | ||||||
| 	payload.password = ctx.form_data.password; | 	payload.password = ctx.form_data.password; | ||||||
|  |  | ||||||
|         let reply = portal.radius_call(ctx, payload); |         let radius = portal.radius_call(ctx, payload); | ||||||
| 	if (reply['access-accept']) { | 	if (radius['access-accept']) { | ||||||
|                 portal.allow_client(ctx); |                 portal.allow_client(ctx, { username: ctx.form_data.username, radius: { reply: radius.reply, request: payload } } ); | ||||||
|                 return; |                 return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| 	// auth failed | 	// auth failed | ||||||
|  | 	portal.debug(ctx, 'invalid credentials\n'); | ||||||
| 	request_start({ ...ctx, error: 1 }); | 	request_start({ ...ctx, error: 1 }); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/logoff.uc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/logoff.uc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | |||||||
|  | Status: 200 OK | ||||||
|  | Content-Type: text/html | ||||||
|  |  | ||||||
|  | <h1> You are now logged-off </h1> | ||||||
| @@ -3,14 +3,18 @@ Content-Type: text/html | |||||||
|  |  | ||||||
| {{ header }} | {{ header }} | ||||||
| {% if (error): %} | {% if (error): %} | ||||||
| <h1> Invalid credentials </h1> | <h2> Invalid credentials </h2> | ||||||
| {% endif %} | {% endif %} | ||||||
|  |  | ||||||
| <form action="/hotspot" method="POST"> | <form action="/hotspot" method="POST"> | ||||||
| <label for="fname">Username:</label> | 	<table> | ||||||
| <input type="text" name="username"><br> | 		<tr><td><label for="fname">Username:</label></td> | ||||||
| <label for="fname">Password:</label> | 			<td><input type="text" name="username"></td> | ||||||
| <input type="password" name="password"> | 		</tr> | ||||||
|  | 		<tr><td><label for="fname">Password:</label></td> | ||||||
|  | 			<td><input type="password" name="password"></td> | ||||||
|  | 		</tr> | ||||||
|  | 	</table> | ||||||
| <input type="hidden" name="action" value="radius"> | <input type="hidden" name="action" value="radius"> | ||||||
| <input type="submit" value="Login" class="btn btn-primary btn-block"> | <input type="submit" value="Login" class="btn btn-primary btn-block"> | ||||||
| </form> | </form> | ||||||
|   | |||||||
| @@ -9,8 +9,10 @@ | |||||||
| #include <libubox/blobmsg_json.h> | #include <libubox/blobmsg_json.h> | ||||||
|  |  | ||||||
| enum { | enum { | ||||||
|         RADIUS_TYPE, |         RADIUS_ACCT, | ||||||
|         RADIUS_SERVER, |         RADIUS_SERVER, | ||||||
|  |         RADIUS_ACCT_SERVER, | ||||||
|  |         RADIUS_ACCT_TYPE, | ||||||
|         RADIUS_USERNAME, |         RADIUS_USERNAME, | ||||||
|         RADIUS_PASSWORD, |         RADIUS_PASSWORD, | ||||||
|         RADIUS_CHAP_PASSWORD, |         RADIUS_CHAP_PASSWORD, | ||||||
| @@ -21,12 +23,23 @@ enum { | |||||||
|         RADIUS_CALLING_STATION, |         RADIUS_CALLING_STATION, | ||||||
|         RADIUS_NAS_IP, |         RADIUS_NAS_IP, | ||||||
|         RADIUS_NAS_ID, |         RADIUS_NAS_ID, | ||||||
|  |         RADIUS_TERMINATE_CAUSE, | ||||||
|  |         RADIUS_SESSION_TIME, | ||||||
|  |         RADIUS_INPUT_OCTETS, | ||||||
|  |         RADIUS_OUTPUT_OCTETS, | ||||||
|  |         RADIUS_INPUT_GIGAWORDS, | ||||||
|  |         RADIUS_OUTPUT_GIGAWORDS, | ||||||
|  |         RADIUS_INPUT_PACKETS, | ||||||
|  |         RADIUS_OUTPUT_PACKETS, | ||||||
|  |         RADIUS_LOGOFF_URL, | ||||||
|         __RADIUS_MAX, |         __RADIUS_MAX, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const struct blobmsg_policy radius_policy[__RADIUS_MAX] = { | static const struct blobmsg_policy radius_policy[__RADIUS_MAX] = { | ||||||
|         [RADIUS_TYPE] = { .name = "type", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_ACCT] = { .name = "acct", .type = BLOBMSG_TYPE_BOOL }, | ||||||
|         [RADIUS_SERVER] = { .name = "server", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_SERVER] = { .name = "server", .type = BLOBMSG_TYPE_STRING }, | ||||||
|  |         [RADIUS_ACCT_SERVER] = { .name = "acct_server", .type = BLOBMSG_TYPE_STRING }, | ||||||
|  |         [RADIUS_ACCT_TYPE] = { .name = "acct_type", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|         [RADIUS_USERNAME] = { .name = "username", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_USERNAME] = { .name = "username", .type = BLOBMSG_TYPE_STRING }, | ||||||
|         [RADIUS_PASSWORD] = { .name = "password", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_PASSWORD] = { .name = "password", .type = BLOBMSG_TYPE_STRING }, | ||||||
|         [RADIUS_CHAP_PASSWORD] = { .name = "chap_password", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_CHAP_PASSWORD] = { .name = "chap_password", .type = BLOBMSG_TYPE_STRING }, | ||||||
| @@ -37,23 +50,17 @@ static const struct blobmsg_policy radius_policy[__RADIUS_MAX] = { | |||||||
|         [RADIUS_CALLING_STATION] = { .name = "calling_station", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_CALLING_STATION] = { .name = "calling_station", .type = BLOBMSG_TYPE_STRING }, | ||||||
|         [RADIUS_NAS_IP] = { .name = "nas_ip", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_NAS_IP] = { .name = "nas_ip", .type = BLOBMSG_TYPE_STRING }, | ||||||
|         [RADIUS_NAS_ID] = { .name = "nas_id", .type = BLOBMSG_TYPE_STRING }, |         [RADIUS_NAS_ID] = { .name = "nas_id", .type = BLOBMSG_TYPE_STRING }, | ||||||
|  |         [RADIUS_TERMINATE_CAUSE] = { .name = "terminate_cause", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_SESSION_TIME] = { .name = "session_time", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_INPUT_OCTETS] = { .name = "input_octets", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_OUTPUT_OCTETS] = { .name = "output_octets", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_INPUT_GIGAWORDS] = { .name = "input_gigawords", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_OUTPUT_GIGAWORDS] = { .name = "output_gigawords", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_INPUT_PACKETS] = { .name = "input_packets", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_OUTPUT_PACKETS] = { .name = "output_packets", .type = BLOBMSG_TYPE_INT32 }, | ||||||
|  |         [RADIUS_LOGOFF_URL] = { .name = "logoff_url", .type = BLOBMSG_TYPE_STRING }, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static struct config { |  | ||||||
| 	char *type; |  | ||||||
| 	char *server; |  | ||||||
| 	char *username; |  | ||||||
| 	char *password; |  | ||||||
| 	char chap_password[17]; |  | ||||||
| 	char chap_challenge[16]; |  | ||||||
| 	char *acct_session; |  | ||||||
| 	struct sockaddr_in client_ip; |  | ||||||
| 	char *called_station; |  | ||||||
| 	char *calling_station; |  | ||||||
| 	struct sockaddr_in  nas_ip; |  | ||||||
| 	char *nas_id; |  | ||||||
| } config; |  | ||||||
|  |  | ||||||
| static struct blob_buf b = {}; | static struct blob_buf b = {}; | ||||||
| static struct blob_attr *tb[__RADIUS_MAX] = {}; | static struct blob_attr *tb[__RADIUS_MAX] = {}; | ||||||
|  |  | ||||||
| @@ -104,266 +111,158 @@ result(rc_handle const *rh, int accept, VALUE_PAIR *pair) | |||||||
| 	return accept; | 	return accept; | ||||||
| } | } | ||||||
|  |  | ||||||
| static void | static int | ||||||
| config_load(void) | radius(void) | ||||||
| { |  | ||||||
| 	if (tb[RADIUS_TYPE]) |  | ||||||
| 		config.type = blobmsg_get_string(tb[RADIUS_TYPE]); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_SERVER]) |  | ||||||
| 		config.server = blobmsg_get_string(tb[RADIUS_SERVER]); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_USERNAME]) |  | ||||||
| 		config.username = blobmsg_get_string(tb[RADIUS_USERNAME]); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_PASSWORD]) |  | ||||||
| 		config.password = blobmsg_get_string(tb[RADIUS_PASSWORD]); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_CHAP_PASSWORD]) { |  | ||||||
| 		*config.chap_password = '\0'; |  | ||||||
| 		str_to_hex(blobmsg_get_string(tb[RADIUS_CHAP_PASSWORD]), &config.chap_password[1], 16); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_CHAP_CHALLENGE]) |  | ||||||
| 		str_to_hex(blobmsg_get_string(tb[RADIUS_CHAP_CHALLENGE]), config.chap_challenge, 16); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_ACCT_SESSION]) |  | ||||||
| 		config.acct_session = blobmsg_get_string(tb[RADIUS_ACCT_SESSION]); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_CLIENT_IP]) { |  | ||||||
| 		inet_pton(AF_INET, blobmsg_get_string(tb[RADIUS_CLIENT_IP]), &(config.client_ip.sin_addr)); |  | ||||||
| 		config.client_ip.sin_addr.s_addr = ntohl(config.client_ip.sin_addr.s_addr); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_CALLED_STATION]) |  | ||||||
| 		config.called_station = blobmsg_get_string(tb[RADIUS_CALLED_STATION]); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_CALLING_STATION]) |  | ||||||
| 		config.calling_station = blobmsg_get_string(tb[RADIUS_CALLING_STATION]); |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_NAS_IP]) { |  | ||||||
| 		inet_pton(AF_INET, blobmsg_get_string(tb[RADIUS_NAS_IP]), &(config.nas_ip.sin_addr)); |  | ||||||
| 		config.nas_ip.sin_addr.s_addr = ntohl(config.nas_ip.sin_addr.s_addr); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if (tb[RADIUS_NAS_ID]) |  | ||||||
| 		config.nas_id = blobmsg_get_string(tb[RADIUS_NAS_ID]); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static rc_handle * |  | ||||||
| radius_init(void) |  | ||||||
| { | { | ||||||
|  | 	VALUE_PAIR *send = NULL, *received; | ||||||
|  | 	struct sockaddr_in client_ip = {}; | ||||||
|  | 	struct sockaddr_in nas_ip = {}; | ||||||
|  |         char chap_challenge[16] = {}; | ||||||
|  |         char chap_password[17] = {}; | ||||||
| 	rc_handle *rh = rc_new(); | 	rc_handle *rh = rc_new(); | ||||||
|  | 	uint32_t val; | ||||||
|  |  | ||||||
| 	if (rh == NULL) | 	if (rh == NULL) | ||||||
| 		return NULL; | 		return result(rh, 0, NULL);; | ||||||
|  |  | ||||||
| 	rh = rc_config_init(rh); | 	rh = rc_config_init(rh); | ||||||
| 	if (rh == NULL) | 	if (rh == NULL) | ||||||
| 		return NULL; | 		return result(rh, 0, NULL);; | ||||||
|  |  | ||||||
| 	rc_add_config(rh, "authserver", config.server, "code", __LINE__); | 	if (tb[RADIUS_SERVER]) | ||||||
|  | 		rc_add_config(rh, "authserver", blobmsg_get_string(tb[RADIUS_SERVER]), "code", __LINE__); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_ACCT_SERVER]) | ||||||
|  | 		rc_add_config(rh, "acctserver", blobmsg_get_string(tb[RADIUS_ACCT_SERVER]), "code", __LINE__); | ||||||
| 	rc_add_config(rh, "servers", "/tmp/radius.servers", "code", __LINE__); | 	rc_add_config(rh, "servers", "/tmp/radius.servers", "code", __LINE__); | ||||||
| 	rc_add_config(rh, "dictionary", "/etc/radcli/dictionary", "code", __LINE__); | 	rc_add_config(rh, "dictionary", "/etc/radcli/dictionary", "code", __LINE__); | ||||||
| 	rc_add_config(rh, "radius_timeout", "5", "code", __LINE__); | 	rc_add_config(rh, "radius_timeout", "2", "code", __LINE__); | ||||||
| 	rc_add_config(rh, "radius_retries", "1", "code", __LINE__); | 	rc_add_config(rh, "radius_retries", "1", "code", __LINE__); | ||||||
| 	rc_add_config(rh, "bindaddr", "*", "code", __LINE__); | 	rc_add_config(rh, "bindaddr", "*", "code", __LINE__); | ||||||
|  |  | ||||||
| 	if (rc_read_dictionary(rh, rc_conf_str(rh, "dictionary")) != 0) | 	if (rc_read_dictionary(rh, rc_conf_str(rh, "dictionary")) != 0) | ||||||
| 		return NULL; |  | ||||||
|  |  | ||||||
| 	return rh; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static int |  | ||||||
| auth(void) |  | ||||||
| { |  | ||||||
| 	VALUE_PAIR *send = NULL, *received; |  | ||||||
| 	rc_handle *rh = NULL; |  | ||||||
|  |  | ||||||
| 	if (!config.server || !config.username || !config.password) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	rh = radius_init(); |  | ||||||
| 	if (!rh) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_USER_NAME, config.username, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); | 		return result(rh, 0, NULL); | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_USER_PASSWORD, config.password, -1, 0) == NULL) | 	if (tb[RADIUS_ACCT_TYPE]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_ACCT_TYPE]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_STATUS_TYPE, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_USERNAME]) | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_USER_NAME, blobmsg_get_string(tb[RADIUS_USERNAME]), -1, 0) == NULL) | ||||||
|  | 	                return result(rh, 0, NULL); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_PASSWORD]) | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_USER_PASSWORD, blobmsg_get_string(tb[RADIUS_PASSWORD]), -1, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_CHAP_PASSWORD]) { | ||||||
|  | 		str_to_hex(blobmsg_get_string(tb[RADIUS_CHAP_PASSWORD]), &chap_password[1], 16); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_CHAP_PASSWORD, chap_password, 17, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_CHAP_CHALLENGE]) { | ||||||
|  | 		str_to_hex(blobmsg_get_string(tb[RADIUS_CHAP_CHALLENGE]), chap_challenge, 16); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_CHAP_CHALLENGE, chap_challenge, 16, 0) == NULL) | ||||||
|  | 	                return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_ACCT_SESSION]) | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_SESSION_ID, blobmsg_get_string(tb[RADIUS_ACCT_SESSION]), -1, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_CLIENT_IP]) { | ||||||
|  | 		inet_pton(AF_INET, blobmsg_get_string(tb[RADIUS_CLIENT_IP]), &(client_ip.sin_addr)); | ||||||
|  | 		client_ip.sin_addr.s_addr = ntohl(client_ip.sin_addr.s_addr); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_FRAMED_IP_ADDRESS, &client_ip.sin_addr, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_CALLED_STATION]) | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_CALLED_STATION_ID, blobmsg_get_string(tb[RADIUS_CALLED_STATION]), -1, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_LOGOFF_URL]) | ||||||
|  | 		if (rc_avpair_add(rh, &send, 3, blobmsg_get_string(tb[RADIUS_LOGOFF_URL]), -1, 14122) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_CALLING_STATION]) | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_CALLING_STATION_ID, blobmsg_get_string(tb[RADIUS_CALLING_STATION]), -1, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_NAS_IP]) { | ||||||
|  | 		inet_pton(AF_INET, blobmsg_get_string(tb[RADIUS_NAS_IP]), &(nas_ip.sin_addr)); | ||||||
|  | 		nas_ip.sin_addr.s_addr = ntohl(nas_ip.sin_addr.s_addr); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_NAS_IP_ADDRESS, &nas_ip.sin_addr, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_NAS_ID]) | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_NAS_IDENTIFIER, blobmsg_get_string(tb[RADIUS_NAS_ID]), -1, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_TERMINATE_CAUSE]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_TERMINATE_CAUSE]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_TERMINATE_CAUSE, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_SESSION_TIME]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_SESSION_TIME]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_SESSION_TIME, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_INPUT_OCTETS]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_INPUT_OCTETS]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_INPUT_OCTETS, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_OUTPUT_OCTETS]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_OUTPUT_OCTETS]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_OUTPUT_OCTETS, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_INPUT_GIGAWORDS]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_INPUT_GIGAWORDS]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_INPUT_GIGAWORDS, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_OUTPUT_GIGAWORDS]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_OUTPUT_GIGAWORDS]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_OUTPUT_GIGAWORDS, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_INPUT_PACKETS]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_INPUT_PACKETS]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_INPUT_PACKETS, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	if (tb[RADIUS_OUTPUT_PACKETS]) { | ||||||
|  | 		val = blobmsg_get_u32(tb[RADIUS_OUTPUT_PACKETS]); | ||||||
|  | 		if (rc_avpair_add(rh, &send, PW_ACCT_OUTPUT_PACKETS, &val, 4, 0) == NULL) | ||||||
|  | 			return result(rh, 0, NULL); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	val = 19; | ||||||
|  | 	if (rc_avpair_add(rh, &send, PW_NAS_PORT_TYPE, &val, 4, 0) == NULL) | ||||||
| 		return result(rh, 0, NULL); | 		return result(rh, 0, NULL); | ||||||
|  |  | ||||||
| 	rc_apply_config(rh); | 	rc_apply_config(rh); | ||||||
| 	if (rc_auth(rh, 0, send, &received, NULL) == OK_RC) | 	if (tb[RADIUS_ACCT] && blobmsg_get_bool(tb[RADIUS_ACCT])) { | ||||||
| 		return result(rh, 1, received); | 		if (rc_acct(rh, 0, send) == OK_RC) | ||||||
|  | 			return result(rh, 1, NULL); | ||||||
| 	return result(rh, 0, NULL); | 	} else { | ||||||
| } | 		if (rc_auth(rh, 0, send, &received, NULL) == OK_RC) | ||||||
|  | 			return result(rh, 1, received); | ||||||
| static int | 	} | ||||||
| uam_auth(void) |  | ||||||
| { |  | ||||||
| 	VALUE_PAIR *send = NULL, *received; |  | ||||||
| 	rc_handle *rh = NULL; |  | ||||||
|  |  | ||||||
| 	if (!config.server || !config.username || !config.password || |  | ||||||
| 	    !config.acct_session || !config.called_station || |  | ||||||
| 	    !config.calling_station || !config.nas_id) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	rh = radius_init(); |  | ||||||
| 	if (!rh) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_USER_NAME, config.username, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_USER_PASSWORD, config.password, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_ACCT_SESSION_ID, config.acct_session, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_FRAMED_IP_ADDRESS, &config.client_ip.sin_addr, 4, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	//if (rc_avpair_add(rh, &send, PW_NAS_PORT_TYPE, , -1, 0) == NULL) |  | ||||||
| 	//	return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	//if (rc_avpair_add(rh, &send, PW_NAS_PORT, , -1, 0) == NULL) |  | ||||||
| 	//	return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| //	if (rc_avpair_add(rh, &send, PW_NAS_PORT_ID_STRING, , -1, 0) == NULL) |  | ||||||
| //		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CALLED_STATION_ID, config.called_station, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CALLING_STATION_ID, config.calling_station, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_NAS_IP_ADDRESS, &config.nas_ip.sin_addr, 4, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_NAS_IDENTIFIER, config.nas_id, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	rc_apply_config(rh); |  | ||||||
| 	if (rc_auth(rh, 0, send, &received, NULL) == OK_RC) |  | ||||||
| 		return result(rh, 1, received); |  | ||||||
|  |  | ||||||
| 	return result(rh, 0, NULL); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static int |  | ||||||
| uam_chap_auth(void) |  | ||||||
| { |  | ||||||
| 	VALUE_PAIR *send = NULL, *received; |  | ||||||
| 	rc_handle *rh = NULL; |  | ||||||
|  |  | ||||||
| 	if (!config.server || !config.username || |  | ||||||
| 	    !config.acct_session || !config.called_station || |  | ||||||
| 	    !config.calling_station || !config.nas_id) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	rh = radius_init(); |  | ||||||
| 	if (!rh) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_USER_NAME, config.username, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CHAP_PASSWORD, config.chap_password, 17, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CHAP_CHALLENGE, config.chap_challenge, 16, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_ACCT_SESSION_ID, config.acct_session, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_FRAMED_IP_ADDRESS, &config.client_ip.sin_addr, 4, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	//if (rc_avpair_add(rh, &send, PW_NAS_PORT_TYPE, , -1, 0) == NULL) |  | ||||||
| 	//	return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	//if (rc_avpair_add(rh, &send, PW_NAS_PORT, , -1, 0) == NULL) |  | ||||||
| 	//	return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| //	if (rc_avpair_add(rh, &send, PW_NAS_PORT_ID_STRING, , -1, 0) == NULL) |  | ||||||
| //		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CALLED_STATION_ID, config.called_station, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CALLING_STATION_ID, config.calling_station, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_NAS_IP_ADDRESS, &config.nas_ip.sin_addr, 4, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_NAS_IDENTIFIER, config.nas_id, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	rc_apply_config(rh); |  | ||||||
| 	if (rc_auth(rh, 0, send, &received, NULL) == OK_RC) |  | ||||||
| 		return result(rh, 1, received); |  | ||||||
|  |  | ||||||
| 	return result(rh, 0, NULL); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| static int |  | ||||||
| uam_acct(void) |  | ||||||
| { |  | ||||||
| 	VALUE_PAIR *send = NULL, *received; |  | ||||||
| 	rc_handle *rh = NULL; |  | ||||||
|  |  | ||||||
| 	if (!config.server || !config.username || !config.password || |  | ||||||
| 	    !config.acct_session || !config.called_station || |  | ||||||
| 	    !config.calling_station || !config.nas_id) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	rh = radius_init(); |  | ||||||
| 	if (!rh) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_USER_NAME, config.username, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_USER_PASSWORD, config.password, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_ACCT_SESSION_ID, config.acct_session, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_FRAMED_IP_ADDRESS, &config.client_ip.sin_addr, 4, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	//if (rc_avpair_add(rh, &send, PW_NAS_PORT_TYPE, , -1, 0) == NULL) |  | ||||||
| 	//	return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	//if (rc_avpair_add(rh, &send, PW_NAS_PORT, , -1, 0) == NULL) |  | ||||||
| 	//	return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| //	if (rc_avpair_add(rh, &send, PW_NAS_PORT_ID_STRING, , -1, 0) == NULL) |  | ||||||
| //		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CALLED_STATION_ID, config.called_station, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_CALLING_STATION_ID, config.calling_station, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_NAS_IP_ADDRESS, &config.nas_ip.sin_addr, 4, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (rc_avpair_add(rh, &send, PW_NAS_IDENTIFIER, config.nas_id, -1, 0) == NULL) |  | ||||||
| 		return result(rh, 0, NULL); |  | ||||||
|  |  | ||||||
| 	rc_apply_config(rh); |  | ||||||
| 	if (rc_auth(rh, 0, send, &received, NULL) == OK_RC) |  | ||||||
| 		return result(rh, 1, received); |  | ||||||
|  |  | ||||||
| 	return result(rh, 0, NULL); | 	return result(rh, 0, NULL); | ||||||
| } | } | ||||||
| @@ -380,21 +279,5 @@ main(int argc, char **argv) | |||||||
|  |  | ||||||
| 	blobmsg_parse(radius_policy, __RADIUS_MAX, tb, blob_data(b.head), blob_len(b.head)); | 	blobmsg_parse(radius_policy, __RADIUS_MAX, tb, blob_data(b.head), blob_len(b.head)); | ||||||
|  |  | ||||||
| 	config_load(); | 	return radius(); | ||||||
| 	if (!config.type) |  | ||||||
| 		return result(NULL, 0, NULL); |  | ||||||
|  |  | ||||||
| 	if (!strcmp(config.type, "auth")) |  | ||||||
| 		return auth(); |  | ||||||
|  |  | ||||||
| 	if (!strcmp(config.type, "uam-auth")) |  | ||||||
| 		return uam_auth(); |  | ||||||
|  |  | ||||||
| 	if (!strcmp(config.type, "uam-chap-auth")) |  | ||||||
| 		return uam_chap_auth(); |  | ||||||
|  |  | ||||||
| 	if (!strcmp(config.type, "uam-acct")) |  | ||||||
| 		return uam_acct(); |  | ||||||
|  |  | ||||||
| 	return result(NULL, 0, NULL); |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -36,6 +36,10 @@ ALLWIFIBOARDS:= \ | |||||||
| 	sercomm-wallaby \ | 	sercomm-wallaby \ | ||||||
| 	edgecore-eap102 \ | 	edgecore-eap102 \ | ||||||
| 	edgecore-eap104 \ | 	edgecore-eap104 \ | ||||||
|  | 	liteon-wpx8324 \ | ||||||
|  | 	indio-um-310ax-v1 \ | ||||||
|  | 	indio-um-510axp-v1 \ | ||||||
|  | 	indio-um-510axm-v1 \ | ||||||
| 	plasmacloud-pax1800 \ | 	plasmacloud-pax1800 \ | ||||||
| 	wallys-dr6018 \ | 	wallys-dr6018 \ | ||||||
| 	wallys-dr6018-v4 \ | 	wallys-dr6018-v4 \ | ||||||
| @@ -240,6 +244,10 @@ $(eval $(call generate-ath11k-wifi-package,wallys-dr6018-v4,Wallys DR6018 V4)) | |||||||
| $(eval $(call generate-ath11k-wifi-package,edgecore-eap101,EdgeCore EAP101)) | $(eval $(call generate-ath11k-wifi-package,edgecore-eap101,EdgeCore EAP101)) | ||||||
| $(eval $(call generate-ath11k-wifi-package,edgecore-eap102,Edgecore EAP102)) | $(eval $(call generate-ath11k-wifi-package,edgecore-eap102,Edgecore EAP102)) | ||||||
| $(eval $(call generate-ath11k-wifi-package,edgecore-eap104,Edgecore EAP104)) | $(eval $(call generate-ath11k-wifi-package,edgecore-eap104,Edgecore EAP104)) | ||||||
|  | $(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-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,tplink-ex227,TP-Link EX227)) | $(eval $(call generate-ath11k-wifi-package,tplink-ex227,TP-Link EX227)) | ||||||
| $(eval $(call generate-ath11k-wifi-package,tplink-ex447,TP-Link EX447)) | $(eval $(call generate-ath11k-wifi-package,tplink-ex447,TP-Link EX447)) | ||||||
| $(eval $(call generate-ath11k-wifi-package,yuncore-ax840,YunCore AX840)) | $(eval $(call generate-ath11k-wifi-package,yuncore-ax840,YunCore AX840)) | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-indio-um-310ax-v1.bin.IPQ6018
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-indio-um-310ax-v1.bin.IPQ6018
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-indio-um-510axm-v1.bin.IPQ6018
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-indio-um-510axm-v1.bin.IPQ6018
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-indio-um-510axp-v1.bin.IPQ6018
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-indio-um-510axp-v1.bin.IPQ6018
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-liteon-wpx8324.bin.IPQ5018
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-liteon-wpx8324.bin.IPQ5018
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-liteon-wpx8324.bin.QCN6122
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								feeds/wifi-ax/ath11k-wifi/board-liteon-wpx8324.bin.QCN6122
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -120,7 +120,7 @@ Index: hostapd-2021-02-20-59e9794c/src/ap/sta_info.c | |||||||
|  	else |  	else | ||||||
|  #endif /* CONFIG_P2P */ |  #endif /* CONFIG_P2P */ | ||||||
| -		os_snprintf(buf, sizeof(buf), MACSTR, MAC2STR(sta->addr)); | -		os_snprintf(buf, sizeof(buf), MACSTR, MAC2STR(sta->addr)); | ||||||
| +		os_snprintf(buf, sizeof(buf), MACSTR " %d %d", MAC2STR(sta->addr), sta->bandwidth[0] / 1000, sta->bandwidth[1] / 1000); | +		os_snprintf(buf, sizeof(buf), MACSTR " %d %d", MAC2STR(sta->addr), sta->bandwidth[0] / 1000000, sta->bandwidth[1] / 1000000); | ||||||
|   |   | ||||||
|  	if (hapd->sta_authorized_cb) |  	if (hapd->sta_authorized_cb) | ||||||
|  		hapd->sta_authorized_cb(hapd->sta_authorized_cb_ctx, |  		hapd->sta_authorized_cb(hapd->sta_authorized_cb_ctx, | ||||||
|   | |||||||
| @@ -533,7 +533,7 @@ mac80211_generate_mac() { | |||||||
| 	local ref="$(cat /sys/class/ieee80211/${phy}/macaddress)" | 	local ref="$(cat /sys/class/ieee80211/${phy}/macaddress)" | ||||||
| 	local mask="$(cat /sys/class/ieee80211/${phy}/address_mask)" | 	local mask="$(cat /sys/class/ieee80211/${phy}/address_mask)" | ||||||
|  |  | ||||||
| 	[ "$mask" = "00:00:00:00:00:00" ] && { | 	[ "$mask" = "00:00:00:00:00:00" -a "$multiple_bssid" != 1 ] && { | ||||||
| 		mask="ff:ff:ff:ff:ff:ff"; | 		mask="ff:ff:ff:ff:ff:ff"; | ||||||
|  |  | ||||||
| 		[ "$(wc -l < /sys/class/ieee80211/${phy}/addresses)" -gt $id ] && { | 		[ "$(wc -l < /sys/class/ieee80211/${phy}/addresses)" -gt $id ] && { | ||||||
|   | |||||||
| @@ -0,0 +1,39 @@ | |||||||
|  | From: Felix Fietkau <nbd@nbd.name> | ||||||
|  | Date: Wed, 10 Nov 2021 22:22:01 +0100 | ||||||
|  | Subject: [PATCH] mac80211: drop check for DONT_REORDER in | ||||||
|  |  __ieee80211_select_queue | ||||||
|  |  | ||||||
|  | When __ieee80211_select_queue is called, skb->cb has not been cleared yet, | ||||||
|  | which means that info->control.flags can contain garbage. | ||||||
|  | In some cases this leads to IEEE80211_TX_CTRL_DONT_REORDER being set, causing | ||||||
|  | packets marked for other queues to randomly end up in BE instead. | ||||||
|  |  | ||||||
|  | This flag only needs to be checked in ieee80211_select_queue_80211, since | ||||||
|  | the radiotap parser is the only piece of code that sets it | ||||||
|  |  | ||||||
|  | Fixes: 66d06c84730c ("mac80211: adhere to Tx control flag that prevents frame reordering") | ||||||
|  | Cc: stable@vger.kernel.org | ||||||
|  | Signed-off-by: Felix Fietkau <nbd@nbd.name> | ||||||
|  | Link: https://lore.kernel.org/r/20211110212201.35452-1-nbd@nbd.name | ||||||
|  | Signed-off-by: Johannes Berg <johannes.berg@intel.com> | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | --- a/net/mac80211/wme.c | ||||||
|  | +++ b/net/mac80211/wme.c | ||||||
|  | @@ -143,7 +143,6 @@ u16 ieee80211_select_queue_80211(struct | ||||||
|  |  u16 __ieee80211_select_queue(struct ieee80211_sub_if_data *sdata, | ||||||
|  |  			     struct sta_info *sta, struct sk_buff *skb) | ||||||
|  |  { | ||||||
|  | -	struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); | ||||||
|  |  	struct mac80211_qos_map *qos_map; | ||||||
|  |  	bool qos; | ||||||
|  |   | ||||||
|  | @@ -156,7 +155,7 @@ u16 __ieee80211_select_queue(struct ieee | ||||||
|  |  	else | ||||||
|  |  		qos = false; | ||||||
|  |   | ||||||
|  | -	if (!qos || (info->control.flags & IEEE80211_TX_CTRL_DONT_REORDER)) { | ||||||
|  | +	if (!qos) { | ||||||
|  |  		skb->priority = 0; /* required for correct WPA/11i MIC */ | ||||||
|  |  		return IEEE80211_AC_BE; | ||||||
|  |  	} | ||||||
| @@ -0,0 +1,12 @@ | |||||||
|  | Index: backports-20210222_001-4.4.60-b157d2276/drivers/net/wireless/ath/ath11k/mac.c | ||||||
|  | =================================================================== | ||||||
|  | --- backports-20210222_001-4.4.60-b157d2276.orig/drivers/net/wireless/ath/ath11k/mac.c | ||||||
|  | +++ backports-20210222_001-4.4.60-b157d2276/drivers/net/wireless/ath/ath11k/mac.c | ||||||
|  | @@ -9356,6 +9356,7 @@ static int __ath11k_mac_register(struct | ||||||
|  |  	wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_CQM_RSSI_LIST); | ||||||
|  |  	wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_STA_TX_PWR); | ||||||
|  |  	wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_BSS_COLOR); | ||||||
|  | +	wiphy_ext_feature_set(ar->hw->wiphy, NL80211_EXT_FEATURE_CAN_REPLACE_PTK0); | ||||||
|  |   | ||||||
|  |  	if (test_bit(WMI_TLV_SERVICE_SCAN_PHYMODE_SUPPORT, | ||||||
|  |  		     ar->ab->wmi_ab.svc_map)) | ||||||
| @@ -0,0 +1,33 @@ | |||||||
|  | From 1ac3763815e804eacc0977afb420f015a78f8d72 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: John Crispin <john@phrozen.org> | ||||||
|  | Date: Fri, 23 Sep 2022 08:48:38 +0200 | ||||||
|  | Subject: [PATCH] backport-5.4: add a BPF off-by-one fix | ||||||
|  |  | ||||||
|  | Signed-off-by: John Crispin <john@phrozen.org> | ||||||
|  | --- | ||||||
|  |  .../backport-5.4/999-bpf-off-by-one-backport.patch  | 13 +++++++++++++ | ||||||
|  |  1 file changed, 13 insertions(+) | ||||||
|  |  create mode 100644 target/linux/generic/backport-5.4/999-bpf-off-by-one-backport.patch | ||||||
|  |  | ||||||
|  | diff --git a/target/linux/generic/backport-5.4/999-bpf-off-by-one-backport.patch b/target/linux/generic/backport-5.4/999-bpf-off-by-one-backport.patch | ||||||
|  | new file mode 100644 | ||||||
|  | index 0000000000..271eac67da | ||||||
|  | --- /dev/null | ||||||
|  | +++ b/target/linux/generic/backport-5.4/999-bpf-off-by-one-backport.patch | ||||||
|  | @@ -0,0 +1,13 @@ | ||||||
|  | +Index: linux-5.4.158/kernel/bpf/verifier.c | ||||||
|  | +=================================================================== | ||||||
|  | +--- linux-5.4.158.orig/kernel/bpf/verifier.c | ||||||
|  | ++++ linux-5.4.158/kernel/bpf/verifier.c | ||||||
|  | +@@ -5372,7 +5372,7 @@ static void find_good_pkt_pointers(struc | ||||||
|  | +  | ||||||
|  | + 	new_range = dst_reg->off; | ||||||
|  | + 	if (range_right_open) | ||||||
|  | +-		new_range--; | ||||||
|  | ++		new_range++; | ||||||
|  | +  | ||||||
|  | + 	/* Examples for register markings: | ||||||
|  | + 	 * | ||||||
|  | --  | ||||||
|  | 2.25.1 | ||||||
|  |  | ||||||
| @@ -1,207 +0,0 @@ | |||||||
| From 2238d38eca53468d8a52209478f801580a54c1ed Mon Sep 17 00:00:00 2001 |  | ||||||
| From: John Crispin <john@phrozen.org> |  | ||||||
| Date: Wed, 17 Aug 2022 16:31:37 +0200 |  | ||||||
| Subject: [PATCH] uhttpd: backport 2 fixes |  | ||||||
|  |  | ||||||
| Signed-off-by: John Crispin <john@phrozen.org> |  | ||||||
| --- |  | ||||||
|  .../services/uhttpd/patches/error.patch       | 165 ++++++++++++++++++ |  | ||||||
|  .../services/uhttpd/patches/path.patch        |  14 ++ |  | ||||||
|  2 files changed, 179 insertions(+) |  | ||||||
|  create mode 100644 package/network/services/uhttpd/patches/error.patch |  | ||||||
|  create mode 100644 package/network/services/uhttpd/patches/path.patch |  | ||||||
|  |  | ||||||
| diff --git a/package/network/services/uhttpd/patches/error.patch b/package/network/services/uhttpd/patches/error.patch |  | ||||||
| new file mode 100644 |  | ||||||
| index 0000000000..374aca0a51 |  | ||||||
| --- /dev/null |  | ||||||
| +++ b/package/network/services/uhttpd/patches/error.patch |  | ||||||
| @@ -0,0 +1,165 @@ |  | ||||||
| +From c5eac5d27fb3967d796fe3c75f4cc1bdcd18ed01 Mon Sep 17 00:00:00 2001 |  | ||||||
| +From: Jo-Philipp Wich <jo@mein.io> |  | ||||||
| +Date: Wed, 10 Aug 2022 21:00:32 +0200 |  | ||||||
| +Subject: [PATCH] file: support using dynamic script handlers as error pages |  | ||||||
| + |  | ||||||
| +Rework the current request handler code to not require an error page path |  | ||||||
| +to be an actual file system entity. |  | ||||||
| + |  | ||||||
| +Signed-off-by: Jo-Philipp Wich <jo@mein.io> |  | ||||||
| +--- |  | ||||||
| + file.c | 42 ++++++++++++++++++++++++++---------------- |  | ||||||
| + 1 file changed, 26 insertions(+), 16 deletions(-) |  | ||||||
| + |  | ||||||
| +diff --git a/file.c b/file.c |  | ||||||
| +index 1548900..ac781c1 100644 |  | ||||||
| +--- a/file.c |  | ||||||
| ++++ b/file.c |  | ||||||
| +@@ -49,6 +49,7 @@ struct deferred_request { |  | ||||||
| + 	struct dispatch_handler *d; |  | ||||||
| + 	struct client *cl; |  | ||||||
| + 	struct path_info pi; |  | ||||||
| ++	char *url; |  | ||||||
| + 	bool called, path; |  | ||||||
| + }; |  | ||||||
| +  |  | ||||||
| +@@ -631,7 +632,7 @@ static void uh_file_data(struct client *cl, struct path_info *pi, int fd) |  | ||||||
| + 	file_write_cb(cl); |  | ||||||
| + } |  | ||||||
| +  |  | ||||||
| +-static bool __handle_file_request(struct client *cl, char *url); |  | ||||||
| ++static bool __handle_file_request(struct client *cl, char *url, bool is_error_handler); |  | ||||||
| +  |  | ||||||
| + static void uh_file_request(struct client *cl, const char *url, |  | ||||||
| + 			    struct path_info *pi, struct blob_attr **tb) |  | ||||||
| +@@ -684,7 +685,7 @@ error: |  | ||||||
| + 		req->redirect_status = 403; |  | ||||||
| + 		error_handler = alloca(strlen(conf.error_handler) + 1); |  | ||||||
| + 		strcpy(error_handler, conf.error_handler); |  | ||||||
| +-		if (__handle_file_request(cl, error_handler)) |  | ||||||
| ++		if (__handle_file_request(cl, error_handler, true)) |  | ||||||
| + 			return; |  | ||||||
| + 	} |  | ||||||
| +  |  | ||||||
| +@@ -728,10 +729,8 @@ dispatch_find(const char *url, struct path_info *pi) |  | ||||||
| + } |  | ||||||
| +  |  | ||||||
| + static void |  | ||||||
| +-uh_invoke_script(struct client *cl, struct dispatch_handler *d, struct path_info *pi) |  | ||||||
| ++uh_invoke_script(struct client *cl, struct dispatch_handler *d, char *url, struct path_info *pi) |  | ||||||
| + { |  | ||||||
| +-	char *url = blobmsg_data(blob_data(cl->hdr.head)); |  | ||||||
| +- |  | ||||||
| + 	n_requests++; |  | ||||||
| + 	d->handle_request(cl, url, pi); |  | ||||||
| + } |  | ||||||
| +@@ -752,7 +751,7 @@ static void uh_complete_request(struct client *cl) |  | ||||||
| + 		cl = dr->cl; |  | ||||||
| + 		dr->called = true; |  | ||||||
| + 		cl->dispatch.data_blocked = false; |  | ||||||
| +-		uh_invoke_script(cl, dr->d, dr->path ? &dr->pi : NULL); |  | ||||||
| ++		uh_invoke_script(cl, dr->d, dr->url, dr->path ? &dr->pi : NULL); |  | ||||||
| + 		client_poll_post_data(cl); |  | ||||||
| + 		ustream_poll(cl->us); |  | ||||||
| + 	} |  | ||||||
| +@@ -787,10 +786,10 @@ static int field_len(const char *ptr) |  | ||||||
| + 	_field(query) |  | ||||||
| +  |  | ||||||
| + static void |  | ||||||
| +-uh_defer_script(struct client *cl, struct dispatch_handler *d, struct path_info *pi) |  | ||||||
| ++uh_defer_script(struct client *cl, struct dispatch_handler *d, char *url, struct path_info *pi) |  | ||||||
| + { |  | ||||||
| + 	struct deferred_request *dr; |  | ||||||
| +-	char *_root, *_phys, *_name, *_info, *_query; |  | ||||||
| ++	char *_url, *_root, *_phys, *_name, *_info, *_query; |  | ||||||
| +  |  | ||||||
| + 	cl->dispatch.req_free = uh_free_pending_request; |  | ||||||
| +  |  | ||||||
| +@@ -798,7 +797,7 @@ uh_defer_script(struct client *cl, struct dispatch_handler *d, struct path_info |  | ||||||
| + 		/* allocate enough memory to duplicate all path_info strings in one block */ |  | ||||||
| + #undef _field |  | ||||||
| + #define _field(_name) &_##_name, field_len(pi->_name), |  | ||||||
| +-		dr = calloc_a(sizeof(*dr), path_info_fields NULL); |  | ||||||
| ++		dr = calloc_a(sizeof(*dr), &_url, strlen(url), path_info_fields NULL); |  | ||||||
| +  |  | ||||||
| + 		memcpy(&dr->pi, pi, sizeof(*pi)); |  | ||||||
| + 		dr->path = true; |  | ||||||
| +@@ -808,11 +807,12 @@ uh_defer_script(struct client *cl, struct dispatch_handler *d, struct path_info |  | ||||||
| + #define _field(_name) if (pi->_name) dr->pi._name = strcpy(_##_name, pi->_name); |  | ||||||
| + 		path_info_fields |  | ||||||
| + 	} else { |  | ||||||
| +-		dr = calloc(1, sizeof(*dr)); |  | ||||||
| ++		dr = calloc_a(sizeof(*dr), &_url, strlen(url), NULL); |  | ||||||
| + 	} |  | ||||||
| +  |  | ||||||
| + 	cl->dispatch.req_data = dr; |  | ||||||
| + 	cl->dispatch.data_blocked = true; |  | ||||||
| ++	dr->url = strcpy(_url, url); |  | ||||||
| + 	dr->cl = cl; |  | ||||||
| + 	dr->d = d; |  | ||||||
| + 	list_add(&dr->list, &pending_requests); |  | ||||||
| +@@ -825,13 +825,13 @@ uh_invoke_handler(struct client *cl, struct dispatch_handler *d, char *url, stru |  | ||||||
| + 		return d->handle_request(cl, url, pi); |  | ||||||
| +  |  | ||||||
| + 	if (n_requests >= conf.max_script_requests) |  | ||||||
| +-		return uh_defer_script(cl, d, pi); |  | ||||||
| ++		return uh_defer_script(cl, d, url, pi); |  | ||||||
| +  |  | ||||||
| + 	cl->dispatch.req_free = uh_complete_request; |  | ||||||
| +-	uh_invoke_script(cl, d, pi); |  | ||||||
| ++	uh_invoke_script(cl, d, url, pi); |  | ||||||
| + } |  | ||||||
| +  |  | ||||||
| +-static bool __handle_file_request(struct client *cl, char *url) |  | ||||||
| ++static bool __handle_file_request(struct client *cl, char *url, bool is_error_handler) |  | ||||||
| + { |  | ||||||
| + 	static const struct blobmsg_policy hdr_policy[__HDR_MAX] = { |  | ||||||
| + 		[HDR_AUTHORIZATION] = { "authorization", BLOBMSG_TYPE_STRING }, |  | ||||||
| +@@ -846,6 +846,16 @@ static bool __handle_file_request(struct client *cl, char *url) |  | ||||||
| + 	struct path_info *pi; |  | ||||||
| + 	char *user, *pass, *auth; |  | ||||||
| +  |  | ||||||
| ++	if (is_error_handler) { |  | ||||||
| ++		d = dispatch_find(url, NULL); |  | ||||||
| ++ |  | ||||||
| ++		if (d) { |  | ||||||
| ++			uh_invoke_handler(cl, d, url, NULL); |  | ||||||
| ++ |  | ||||||
| ++			return true; |  | ||||||
| ++		} |  | ||||||
| ++	} |  | ||||||
| ++ |  | ||||||
| + 	pi = uh_path_lookup(cl, url); |  | ||||||
| + 	if (!pi) |  | ||||||
| + 		return false; |  | ||||||
| +@@ -931,7 +941,7 @@ void uh_handle_request(struct client *cl) |  | ||||||
| + 	if (d) |  | ||||||
| + 		return uh_invoke_handler(cl, d, url, NULL); |  | ||||||
| +  |  | ||||||
| +-	if (__handle_file_request(cl, url)) |  | ||||||
| ++	if (__handle_file_request(cl, url, false)) |  | ||||||
| + 		return; |  | ||||||
| +  |  | ||||||
| + 	if (uh_handler_run(cl, &url, true)) { |  | ||||||
| +@@ -939,7 +949,7 @@ void uh_handle_request(struct client *cl) |  | ||||||
| + 			return; |  | ||||||
| +  |  | ||||||
| + 		uh_handler_run(cl, &url, false); |  | ||||||
| +-		if (__handle_file_request(cl, url)) |  | ||||||
| ++		if (__handle_file_request(cl, url, false)) |  | ||||||
| + 			return; |  | ||||||
| + 	} |  | ||||||
| +  |  | ||||||
| +@@ -947,7 +957,7 @@ void uh_handle_request(struct client *cl) |  | ||||||
| + 	if (conf.error_handler) { |  | ||||||
| + 		error_handler = alloca(strlen(conf.error_handler) + 1); |  | ||||||
| + 		strcpy(error_handler, conf.error_handler); |  | ||||||
| +-		if (__handle_file_request(cl, error_handler)) |  | ||||||
| ++		if (__handle_file_request(cl, error_handler, true)) |  | ||||||
| + 			return; |  | ||||||
| + 	} |  | ||||||
| +  |  | ||||||
| +--  |  | ||||||
| +2.35.1 |  | ||||||
| + |  | ||||||
| + |  | ||||||
| diff --git a/package/network/services/uhttpd/patches/path.patch b/package/network/services/uhttpd/patches/path.patch |  | ||||||
| new file mode 100644 |  | ||||||
| index 0000000000..27eebb56d8 |  | ||||||
| --- /dev/null |  | ||||||
| +++ b/package/network/services/uhttpd/patches/path.patch |  | ||||||
| @@ -0,0 +1,14 @@ |  | ||||||
| +diff --git a/utils.c b/utils.c |  | ||||||
| +index 142a410..6502d94 100644 |  | ||||||
| +--- a/utils.c |  | ||||||
| ++++ b/utils.c |  | ||||||
| +@@ -215,7 +215,7 @@ bool uh_path_match(const char *prefix, const char *url) |  | ||||||
| + 	if (strncmp(url, prefix, len) != 0) |  | ||||||
| + 		return false; |  | ||||||
| +  |  | ||||||
| +-	return url[len] == '/' || url[len] == 0; |  | ||||||
| ++	return url[len] == '/' || url[len] == '?' || url[len] == 0; |  | ||||||
| + } |  | ||||||
| +  |  | ||||||
| + char *uh_split_header(char *str) |  | ||||||
| + |  | ||||||
| --  |  | ||||||
| 2.25.1 |  | ||||||
|  |  | ||||||
| @@ -1,20 +1,24 @@ | |||||||
| From 3cd6c3dc3cb38799bce6e728d3794d50b829678b Mon Sep 17 00:00:00 2001 | From 3a4a31f26f1699b9a4a7d6684a380a990bb9ac86 Mon Sep 17 00:00:00 2001 | ||||||
| From: John Crispin <john@phrozen.org> | From: John Crispin <john@phrozen.org> | ||||||
| Date: Wed, 10 Aug 2022 09:50:13 +0200 | Date: Wed, 10 Aug 2022 09:50:13 +0200 | ||||||
| Subject: [PATCH] uhttpd: update to latest HEAD | Subject: [PATCH 85/85] uhttpd: update to latest HEAD | ||||||
|  |  | ||||||
| Signed-off-by: John Crispin <john@phrozen.org> | Signed-off-by: John Crispin <john@phrozen.org> | ||||||
| --- | --- | ||||||
|  package/network/services/uhttpd/Makefile      | 44 ++++++++++++++----- |  package/network/services/uhttpd/Makefile      |  43 +++-- | ||||||
|  .../services/uhttpd/files/uhttpd.config       |  8 ++++ |  .../services/uhttpd/files/uhttpd.config       |   8 + | ||||||
|  .../network/services/uhttpd/files/uhttpd.init | 15 +++++++ |  .../network/services/uhttpd/files/uhttpd.init |  15 ++ | ||||||
|  3 files changed, 57 insertions(+), 10 deletions(-) |  .../services/uhttpd/patches/error.patch       | 165 ------------------ | ||||||
|  |  .../services/uhttpd/patches/path.patch        |  14 -- | ||||||
|  |  5 files changed, 56 insertions(+), 189 deletions(-) | ||||||
|  |  delete mode 100644 package/network/services/uhttpd/patches/error.patch | ||||||
|  |  delete mode 100644 package/network/services/uhttpd/patches/path.patch | ||||||
|  |  | ||||||
| diff --git a/package/network/services/uhttpd/Makefile b/package/network/services/uhttpd/Makefile | diff --git a/package/network/services/uhttpd/Makefile b/package/network/services/uhttpd/Makefile | ||||||
| index de666a480d..860b41f1a4 100644 | index de666a480d..0ae076ca8b 100644 | ||||||
| --- a/package/network/services/uhttpd/Makefile | --- a/package/network/services/uhttpd/Makefile | ||||||
| +++ b/package/network/services/uhttpd/Makefile | +++ b/package/network/services/uhttpd/Makefile | ||||||
| @@ -8,19 +8,19 @@ | @@ -8,19 +8,18 @@ | ||||||
|  include $(TOPDIR)/rules.mk |  include $(TOPDIR)/rules.mk | ||||||
|   |   | ||||||
|  PKG_NAME:=uhttpd |  PKG_NAME:=uhttpd | ||||||
| @@ -27,8 +31,7 @@ index de666a480d..860b41f1a4 100644 | |||||||
| -PKG_SOURCE_VERSION:=15346de8d3ba422002496526ee24c62a3601ab8c | -PKG_SOURCE_VERSION:=15346de8d3ba422002496526ee24c62a3601ab8c | ||||||
| -PKG_MIRROR_HASH:=819424d071ed7c8888f9ca66f679907831becc59a67dd4a5ec521d5fba0a3171 | -PKG_MIRROR_HASH:=819424d071ed7c8888f9ca66f679907831becc59a67dd4a5ec521d5fba0a3171 | ||||||
| +PKG_SOURCE_DATE:=2022-06-01 | +PKG_SOURCE_DATE:=2022-06-01 | ||||||
| +PKG_SOURCE_VERSION:=d59d732a10a4a2b9f18af6dfc3facf696108f31e | +PKG_SOURCE_VERSION:=e3395cd90bed9b7b9fc319e79528fedcc0d947fe | ||||||
| +PKG_MIRROR_HASH:=31caa46ca025a1a7657bd5252d59d4a67d0f1c4b87c15a1bc94663ba3cc899ee |  | ||||||
|  PKG_MAINTAINER:=Felix Fietkau <nbd@nbd.name> |  PKG_MAINTAINER:=Felix Fietkau <nbd@nbd.name> | ||||||
|  PKG_LICENSE:=ISC |  PKG_LICENSE:=ISC | ||||||
|   |   | ||||||
| @@ -39,7 +42,7 @@ index de666a480d..860b41f1a4 100644 | |||||||
|   |   | ||||||
|  include $(INCLUDE_DIR)/package.mk |  include $(INCLUDE_DIR)/package.mk | ||||||
|  include $(INCLUDE_DIR)/cmake.mk |  include $(INCLUDE_DIR)/cmake.mk | ||||||
| @@ -49,8 +49,20 @@ define Package/uhttpd/config | @@ -49,8 +48,20 @@ define Package/uhttpd/config | ||||||
|      depends on PACKAGE_uhttpd-mod-lua |      depends on PACKAGE_uhttpd-mod-lua | ||||||
|      bool "Enable Integrated Lua interpreter" |      bool "Enable Integrated Lua interpreter" | ||||||
|  	default y |  	default y | ||||||
| @@ -60,7 +63,7 @@ index de666a480d..860b41f1a4 100644 | |||||||
|  define Package/uhttpd-mod-lua |  define Package/uhttpd-mod-lua | ||||||
|    $(Package/uhttpd/default) |    $(Package/uhttpd/default) | ||||||
|    TITLE+= (Lua plugin) |    TITLE+= (Lua plugin) | ||||||
| @@ -73,19 +85,25 @@ define Package/uhttpd-mod-ubus/description | @@ -73,19 +84,25 @@ define Package/uhttpd-mod-ubus/description | ||||||
|   session.* namespace and procedures. |   session.* namespace and procedures. | ||||||
|  endef |  endef | ||||||
|   |   | ||||||
| @@ -91,7 +94,7 @@ index de666a480d..860b41f1a4 100644 | |||||||
|   |   | ||||||
|  define Package/uhttpd/install |  define Package/uhttpd/install | ||||||
|  	$(INSTALL_DIR) $(1)/etc/init.d |  	$(INSTALL_DIR) $(1)/etc/init.d | ||||||
| @@ -108,7 +126,13 @@ define Package/uhttpd-mod-ubus/install | @@ -108,7 +125,13 @@ define Package/uhttpd-mod-ubus/install | ||||||
|  	$(INSTALL_DATA) ./files/ubus.default $(1)/etc/uci-defaults/00_uhttpd_ubus |  	$(INSTALL_DATA) ./files/ubus.default $(1)/etc/uci-defaults/00_uhttpd_ubus | ||||||
|  endef |  endef | ||||||
|   |   | ||||||
| @@ -157,6 +160,4 @@ index 30fd7b4259..8dbc23f59c 100755 | |||||||
|  	append_arg "$cfg" script_timeout "-t" |  	append_arg "$cfg" script_timeout "-t" | ||||||
|  	append_arg "$cfg" network_timeout "-T" |  	append_arg "$cfg" network_timeout "-T" | ||||||
|  	append_arg "$cfg" http_keepalive "-k" |  	append_arg "$cfg" http_keepalive "-k" | ||||||
| --  |  | ||||||
| 2.25.1 |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -0,0 +1,30 @@ | |||||||
|  | From aa0404504cff8bcdac40d8e9b3ec708d2079d705 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: John Crispin <john@phrozen.org> | ||||||
|  | Date: Thu, 22 Sep 2022 15:12:20 +0200 | ||||||
|  | Subject: [PATCH] base-files: add ucidef_set_wifi_country | ||||||
|  |  | ||||||
|  | Signed-off-by: John Crispin <john@phrozen.org> | ||||||
|  | --- | ||||||
|  |  package/base-files/files/lib/functions/uci-defaults.sh | 6 ++++++ | ||||||
|  |  1 file changed, 6 insertions(+) | ||||||
|  |  | ||||||
|  | diff --git a/package/base-files/files/lib/functions/uci-defaults.sh b/package/base-files/files/lib/functions/uci-defaults.sh | ||||||
|  | index ff3433a0a2..3bc8e6bb1c 100644 | ||||||
|  | --- a/package/base-files/files/lib/functions/uci-defaults.sh | ||||||
|  | +++ b/package/base-files/files/lib/functions/uci-defaults.sh | ||||||
|  | @@ -627,6 +627,12 @@ ucidef_set_wifi_scanning() { | ||||||
|  |  	json_select .. | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +ucidef_set_wifi_country() { | ||||||
|  | +	json_select_object wifi | ||||||
|  | +		json_add_string country $1  | ||||||
|  | +	json_select .. | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  ucidef_set_ntpserver() { | ||||||
|  |  	local server | ||||||
|  |   | ||||||
|  | --  | ||||||
|  | 2.25.1 | ||||||
|  |  | ||||||
| @@ -137,7 +137,7 @@ index 0000000000..f2f4a933d7 | |||||||
| + 	else | + 	else | ||||||
| + #endif /* CONFIG_P2P */ | + #endif /* CONFIG_P2P */ | ||||||
| +-		os_snprintf(buf, sizeof(buf), MACSTR, MAC2STR(sta->addr)); | +-		os_snprintf(buf, sizeof(buf), MACSTR, MAC2STR(sta->addr)); | ||||||
| ++		os_snprintf(buf, sizeof(buf), MACSTR " %d %d", MAC2STR(sta->addr), sta->bandwidth[0] / 1000, sta->bandwidth[1] / 1000); | ++		os_snprintf(buf, sizeof(buf), MACSTR " %d %d", MAC2STR(sta->addr), sta->bandwidth[0] / 1000000, sta->bandwidth[1] / 1000000); | ||||||
| +  | +  | ||||||
| + 	if (hapd->sta_authorized_cb) | + 	if (hapd->sta_authorized_cb) | ||||||
| + 		hapd->sta_authorized_cb(hapd->sta_authorized_cb_ctx, | + 		hapd->sta_authorized_cb(hapd->sta_authorized_cb_ctx, | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								profiles/indio_um-310ax-v1.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								profiles/indio_um-310ax-v1.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | --- | ||||||
|  | profile: indio_um-310ax-v1  | ||||||
|  | target: ipq807x | ||||||
|  | subtarget: ipq60xx | ||||||
|  | description: Build image for the Indio UM-310AX V1  | ||||||
|  | image: bin/targets/ipq807x/ipq60xx/openwrt-ipq807x-indio-um-310ax-v1-squashfs-sysupgrade.tar | ||||||
|  | feeds: | ||||||
|  |   - name: ipq807x | ||||||
|  |     path: ../../feeds/ipq807x | ||||||
|  | include: | ||||||
|  |   - wifi-ax | ||||||
|  |   - ucentral-ap | ||||||
							
								
								
									
										12
									
								
								profiles/indio_um-510axm-v1.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								profiles/indio_um-510axm-v1.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | --- | ||||||
|  | profile: indio_um-510axm-v1  | ||||||
|  | target: ipq807x | ||||||
|  | subtarget: ipq60xx | ||||||
|  | description: Build image for the Indio UM-510AXM V1  | ||||||
|  | image: bin/targets/ipq807x/ipq60xx/openwrt-ipq807x-indio-um-510axm-v1-squashfs-sysupgrade.tar | ||||||
|  | feeds: | ||||||
|  |   - name: ipq807x | ||||||
|  |     path: ../../feeds/ipq807x | ||||||
|  | include: | ||||||
|  |   - wifi-ax | ||||||
|  |   - ucentral-ap | ||||||
							
								
								
									
										12
									
								
								profiles/indio_um-510axp-v1.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								profiles/indio_um-510axp-v1.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | --- | ||||||
|  | profile: indio_um-510axp-v1  | ||||||
|  | target: ipq807x | ||||||
|  | subtarget: ipq60xx | ||||||
|  | description: Build image for the Indio UM-510AXP V1  | ||||||
|  | image: bin/targets/ipq807x/ipq60xx/openwrt-ipq807x-indio-um-510axp-v1-squashfs-sysupgrade.tar | ||||||
|  | feeds: | ||||||
|  |   - name: ipq807x | ||||||
|  |     path: ../../feeds/ipq807x | ||||||
|  | include: | ||||||
|  |   - wifi-ax | ||||||
|  |   - ucentral-ap | ||||||
							
								
								
									
										16
									
								
								profiles/liteon_wpx8324.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								profiles/liteon_wpx8324.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | --- | ||||||
|  | profile: liteon_wpx8324 | ||||||
|  | target: ipq807x | ||||||
|  | subtarget: ipq50xx | ||||||
|  | description: Build image for the Liteon WPX8324 | ||||||
|  | image: bin/targets/ipq807x/ipq50xx/openwrt-ipq807x-liteon_wpx8324-squashfs-sysupgrade.tar | ||||||
|  | feeds: | ||||||
|  |   - name: ipq807x | ||||||
|  |     path: ../../feeds/ipq807x | ||||||
|  | include: | ||||||
|  |   - wifi-ax | ||||||
|  |   - ucentral-ap | ||||||
|  | diffconfig: | | ||||||
|  |   CONFIG_KERNEL_IPQ_MEM_PROFILE=512 | ||||||
|  |   CONFIG_BUSYBOX_CUSTOM=y | ||||||
|  |   CONFIG_BUSYBOX_CONFIG_STTY=y | ||||||
		Reference in New Issue
	
	Block a user