mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-11-02 19:37:51 +00:00 
			
		
		
		
	Compare commits
	
		
			131 Commits
		
	
	
		
			v2.7.0-rc1
			...
			v2.8.0-rc5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					7997df122a | ||
| 
						 | 
					0c03b63c0f | ||
| 
						 | 
					5ed2f1d964 | ||
| 
						 | 
					515793450e | ||
| 
						 | 
					541e9b0b4f | ||
| 
						 | 
					24611df4c6 | ||
| 
						 | 
					083010d43c | ||
| 
						 | 
					f9b46fd6b0 | ||
| 
						 | 
					74eb6f96ab | ||
| 
						 | 
					4967fcd2be | ||
| 
						 | 
					e973110de7 | ||
| 
						 | 
					a62503328b | ||
| 
						 | 
					e42051d3a9 | ||
| 
						 | 
					e5336b7351 | ||
| 
						 | 
					5469af35f1 | ||
| 
						 | 
					8c9cd8f9d2 | ||
| 
						 | 
					8b3ac5ea36 | ||
| 
						 | 
					c230825486 | ||
| 
						 | 
					e8b0f5da60 | ||
| 
						 | 
					bc45e11824 | ||
| 
						 | 
					d6b3e97c34 | ||
| 
						 | 
					d35a12b4f4 | ||
| 
						 | 
					a42f103500 | ||
| 
						 | 
					dc2a48c515 | ||
| 
						 | 
					db617e23f0 | ||
| 
						 | 
					71189b1b74 | ||
| 
						 | 
					5567de89e6 | ||
| 
						 | 
					5430d79f53 | ||
| 
						 | 
					9d82d88a0c | ||
| 
						 | 
					0e264203de | ||
| 
						 | 
					469443da2a | ||
| 
						 | 
					692958d2fd | ||
| 
						 | 
					e65fa74071 | ||
| 
						 | 
					fb64d45c39 | ||
| 
						 | 
					71e5c8f441 | ||
| 
						 | 
					8e34f6653c | ||
| 
						 | 
					bee060b9bb | ||
| 
						 | 
					e3e94fe520 | ||
| 
						 | 
					237c090cb4 | ||
| 
						 | 
					74ea7a7a1e | ||
| 
						 | 
					330dbd49e6 | ||
| 
						 | 
					a84b047061 | ||
| 
						 | 
					3795060bf2 | ||
| 
						 | 
					e61ab97815 | ||
| 
						 | 
					0162828df8 | ||
| 
						 | 
					73cfef1203 | ||
| 
						 | 
					3eb6360054 | ||
| 
						 | 
					47e4bc585a | ||
| 
						 | 
					3746722a4d | ||
| 
						 | 
					5828971cfe | ||
| 
						 | 
					dd911cbf21 | ||
| 
						 | 
					f167553348 | ||
| 
						 | 
					d483c55c14 | ||
| 
						 | 
					d9815c0f62 | ||
| 
						 | 
					daadf043d8 | ||
| 
						 | 
					1a56d5820d | ||
| 
						 | 
					8e2f2fcce3 | ||
| 
						 | 
					fc5a841563 | ||
| 
						 | 
					d511a338df | ||
| 
						 | 
					a3d348b664 | ||
| 
						 | 
					b48506b156 | ||
| 
						 | 
					17bb88b67a | ||
| 
						 | 
					578a616b00 | ||
| 
						 | 
					93f603e27c | ||
| 
						 | 
					09b513550c | ||
| 
						 | 
					5e451461cf | ||
| 
						 | 
					fd33396acb | ||
| 
						 | 
					3bdfa68ff5 | ||
| 
						 | 
					3dbc070f2c | ||
| 
						 | 
					b48e5eb057 | ||
| 
						 | 
					3501bd9c11 | ||
| 
						 | 
					70635ac911 | ||
| 
						 | 
					f9a00b7ebd | ||
| 
						 | 
					5bec28b7e5 | ||
| 
						 | 
					e41818470f | ||
| 
						 | 
					a31422d3d7 | ||
| 
						 | 
					bea3d2c4f8 | ||
| 
						 | 
					4c4cb58027 | ||
| 
						 | 
					4312a42b62 | ||
| 
						 | 
					011e5b6e1a | ||
| 
						 | 
					8233c10569 | ||
| 
						 | 
					fb73d889ed | ||
| 
						 | 
					80bfb8671d | ||
| 
						 | 
					521df1a142 | ||
| 
						 | 
					72a75b72ac | ||
| 
						 | 
					c22dce10d3 | ||
| 
						 | 
					8eb801a0cc | ||
| 
						 | 
					6eaef7adad | ||
| 
						 | 
					0272d4bcad | ||
| 
						 | 
					41c64e9978 | ||
| 
						 | 
					9c2f0a098d | ||
| 
						 | 
					0bb8d0dcc0 | ||
| 
						 | 
					a542660072 | ||
| 
						 | 
					8ee15d0053 | ||
| 
						 | 
					311515867c | ||
| 
						 | 
					16bbcddd40 | ||
| 
						 | 
					a4b663b824 | ||
| 
						 | 
					736ab2b803 | ||
| 
						 | 
					cd2fbd11f2 | ||
| 
						 | 
					708fe70e75 | ||
| 
						 | 
					0c9499c085 | ||
| 
						 | 
					d52d4ff627 | ||
| 
						 | 
					324df56861 | ||
| 
						 | 
					a21a08e8bf | ||
| 
						 | 
					393db0ec2a | ||
| 
						 | 
					ca26d347eb | ||
| 
						 | 
					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 | 
@@ -15,7 +15,7 @@ runs:
 | 
				
			|||||||
      id: import_snapshot
 | 
					      id: import_snapshot
 | 
				
			||||||
      shell: bash
 | 
					      shell: bash
 | 
				
			||||||
      run: |
 | 
					      run: |
 | 
				
			||||||
        echo ::set-output name=import_task_id::$(aws ec2 import-snapshot --description '${{ inputs.firmware_image_name }}' --disk-container 'Format=raw,UserBucket={S3Bucket=${{ inputs.firmware_image_s3_bucket }},S3Key=${{ inputs.firmware_image_name }}}' | jq -r '.ImportTaskId')
 | 
					        echo "import_task_id=$(aws ec2 import-snapshot --description '${{ inputs.firmware_image_name }}' --disk-container 'Format=raw,UserBucket={S3Bucket=${{ inputs.firmware_image_s3_bucket }},S3Key=${{ inputs.firmware_image_name }}}' | jq -r '.ImportTaskId')" >> $GITHUB_OUTPUT
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Wait for import task to complete and get snapshot ID
 | 
					    - name: Wait for import task to complete and get snapshot ID
 | 
				
			||||||
      id: get_snapshot_id
 | 
					      id: get_snapshot_id
 | 
				
			||||||
@@ -26,7 +26,7 @@ runs:
 | 
				
			|||||||
          IMPORT_TASK_STATUS=$(aws ec2 describe-import-snapshot-tasks --import-task-ids ${{ steps.import_snapshot.outputs.import_task_id }} | jq -r '.ImportSnapshotTasks[].SnapshotTaskDetail.Status')
 | 
					          IMPORT_TASK_STATUS=$(aws ec2 describe-import-snapshot-tasks --import-task-ids ${{ steps.import_snapshot.outputs.import_task_id }} | jq -r '.ImportSnapshotTasks[].SnapshotTaskDetail.Status')
 | 
				
			||||||
          echo "Import task status is $IMPORT_TASK_STATUS, waiting for completion."
 | 
					          echo "Import task status is $IMPORT_TASK_STATUS, waiting for completion."
 | 
				
			||||||
        done
 | 
					        done
 | 
				
			||||||
        echo ::set-output name=id::$(aws ec2 describe-import-snapshot-tasks --import-task-ids ${{ steps.import_snapshot.outputs.import_task_id }} | jq -r '.ImportSnapshotTasks[].SnapshotTaskDetail.SnapshotId')
 | 
					        echo "id=$(aws ec2 describe-import-snapshot-tasks --import-task-ids ${{ steps.import_snapshot.outputs.import_task_id }} | jq -r '.ImportSnapshotTasks[].SnapshotTaskDetail.SnapshotId')" >> $GITHUB_OUTPUT
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Tag snapshot with image name
 | 
					    - name: Tag snapshot with image name
 | 
				
			||||||
      shell: bash
 | 
					      shell: bash
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										8
									
								
								.github/workflows/build-dev.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/build-dev.yml
									
									
									
									
										vendored
									
									
								
							@@ -21,10 +21,10 @@ 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_wf194c4', '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', 'hfcl_ion4x', 'hfcl_ion4x_2', 'indio_um-305ac', 'indio_um-305ax', 'indio_um-325ac', 'indio_um-510ac-v3', 'indio_um-550ac', 'indio_um-310ax-v1', 'indio_um-510axp-v1', 'indio_um-510axm-v1', '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', 'yuncore_ax840', 'yuncore_fap640', 'yuncore_fap650' ]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
    - uses: actions/checkout@v2
 | 
					    - uses: actions/checkout@v3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Build image for ${{ matrix.target }}
 | 
					    - name: Build image for ${{ matrix.target }}
 | 
				
			||||||
      id: build
 | 
					      id: build
 | 
				
			||||||
@@ -72,7 +72,7 @@ jobs:
 | 
				
			|||||||
        [ -f openwrt/tmp/image-file ] && aws s3api put-object-tagging --bucket "$AWS_S3_BUCKET_NAME" --key "$JSON_NAME" --tagging "{\"TagSet\":[{\"Key\":\"release\",\"Value\":\"$IS_RELEASE\"}]}"
 | 
					        [ -f openwrt/tmp/image-file ] && aws s3api put-object-tagging --bucket "$AWS_S3_BUCKET_NAME" --key "$JSON_NAME" --tagging "{\"TagSet\":[{\"Key\":\"release\",\"Value\":\"$IS_RELEASE\"}]}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if [ ${{ matrix.target }} == 'x64_vm' ]; then
 | 
					        if [ ${{ matrix.target }} == 'x64_vm' ]; then
 | 
				
			||||||
          echo ::set-output name=x64_vm_image_name::"$(echo $IMG_NAME)"
 | 
					          echo "x64_vm_image_name=$(echo $IMG_NAME)" >> $GITHUB_OUTPUT
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  trigger-testing:
 | 
					  trigger-testing:
 | 
				
			||||||
@@ -93,7 +93,7 @@ jobs:
 | 
				
			|||||||
    needs: build
 | 
					    needs: build
 | 
				
			||||||
    if: startsWith(github.ref, 'refs/tags/v')
 | 
					    if: startsWith(github.ref, 'refs/tags/v')
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
    - uses: actions/checkout@v2
 | 
					    - uses: actions/checkout@v3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Use create-ami-from-image composite action
 | 
					    - name: Use create-ami-from-image composite action
 | 
				
			||||||
      uses: ./.github/actions/create-ami-from-image
 | 
					      uses: ./.github/actions/create-ami-from-image
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										6
									
								
								.github/workflows/x64_vm-build-test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/x64_vm-build-test.yml
									
									
									
									
										vendored
									
									
								
							@@ -22,7 +22,7 @@ jobs:
 | 
				
			|||||||
        target: ['x64_vm']
 | 
					        target: ['x64_vm']
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
    - uses: actions/checkout@v2
 | 
					    - uses: actions/checkout@v3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    - name: Build image for ${{ matrix.target }}
 | 
					    - name: Build image for ${{ matrix.target }}
 | 
				
			||||||
      id: build
 | 
					      id: build
 | 
				
			||||||
@@ -70,14 +70,14 @@ jobs:
 | 
				
			|||||||
        [ -f openwrt/tmp/image-file ] && aws s3api put-object-tagging --bucket "$AWS_S3_BUCKET_NAME" --key "$JSON_NAME" --tagging "{\"TagSet\":[{\"Key\":\"release\",\"Value\":\"$IS_RELEASE\"}]}"
 | 
					        [ -f openwrt/tmp/image-file ] && aws s3api put-object-tagging --bucket "$AWS_S3_BUCKET_NAME" --key "$JSON_NAME" --tagging "{\"TagSet\":[{\"Key\":\"release\",\"Value\":\"$IS_RELEASE\"}]}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if [[ ${{ matrix.target }} == 'x64_vm' ]]; then
 | 
					        if [[ ${{ matrix.target }} == 'x64_vm' ]]; then
 | 
				
			||||||
          echo ::set-output name=x64_vm_image_name::"$(echo $IMG_NAME)"
 | 
					            echo "x64_vm_image_name=$(echo $IMG_NAME)" >> $GITHUB_OUTPUT
 | 
				
			||||||
        fi
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  create-x64_vm-ami:
 | 
					  create-x64_vm-ami:
 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
    needs: build
 | 
					    needs: build
 | 
				
			||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
    - uses: actions/checkout@v2
 | 
					    - uses: actions/checkout@v3
 | 
				
			||||||
      with:
 | 
					      with:
 | 
				
			||||||
        ref: WIFI-7206-add-workflow-to-build-virtual-ap-image
 | 
					        ref: WIFI-7206-add-workflow-to-build-virtual-ap-image
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										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,7 +34,14 @@ 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,ion4x|\
 | 
				
			||||||
 | 
					hfcl,ion4x_2|\
 | 
				
			||||||
hfcl,ion4xe)
 | 
					hfcl,ion4xe)
 | 
				
			||||||
        ucidef_set_led_wlan "wlan5g" "WLAN5G" "blue:wifi5" "phy0tpt"
 | 
					        ucidef_set_led_wlan "wlan5g" "WLAN5G" "blue:wifi5" "phy0tpt"
 | 
				
			||||||
        ucidef_set_led_wlan "wlan2g" "WLAN2G" "blue:wifi2" "phy1tpt"
 | 
					        ucidef_set_led_wlan "wlan2g" "WLAN2G" "blue:wifi2" "phy1tpt"
 | 
				
			||||||
@@ -43,6 +50,11 @@ glinet,ax1800|\
 | 
				
			|||||||
glinet,axt1800)
 | 
					glinet,axt1800)
 | 
				
			||||||
	ucidef_set_led_netdev "wan" "WAN" "blue:wan" "eth0" "tx rx link"
 | 
						ucidef_set_led_netdev "wan" "WAN" "blue:wan" "eth0" "tx rx link"
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
 | 
					yuncore,fap650|\
 | 
				
			||||||
 | 
					muxi,ap3220l)
 | 
				
			||||||
 | 
					        ucidef_set_led_wlan "wlan2g" "WLAN2G" "green:wifi2" "phy0tpt"
 | 
				
			||||||
 | 
					        ucidef_set_led_wlan "wlan5g" "WLAN5G" "green:wifi5" "phy1tpt"
 | 
				
			||||||
 | 
						;;
 | 
				
			||||||
esac
 | 
					esac
 | 
				
			||||||
 | 
					
 | 
				
			||||||
board_config_flush
 | 
					board_config_flush
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -13,6 +13,8 @@ qcom_setup_interfaces()
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	case $board in
 | 
						case $board in
 | 
				
			||||||
	hfcl,ion4xi|\
 | 
						hfcl,ion4xi|\
 | 
				
			||||||
 | 
						hfcl,ion4x|\
 | 
				
			||||||
 | 
						hfcl,ion4x_2|\
 | 
				
			||||||
	hfcl,ion4xe)
 | 
						hfcl,ion4xe)
 | 
				
			||||||
		ucidef_set_interface_wan "eth0 eth1"
 | 
							ucidef_set_interface_wan "eth0 eth1"
 | 
				
			||||||
		ucidef_set_interface_lan ""
 | 
							ucidef_set_interface_lan ""
 | 
				
			||||||
@@ -31,6 +33,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|\
 | 
				
			||||||
@@ -46,13 +51,18 @@ qcom_setup_interfaces()
 | 
				
			|||||||
		ucidef_set_interface_wan "eth0"
 | 
							ucidef_set_interface_wan "eth0"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	edgecore,eap102|\
 | 
						edgecore,eap102|\
 | 
				
			||||||
	edgecore,eap104|\
 | 
						liteon,wpx8324|\
 | 
				
			||||||
	wallys,dr6018|\
 | 
						wallys,dr6018|\
 | 
				
			||||||
	cig,wf188n|\
 | 
						cig,wf188n|\
 | 
				
			||||||
	cig,wf196)
 | 
						cig,wf196|\
 | 
				
			||||||
 | 
						muxi,ap3220l)
 | 
				
			||||||
		ucidef_set_interface_lan "eth1"
 | 
							ucidef_set_interface_lan "eth1"
 | 
				
			||||||
		ucidef_set_interface_wan "eth0"
 | 
							ucidef_set_interface_wan "eth0"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
 | 
						yuncore,fap650)
 | 
				
			||||||
 | 
							ucidef_set_interface_lan "eth3 eth2 eth1 eth0"
 | 
				
			||||||
 | 
							ucidef_set_interface_wan "eth4"
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
	qcom,ipq807x-hk14)
 | 
						qcom,ipq807x-hk14)
 | 
				
			||||||
		ucidef_set_interface_lan "eth0 eth1 eth2 eth3"
 | 
							ucidef_set_interface_lan "eth0 eth1 eth2 eth3"
 | 
				
			||||||
		ucidef_set_interface_wan "eth4"
 | 
							ucidef_set_interface_wan "eth4"
 | 
				
			||||||
@@ -72,6 +82,12 @@ qcom_setup_interfaces()
 | 
				
			|||||||
		ucidef_add_switch_attr "switch1" "enable" "false"
 | 
							ucidef_add_switch_attr "switch1" "enable" "false"
 | 
				
			||||||
		ucidef_add_switch_attr "switch1" "reset" "true"
 | 
							ucidef_add_switch_attr "switch1" "reset" "true"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
 | 
						edgecore,eap104)
 | 
				
			||||||
 | 
							ucidef_set_interface_lan "lan1 lan2 lan3 lan4"
 | 
				
			||||||
 | 
							ucidef_set_interface_wan "eth0"
 | 
				
			||||||
 | 
							ucidef_add_switch "switch1" \
 | 
				
			||||||
 | 
								"6@eth1" "1:lan1" "2:lan2" "3:lan3" "4:lan4"
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
	esac
 | 
						esac
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -81,13 +97,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,10 +126,21 @@ 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)
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
 | 
						muxi,ap3220l)
 | 
				
			||||||
 | 
							wan_mac=$(mtd_get_mac_binary 0:Product_Info 0x5b)
 | 
				
			||||||
 | 
							lan_mac=$(macaddr_add "$wan_mac" 1)
 | 
				
			||||||
 | 
							ucidef_set_network_device_mac eth0 $wan_mac
 | 
				
			||||||
 | 
							ucidef_set_network_device_mac eth1 $lan_mac
 | 
				
			||||||
 | 
							ip link set eth0 address $wan_mac
 | 
				
			||||||
 | 
							ip link set eth1 address $lan_mac
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
	*)
 | 
						*)
 | 
				
			||||||
		wan_mac=$(cat /sys/class/net/eth0/address)
 | 
							wan_mac=$(cat /sys/class/net/eth0/address)
 | 
				
			||||||
		lan_mac=$(macaddr_add "$wan_mac" 1)
 | 
							lan_mac=$(macaddr_add "$wan_mac" 1)
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -86,11 +86,13 @@ 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|\
 | 
				
			||||||
	tplink,ex447|\
 | 
						tplink,ex447|\
 | 
				
			||||||
	yuncore,ax840|\
 | 
					 | 
				
			||||||
	sercomm,wallaby)
 | 
						sercomm,wallaby)
 | 
				
			||||||
                caldata_extract "0:ART" 0x1000 0x20000
 | 
					                caldata_extract "0:ART" 0x1000 0x20000
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
@@ -102,6 +104,8 @@ case "$FIRMWARE" in
 | 
				
			|||||||
	cig,wf188n|\
 | 
						cig,wf188n|\
 | 
				
			||||||
	edgecore,eap101|\
 | 
						edgecore,eap101|\
 | 
				
			||||||
	hfcl,ion4xi|\
 | 
						hfcl,ion4xi|\
 | 
				
			||||||
 | 
						hfcl,ion4x_2|\
 | 
				
			||||||
 | 
						hfcl,ion4x|\
 | 
				
			||||||
	hfcl,ion4xe|\
 | 
						hfcl,ion4xe|\
 | 
				
			||||||
	wallys,dr6018|\
 | 
						wallys,dr6018|\
 | 
				
			||||||
	wallys,dr6018-v4|\
 | 
						wallys,dr6018-v4|\
 | 
				
			||||||
@@ -111,6 +115,8 @@ case "$FIRMWARE" in
 | 
				
			|||||||
	qcom,ipq6018-cp01|\
 | 
						qcom,ipq6018-cp01|\
 | 
				
			||||||
	xiaomi,ax1800|\
 | 
						xiaomi,ax1800|\
 | 
				
			||||||
	glinet,ax1800|\
 | 
						glinet,ax1800|\
 | 
				
			||||||
 | 
						yuncore,ax840|\
 | 
				
			||||||
 | 
						yuncore,fap650|\
 | 
				
			||||||
	plasmacloud,pax1800-v1|\
 | 
						plasmacloud,pax1800-v1|\
 | 
				
			||||||
	plasmacloud,pax1800-v2)
 | 
						plasmacloud,pax1800-v2)
 | 
				
			||||||
                caldata_extract "0:ART" 0x1000 0x20000  
 | 
					                caldata_extract "0:ART" 0x1000 0x20000  
 | 
				
			||||||
@@ -121,7 +127,9 @@ 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|\
 | 
				
			||||||
 | 
						muxi,ap3220l|\
 | 
				
			||||||
	qcom,ipq5018-mp03.1)
 | 
						qcom,ipq5018-mp03.1)
 | 
				
			||||||
                caldata_extract "0:ART" 0x1000 0x20000  
 | 
					                caldata_extract "0:ART" 0x1000 0x20000  
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
@@ -137,9 +145,13 @@ 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  
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
 | 
						muxi,ap3220l)
 | 
				
			||||||
 | 
							caldata_extract "0:ART" 0x26800 0x20000
 | 
				
			||||||
 | 
							;;
 | 
				
			||||||
	esac
 | 
						esac
 | 
				
			||||||
	;;
 | 
						;;
 | 
				
			||||||
ath11k/QCN9074/hw1.0/caldata_1.bin)
 | 
					ath11k/QCN9074/hw1.0/caldata_1.bin)
 | 
				
			||||||
@@ -164,6 +176,8 @@ ath11k/QCN9074/hw1.0/caldata_2.bin)
 | 
				
			|||||||
ath11k-macs)
 | 
					ath11k-macs)
 | 
				
			||||||
	case "$board" in
 | 
						case "$board" in
 | 
				
			||||||
	hfcl,ion4xi|\
 | 
						hfcl,ion4xi|\
 | 
				
			||||||
 | 
						hfcl,ion4x|\
 | 
				
			||||||
 | 
						hfcl,ion4x_2|\
 | 
				
			||||||
	hfcl,ion4xe)                                               
 | 
						hfcl,ion4xe)                                               
 | 
				
			||||||
		ath11k_generate_macs_ion4x
 | 
							ath11k_generate_macs_ion4x
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
@@ -173,11 +187,15 @@ 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
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	cig,wf194c|\
 | 
						cig,wf194c|\
 | 
				
			||||||
	cig,wf194c)
 | 
						cig,wf194c4|\
 | 
				
			||||||
 | 
						cig,wf196)
 | 
				
			||||||
		ath11k_generate_macs_wf194
 | 
							ath11k_generate_macs_wf194
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	plasmacloud,pax1800-v1|\
 | 
						plasmacloud,pax1800-v1|\
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -76,20 +76,28 @@ 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,ion4x|\
 | 
				
			||||||
 | 
						hfcl,ion4x_2|\
 | 
				
			||||||
	hfcl,ion4xe|\
 | 
						hfcl,ion4xe|\
 | 
				
			||||||
 | 
						muxi,ap3220l|\
 | 
				
			||||||
	plasmacloud,pax1800-v1|\
 | 
						plasmacloud,pax1800-v1|\
 | 
				
			||||||
	plasmacloud,pax1800-v2|\
 | 
						plasmacloud,pax1800-v2|\
 | 
				
			||||||
	tplink,ex227|\
 | 
						tplink,ex227|\
 | 
				
			||||||
	tplink,ex447|\
 | 
						tplink,ex447|\
 | 
				
			||||||
	yuncore,ax840|\
 | 
						yuncore,ax840|\
 | 
				
			||||||
	motorola,q14|\
 | 
						motorola,q14|\
 | 
				
			||||||
 | 
						muxi,ap3220l|\
 | 
				
			||||||
	qcom,ipq6018-cp01|\
 | 
						qcom,ipq6018-cp01|\
 | 
				
			||||||
	qcom,ipq807x-hk01|\
 | 
						qcom,ipq807x-hk01|\
 | 
				
			||||||
	qcom,ipq807x-hk14|\
 | 
						qcom,ipq807x-hk14|\
 | 
				
			||||||
@@ -118,9 +126,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|\
 | 
				
			||||||
@@ -135,6 +145,8 @@ platform_do_upgrade() {
 | 
				
			|||||||
		nand_upgrade_tar "$1"
 | 
							nand_upgrade_tar "$1"
 | 
				
			||||||
		;;
 | 
							;;
 | 
				
			||||||
	hfcl,ion4xi|\
 | 
						hfcl,ion4xi|\
 | 
				
			||||||
 | 
						hfcl,ion4x|\
 | 
				
			||||||
 | 
						hfcl,ion4x_2|\
 | 
				
			||||||
	hfcl,ion4xe)
 | 
						hfcl,ion4xe)
 | 
				
			||||||
		if grep -q rootfs_1 /proc/cmdline; then
 | 
							if grep -q rootfs_1 /proc/cmdline; then
 | 
				
			||||||
			CI_UBIPART="rootfs"
 | 
								CI_UBIPART="rootfs"
 | 
				
			||||||
@@ -145,6 +157,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,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-muxi-ap3220l.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-hfcl-ion4x.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-hfcl-ion4x_2.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-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,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-yuncore-fap650.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,891 @@
 | 
				
			|||||||
 | 
					/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 = "MUXI AP3220L";
 | 
				
			||||||
 | 
						compatible = "muxi,ap3220l", "qcom,ipq5018-mp03.5-c1", "qcom,ipq5018";
 | 
				
			||||||
 | 
						interrupt-parent = <&intc>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aliases {
 | 
				
			||||||
 | 
							serial0 = &blsp1_uart1;
 | 
				
			||||||
 | 
							serial1 = &blsp1_uart2;
 | 
				
			||||||
 | 
							ethernet0 = "/soc/dp1";
 | 
				
			||||||
 | 
							ethernet1 = "/soc/dp2";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led-boot = &led_power;
 | 
				
			||||||
 | 
							led-failsafe = &led_power;
 | 
				
			||||||
 | 
							led-running = &led_power;
 | 
				
			||||||
 | 
							led-upgrade = &led_power;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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 {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							blsp1_uart1: serial@78af000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp0_uart_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "okay";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							blsp1_uart2: serial@78b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp1_uart_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qpic_bam: dma@7984000{
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							nand: qpic-nand@79b0000 {
 | 
				
			||||||
 | 
								pinctrl-0 = <&qspi_nand_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							spi_0: spi@78b5000 { /* BLSP1 QUP0 */
 | 
				
			||||||
 | 
								pinctrl-0 = <&blsp0_spi_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								cs-select = <0>;
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								m25p80@0 {
 | 
				
			||||||
 | 
									#address-cells = <1>;
 | 
				
			||||||
 | 
									#size-cells = <1>;
 | 
				
			||||||
 | 
									reg = <0>;
 | 
				
			||||||
 | 
									compatible = "n25q128a11";
 | 
				
			||||||
 | 
									linux,modalias = "m25p80", "n25q128a11";
 | 
				
			||||||
 | 
									spi-max-frequency = <50000000>;
 | 
				
			||||||
 | 
									use-default-sizes;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio0: mdio@88000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <7>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mdio1: mdio@90000 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
								pinctrl-0 = <&mdio1_pins &phy_pins>;
 | 
				
			||||||
 | 
								pinctrl-names = "default";
 | 
				
			||||||
 | 
								phy-reset-gpio = <&tlmm 39 0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@0 {
 | 
				
			||||||
 | 
									reg = <0>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@1 {
 | 
				
			||||||
 | 
									reg = <1>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@2 {
 | 
				
			||||||
 | 
									reg = <2>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								ethernet-phy@3 {
 | 
				
			||||||
 | 
									reg = <3>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ess-instance {
 | 
				
			||||||
 | 
								num_devices = <0x2>;
 | 
				
			||||||
 | 
								ess-switch@0x39c00000 {
 | 
				
			||||||
 | 
									compatible = "qcom,ess-switch-ipq50xx";
 | 
				
			||||||
 | 
									device_id = <0>;
 | 
				
			||||||
 | 
									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>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@1 {
 | 
				
			||||||
 | 
											port_id = <2>;
 | 
				
			||||||
 | 
											forced-speed = <1000>;
 | 
				
			||||||
 | 
											forced-duplex = <1>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
									/*
 | 
				
			||||||
 | 
									led_source@0 {
 | 
				
			||||||
 | 
										source = <0>;
 | 
				
			||||||
 | 
										mode = "normal";
 | 
				
			||||||
 | 
										speed = "all";
 | 
				
			||||||
 | 
										blink_en = "enable";
 | 
				
			||||||
 | 
										active = "high";
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
									*/
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
								ess-switch1@1 {
 | 
				
			||||||
 | 
									compatible = "qcom,ess-switch-qca83xx";
 | 
				
			||||||
 | 
									device_id = <1>;
 | 
				
			||||||
 | 
									switch_access_mode = "mdio";
 | 
				
			||||||
 | 
									mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
									reset_gpio = <0x27>;
 | 
				
			||||||
 | 
									switch_cpu_bmp = <0x40>;  /* cpu port bitmap */
 | 
				
			||||||
 | 
									switch_lan_bmp = <0x1e>; /* lan port bitmap */
 | 
				
			||||||
 | 
									switch_wan_bmp = <0x0>;  /* wan port bitmap */
 | 
				
			||||||
 | 
									qca,ar8327-initvals = <
 | 
				
			||||||
 | 
											0x00004 0x7600000   /* PAD0_MODE */
 | 
				
			||||||
 | 
											0x00008 0x1000000   /* PAD5_MODE */
 | 
				
			||||||
 | 
											0x0000c 0x80        /* PAD6_MODE */
 | 
				
			||||||
 | 
											0x00010 0x2613a0    /* PORT6 FORCE MODE*/
 | 
				
			||||||
 | 
											0x000e4 0xaa545     /* MAC_POWER_SEL */
 | 
				
			||||||
 | 
											0x000e0 0xc74164de  /* SGMII_CTRL */
 | 
				
			||||||
 | 
											0x0007c 0x4e        /* PORT0_STATUS */
 | 
				
			||||||
 | 
											0x00094 0x4e        /* PORT6_STATUS */
 | 
				
			||||||
 | 
									>;
 | 
				
			||||||
 | 
									qcom,port_phyinfo {
 | 
				
			||||||
 | 
										port@0 {
 | 
				
			||||||
 | 
											port_id = <1>;
 | 
				
			||||||
 | 
											phy_address = <0>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@1 {
 | 
				
			||||||
 | 
											port_id = <2>;
 | 
				
			||||||
 | 
											phy_address = <1>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@2 {
 | 
				
			||||||
 | 
											port_id = <3>;
 | 
				
			||||||
 | 
											phy_address = <2>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
										port@3 {
 | 
				
			||||||
 | 
											port_id = <4>;
 | 
				
			||||||
 | 
											phy_address = <3>;
 | 
				
			||||||
 | 
										};
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ess-uniphy@98000 {
 | 
				
			||||||
 | 
								status = "disabled";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							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 = <3>;
 | 
				
			||||||
 | 
								mdio-bus = <&mdio1>;
 | 
				
			||||||
 | 
								local-mac-address = [000000000000];
 | 
				
			||||||
 | 
								phy-mode = "sgmii";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							qcom,test@0 {
 | 
				
			||||||
 | 
								status = "ok";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						thermal-zones {
 | 
				
			||||||
 | 
							status = "ok";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
						//pinctrl-0 = <&phy_led_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_uart_pins: uart_pins {
 | 
				
			||||||
 | 
							blsp0_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio20", "gpio21";
 | 
				
			||||||
 | 
								function = "blsp0_uart0";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp1_uart_pins: blsp1_uart_pins {
 | 
				
			||||||
 | 
							blsp1_uart_rx_tx {
 | 
				
			||||||
 | 
								pins = "gpio23", "gpio25";
 | 
				
			||||||
 | 
								function = "blsp1_uart2";
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						blsp0_spi_pins: blsp0_spi_pins {
 | 
				
			||||||
 | 
							mux {
 | 
				
			||||||
 | 
								pins = "gpio10", "gpio11", "gpio12", "gpio13";
 | 
				
			||||||
 | 
								function = "blsp0_spi";
 | 
				
			||||||
 | 
								drive-strength = <2>;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						qspi_nand_pins: qspi_nand_pins {
 | 
				
			||||||
 | 
							qspi_clock {
 | 
				
			||||||
 | 
									pins = "gpio9";
 | 
				
			||||||
 | 
									function = "qspi_clk";
 | 
				
			||||||
 | 
									drive-strength = <8>;
 | 
				
			||||||
 | 
									bias-disable;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							qspi_cs {
 | 
				
			||||||
 | 
									pins = "gpio8";
 | 
				
			||||||
 | 
									function = "qspi_cs";
 | 
				
			||||||
 | 
									drive-strength = <8>;
 | 
				
			||||||
 | 
									bias-disable;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							qspi_data_0 {
 | 
				
			||||||
 | 
									pins = "gpio7";
 | 
				
			||||||
 | 
									function = "qspi0";
 | 
				
			||||||
 | 
									drive-strength = <8>;
 | 
				
			||||||
 | 
									bias-disable;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							qspi_data_1 {
 | 
				
			||||||
 | 
									pins = "gpio6";
 | 
				
			||||||
 | 
									function = "qspi1";
 | 
				
			||||||
 | 
									drive-strength = <8>;
 | 
				
			||||||
 | 
									bias-disable;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							qspi_data_2 {
 | 
				
			||||||
 | 
									pins = "gpio5";
 | 
				
			||||||
 | 
									function = "qspi2";
 | 
				
			||||||
 | 
									drive-strength = <8>;
 | 
				
			||||||
 | 
									bias-disable;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							qspi_data_3 {
 | 
				
			||||||
 | 
									pins = "gpio4";
 | 
				
			||||||
 | 
									function = "qspi3";
 | 
				
			||||||
 | 
									drive-strength = <8>;
 | 
				
			||||||
 | 
									bias-disable;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						phy_pins: phy_pins {
 | 
				
			||||||
 | 
							phy_intr {
 | 
				
			||||||
 | 
								pins = "gpio29";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
								bias-disable;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							phy_reset {
 | 
				
			||||||
 | 
								pins = "gpio39";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
								output-low;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						mdio1_pins: mdio_pinmux {
 | 
				
			||||||
 | 
							mux_0 {
 | 
				
			||||||
 | 
								pins = "gpio36";
 | 
				
			||||||
 | 
								function = "mdc";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mux_1 {
 | 
				
			||||||
 | 
								pins = "gpio37";
 | 
				
			||||||
 | 
								function = "mdio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						phy_led_pins: phy_led_pins {
 | 
				
			||||||
 | 
							gephy_led_pin {
 | 
				
			||||||
 | 
								//pins = "gpio46";
 | 
				
			||||||
 | 
								function = "led0";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						button_pins: button_pins {
 | 
				
			||||||
 | 
							reset_button {
 | 
				
			||||||
 | 
								pins = "gpio32";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-up;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						led_pins: led_pins {
 | 
				
			||||||
 | 
							led_pwr {
 | 
				
			||||||
 | 
								pins = "gpio26";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_2g {
 | 
				
			||||||
 | 
								pins = "gpio31";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_5g {
 | 
				
			||||||
 | 
								pins = "gpio33";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
						gpio_keys {
 | 
				
			||||||
 | 
							compatible = "gpio-keys";
 | 
				
			||||||
 | 
							pinctrl-0 = <&button_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							button@1 {
 | 
				
			||||||
 | 
								label = "reset_button";
 | 
				
			||||||
 | 
								linux,code = <KEY_RESTART>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 32 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,input-type = <1>;
 | 
				
			||||||
 | 
								debounce-interval = <60>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						leds {
 | 
				
			||||||
 | 
							compatible = "gpio-leds";
 | 
				
			||||||
 | 
							pinctrl-0 = <&led_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								led_power: led_pwr {
 | 
				
			||||||
 | 
									label = "green:led_pwr";
 | 
				
			||||||
 | 
									gpios = <&tlmm 26 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
									default-state = "on";
 | 
				
			||||||
 | 
									linux,default-trigger = "led_pwr";
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								led_2g {
 | 
				
			||||||
 | 
									label = "green:wifi2";
 | 
				
			||||||
 | 
									gpio = <&tlmm 33 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
									default-state = "off";
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								led_5g {
 | 
				
			||||||
 | 
									label = "green:wifi5";
 | 
				
			||||||
 | 
									gpio = <&tlmm 31 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
									default-state = "off";
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&usb3 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
						device-power-gpio = <&tlmm 30 1>;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&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 = <0x2 0x4 0x2 0xF 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 6G */
 | 
				
			||||||
 | 
						qcom,multipd_arch;
 | 
				
			||||||
 | 
						qcom,userpd-subsys-name = "q6v5_wcss_userpd2";
 | 
				
			||||||
 | 
					#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 = <0x4D600000 0x4D600000 0x4D300000 0x0 0x0>;
 | 
				
			||||||
 | 
					#ifdef __CNSS2__
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4E800000 0x4E800000 0 0 0>;
 | 
				
			||||||
 | 
					#else
 | 
				
			||||||
 | 
						qcom,caldb-addr = <0x4E800000>;
 | 
				
			||||||
 | 
						m3-dump-addr = <0x4E600000>;
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
						qcom,caldb-size = <0x500000>;
 | 
				
			||||||
 | 
						status = "disabled";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&wifi2 {
 | 
				
			||||||
 | 
						/* 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,155 @@
 | 
				
			|||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * 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 "qcom-ipq6018-cp01-hfcl.dtsi"
 | 
				
			||||||
 | 
					#include "qcom-ipq6018-rpm-regulator.dtsi"
 | 
				
			||||||
 | 
					#include "qcom-ipq6018-cpr-regulator.dtsi"
 | 
				
			||||||
 | 
					#include "qcom-ipq6018-cp-cpu.dtsi"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						model = "HFCL ION4X";
 | 
				
			||||||
 | 
						compatible = "hfcl,ion4x", "qcom,ipq6018-cp01", "qcom,ipq6018";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/*
 | 
				
			||||||
 | 
						 * +=========+==============+========================+
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * | Region | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * | Linux  |  0x41000000  |         139MB           |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | TZ App |  0x49B00000  |           6MB           |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 *
 | 
				
			||||||
 | 
						 * From the available 145 MB for Linux in the first 256 MB,
 | 
				
			||||||
 | 
						 * we are reserving 6 MB for TZAPP.
 | 
				
			||||||
 | 
						 *
 | 
				
			||||||
 | 
						 * Refer arch/arm64/boot/dts/qcom/qcom-ipq6018-memory.dtsi
 | 
				
			||||||
 | 
						 * for memory layout.
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* TZAPP is enabled in default memory profile only */
 | 
				
			||||||
 | 
					#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 {
 | 
				
			||||||
 | 
						i2c_1_pins: i2c_1_pins {
 | 
				
			||||||
 | 
							mux {
 | 
				
			||||||
 | 
								pins = "gpio42", "gpio43";
 | 
				
			||||||
 | 
								function = "blsp2_i2c";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						i2c_2_pins: i2c_2_pins {
 | 
				
			||||||
 | 
					                mux {
 | 
				
			||||||
 | 
					                        pins = "gpio55", "gpio56";
 | 
				
			||||||
 | 
					                        function = "blsp4_i2c";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_1 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&i2c_1_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						lm75@48 {
 | 
				
			||||||
 | 
							compatible = "lm75";
 | 
				
			||||||
 | 
							reg = <0x48>;
 | 
				
			||||||
 | 
							status = "okay";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_2 {
 | 
				
			||||||
 | 
					        pinctrl-0 = <&i2c_2_pins>;
 | 
				
			||||||
 | 
					        pinctrl-names = "default";
 | 
				
			||||||
 | 
					        status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&sdhc_2 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&sd_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						cd-gpios = <&tlmm 62 1>;
 | 
				
			||||||
 | 
						sd-ldo-gpios = <&tlmm 66 0>;
 | 
				
			||||||
 | 
						vqmmc-supply = <&ipq6018_l2_corner>;
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
					        leds {
 | 
				
			||||||
 | 
					                compatible = "gpio-leds";
 | 
				
			||||||
 | 
					                pinctrl-0 = <&leds_pins>;
 | 
				
			||||||
 | 
					                pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                led@60 {
 | 
				
			||||||
 | 
					                        label = "blue:wifi5";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 60 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_5g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led@61 {
 | 
				
			||||||
 | 
					                        label = "blue:wifi2";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_2g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
						leds_pins: leds_pins {
 | 
				
			||||||
 | 
							led_5g {
 | 
				
			||||||
 | 
								pins = "gpio60";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							led_2g {
 | 
				
			||||||
 | 
								pins = "gpio61";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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
 | 
				
			||||||
@@ -0,0 +1,155 @@
 | 
				
			|||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * 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 "qcom-ipq6018-cp01-hfcl.dtsi"
 | 
				
			||||||
 | 
					#include "qcom-ipq6018-rpm-regulator.dtsi"
 | 
				
			||||||
 | 
					#include "qcom-ipq6018-cpr-regulator.dtsi"
 | 
				
			||||||
 | 
					#include "qcom-ipq6018-cp-cpu.dtsi"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						model = "HFCL ION4X_2";
 | 
				
			||||||
 | 
						compatible = "hfcl,ion4x_2", "qcom,ipq6018-cp01", "qcom,ipq6018";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/*
 | 
				
			||||||
 | 
						 * +=========+==============+========================+
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * | Region | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * | Linux  |  0x41000000  |         139MB           |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | TZ App |  0x49B00000  |           6MB           |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 *
 | 
				
			||||||
 | 
						 * From the available 145 MB for Linux in the first 256 MB,
 | 
				
			||||||
 | 
						 * we are reserving 6 MB for TZAPP.
 | 
				
			||||||
 | 
						 *
 | 
				
			||||||
 | 
						 * Refer arch/arm64/boot/dts/qcom/qcom-ipq6018-memory.dtsi
 | 
				
			||||||
 | 
						 * for memory layout.
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* TZAPP is enabled in default memory profile only */
 | 
				
			||||||
 | 
					#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 {
 | 
				
			||||||
 | 
						i2c_1_pins: i2c_1_pins {
 | 
				
			||||||
 | 
							mux {
 | 
				
			||||||
 | 
								pins = "gpio42", "gpio43";
 | 
				
			||||||
 | 
								function = "blsp2_i2c";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						i2c_2_pins: i2c_2_pins {
 | 
				
			||||||
 | 
					                mux {
 | 
				
			||||||
 | 
					                        pins = "gpio55", "gpio56";
 | 
				
			||||||
 | 
					                        function = "blsp4_i2c";
 | 
				
			||||||
 | 
					                        drive-strength = <8>;
 | 
				
			||||||
 | 
					                        bias-pull-down;
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_1 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&i2c_1_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						lm75@48 {
 | 
				
			||||||
 | 
							compatible = "lm75";
 | 
				
			||||||
 | 
							reg = <0x48>;
 | 
				
			||||||
 | 
							status = "okay";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&i2c_2 {
 | 
				
			||||||
 | 
					        pinctrl-0 = <&i2c_2_pins>;
 | 
				
			||||||
 | 
					        pinctrl-names = "default";
 | 
				
			||||||
 | 
					        status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&sdhc_2 {
 | 
				
			||||||
 | 
						pinctrl-0 = <&sd_pins>;
 | 
				
			||||||
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
						cd-gpios = <&tlmm 62 1>;
 | 
				
			||||||
 | 
						sd-ldo-gpios = <&tlmm 66 0>;
 | 
				
			||||||
 | 
						vqmmc-supply = <&ipq6018_l2_corner>;
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
					        leds {
 | 
				
			||||||
 | 
					                compatible = "gpio-leds";
 | 
				
			||||||
 | 
					                pinctrl-0 = <&leds_pins>;
 | 
				
			||||||
 | 
					                pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                led@60 {
 | 
				
			||||||
 | 
					                        label = "blue:wifi5";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 60 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_5g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					                led@61 {
 | 
				
			||||||
 | 
					                        label = "blue:wifi2";
 | 
				
			||||||
 | 
					                        gpios = <&tlmm 61 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
					                        linux,default-trigger = "led_2g";
 | 
				
			||||||
 | 
					                        default-state = "off";
 | 
				
			||||||
 | 
					                };
 | 
				
			||||||
 | 
					        };
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&tlmm {
 | 
				
			||||||
 | 
						leds_pins: leds_pins {
 | 
				
			||||||
 | 
							led_5g {
 | 
				
			||||||
 | 
								pins = "gpio60";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							led_2g {
 | 
				
			||||||
 | 
								pins = "gpio61";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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
 | 
				
			||||||
@@ -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";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -0,0 +1,423 @@
 | 
				
			|||||||
 | 
					/dts-v1/;
 | 
				
			||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * 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 "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>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/ {
 | 
				
			||||||
 | 
						#address-cells = <0x2>;
 | 
				
			||||||
 | 
						#size-cells = <0x2>;
 | 
				
			||||||
 | 
						model = "Qualcomm Technologies, Inc. IPQ6018/AP-CP03-C1";
 | 
				
			||||||
 | 
						compatible = "yuncore,fap650", "qcom,ipq6018-cp03", "qcom,ipq6018";
 | 
				
			||||||
 | 
						interrupt-parent = <&intc>;
 | 
				
			||||||
 | 
						qcom,msm-id = <0x1A5 0x0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						aliases {
 | 
				
			||||||
 | 
							/*
 | 
				
			||||||
 | 
							 * Aliases as required by u-boot
 | 
				
			||||||
 | 
							 * to patch MAC addresses
 | 
				
			||||||
 | 
							 */
 | 
				
			||||||
 | 
							ethernet0 = "/soc/dp1";
 | 
				
			||||||
 | 
							ethernet1 = "/soc/dp2";
 | 
				
			||||||
 | 
							ethernet2 = "/soc/dp3";
 | 
				
			||||||
 | 
							ethernet3 = "/soc/dp4";
 | 
				
			||||||
 | 
							ethernet4 = "/soc/dp5";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led-boot = &led_power;
 | 
				
			||||||
 | 
							led-failsafe = &led_power;
 | 
				
			||||||
 | 
							led-running = &led_power;
 | 
				
			||||||
 | 
							led-upgrade = &led_power;
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/*
 | 
				
			||||||
 | 
						 * +=========+==============+========================+
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * | Region | Start Offset |          Size           |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * | Linux  |  0x41000000  |         139MB           |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * |        |              |                         |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 * | TZ App |  0x49B00000  |           6MB           |
 | 
				
			||||||
 | 
						 * +--------+--------------+-------------------------+
 | 
				
			||||||
 | 
						 *
 | 
				
			||||||
 | 
						 * From the available 145 MB for Linux in the first 256 MB,
 | 
				
			||||||
 | 
						 * we are reserving 6 MB for TZAPP.
 | 
				
			||||||
 | 
						 *
 | 
				
			||||||
 | 
						 * Refer arch/arm64/boot/dts/qcom/qcom-ipq6018-memory.dtsi
 | 
				
			||||||
 | 
						 * for memory layout.
 | 
				
			||||||
 | 
						 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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 {
 | 
				
			||||||
 | 
							wps_button {
 | 
				
			||||||
 | 
								pins = "gpio19";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						leds_pins: leds_pins {
 | 
				
			||||||
 | 
							led_sys {
 | 
				
			||||||
 | 
								pins = "gpio32";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_5g {
 | 
				
			||||||
 | 
								pins = "gpio35";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_2g {
 | 
				
			||||||
 | 
								pins = "gpio37";
 | 
				
			||||||
 | 
								function = "gpio";
 | 
				
			||||||
 | 
								drive-strength = <8>;
 | 
				
			||||||
 | 
								bias-pull-down;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&soc {
 | 
				
			||||||
 | 
						mdio@90000 {
 | 
				
			||||||
 | 
							pinctrl-0 = <&mdio_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
							phy-reset-gpio = <&tlmm 75 0>;
 | 
				
			||||||
 | 
							status = "ok";
 | 
				
			||||||
 | 
							phy0: ethernet-phy@0 {
 | 
				
			||||||
 | 
								reg = <0>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							phy1: ethernet-phy@1 {
 | 
				
			||||||
 | 
								reg = <1>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							phy2: ethernet-phy@2 {
 | 
				
			||||||
 | 
								reg = <2>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							phy3: ethernet-phy@3 {
 | 
				
			||||||
 | 
								reg = <3>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							phy4: ethernet-phy@4 {
 | 
				
			||||||
 | 
								reg = <4>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ess-switch@3a000000 {
 | 
				
			||||||
 | 
							switch_cpu_bmp = <0x1>;  /* cpu port bitmap */
 | 
				
			||||||
 | 
							switch_lan_bmp = <0x1e>; /* lan port bitmap */
 | 
				
			||||||
 | 
							switch_wan_bmp = <0x20>; /* wan port bitmap */
 | 
				
			||||||
 | 
							switch_inner_bmp = <0xc0>; /*inner port bitmap*/
 | 
				
			||||||
 | 
							switch_mac_mode = <0x0>; /* 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 = <3>;
 | 
				
			||||||
 | 
									phy_address = <4>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
								port@4 {
 | 
				
			||||||
 | 
									port_id = <4>;
 | 
				
			||||||
 | 
									phy_address = <3>;
 | 
				
			||||||
 | 
								};
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						dp1 {
 | 
				
			||||||
 | 
							device_type = "network";
 | 
				
			||||||
 | 
							compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
							qcom,id = <1>;
 | 
				
			||||||
 | 
							reg = <0x3a001000 0x200>;
 | 
				
			||||||
 | 
							qcom,mactype = <0>;
 | 
				
			||||||
 | 
							local-mac-address = [000000000000];
 | 
				
			||||||
 | 
							qcom,link-poll = <1>;
 | 
				
			||||||
 | 
							qcom,phy-mdio-addr = <0>;
 | 
				
			||||||
 | 
							phy-mode = "sgmii";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						dp2 {
 | 
				
			||||||
 | 
							device_type = "network";
 | 
				
			||||||
 | 
							compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
							qcom,id = <2>;
 | 
				
			||||||
 | 
							reg = <0x3a001200 0x200>;
 | 
				
			||||||
 | 
							qcom,mactype = <0>;
 | 
				
			||||||
 | 
							local-mac-address = [000000000000];
 | 
				
			||||||
 | 
							qcom,link-poll = <1>;
 | 
				
			||||||
 | 
							qcom,phy-mdio-addr = <1>;
 | 
				
			||||||
 | 
							phy-mode = "sgmii";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						dp3 {
 | 
				
			||||||
 | 
							device_type = "network";
 | 
				
			||||||
 | 
							compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
							qcom,id = <3>;
 | 
				
			||||||
 | 
							reg = <0x3a001400 0x200>;
 | 
				
			||||||
 | 
							qcom,mactype = <0>;
 | 
				
			||||||
 | 
							local-mac-address = [000000000000];
 | 
				
			||||||
 | 
							qcom,link-poll = <1>;
 | 
				
			||||||
 | 
							qcom,phy-mdio-addr = <2>;
 | 
				
			||||||
 | 
							phy-mode = "sgmii";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						dp4 {
 | 
				
			||||||
 | 
							device_type = "network";
 | 
				
			||||||
 | 
							compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
							qcom,id = <4>;
 | 
				
			||||||
 | 
							reg = <0x3a001600 0x200>;
 | 
				
			||||||
 | 
							qcom,mactype = <0>;
 | 
				
			||||||
 | 
							local-mac-address = [000000000000];
 | 
				
			||||||
 | 
							qcom,link-poll = <1>;
 | 
				
			||||||
 | 
							qcom,phy-mdio-addr = <3>;
 | 
				
			||||||
 | 
							phy-mode = "sgmii";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						dp5 {
 | 
				
			||||||
 | 
							device_type = "network";
 | 
				
			||||||
 | 
							compatible = "qcom,nss-dp";
 | 
				
			||||||
 | 
							qcom,id = <5>;
 | 
				
			||||||
 | 
							reg = <0x3a001800 0x200>;
 | 
				
			||||||
 | 
							qcom,mactype = <0>;
 | 
				
			||||||
 | 
							local-mac-address = [000000000000];
 | 
				
			||||||
 | 
							qcom,link-poll = <1>;
 | 
				
			||||||
 | 
							qcom,phy-mdio-addr = <4>;
 | 
				
			||||||
 | 
							phy-mode = "sgmii";
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						leds {
 | 
				
			||||||
 | 
							compatible = "gpio-leds";
 | 
				
			||||||
 | 
							pinctrl-0 = <&leds_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led_power: led@32 {
 | 
				
			||||||
 | 
								label = "green:power";
 | 
				
			||||||
 | 
								gpios = <&tlmm 32 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
								default-state = "on";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led@35 {
 | 
				
			||||||
 | 
								label = "green:wifi5";
 | 
				
			||||||
 | 
								gpios = <&tlmm 35 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
								default-state = "off";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							led@37 {
 | 
				
			||||||
 | 
								label = "green:wifi2";
 | 
				
			||||||
 | 
								gpios = <&tlmm 37 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
								default-state = "off";
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						gpio_keys {
 | 
				
			||||||
 | 
							compatible = "gpio-keys";
 | 
				
			||||||
 | 
							pinctrl-0 = <&button_pins>;
 | 
				
			||||||
 | 
							pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							wps {
 | 
				
			||||||
 | 
								label = "reset";
 | 
				
			||||||
 | 
								linux,code = <KEY_RESTART>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 19 GPIO_ACTIVE_LOW>;
 | 
				
			||||||
 | 
								linux,input-type = <1>;
 | 
				
			||||||
 | 
								debounce-interval = <60>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&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";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&ssphy_0 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&qusb_phy_0 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&usb3 {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					&nss_crypto {
 | 
				
			||||||
 | 
						status = "ok";
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* 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
 | 
				
			||||||
@@ -50,25 +50,43 @@
 | 
				
			|||||||
			bootargs-append = " swiotlb=1 coherent_pool=2M";
 | 
								bootargs-append = " swiotlb=1 coherent_pool=2M";
 | 
				
			||||||
		#endif
 | 
							#endif
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						gpio-export {
 | 
				
			||||||
 | 
							compatible = "gpio-export";
 | 
				
			||||||
 | 
							#size-cells = <0>;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							mcu-enable {
 | 
				
			||||||
 | 
								gpio-export,name = "mcu-enable";
 | 
				
			||||||
 | 
								gpio-export,output = <1>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							usb-enable {
 | 
				
			||||||
 | 
								gpio-export,name = "usb-enable";
 | 
				
			||||||
 | 
								gpio-export,output = <1>;
 | 
				
			||||||
 | 
								gpios = <&tlmm 55 GPIO_ACTIVE_HIGH>;
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
&tlmm {
 | 
					&tlmm {
 | 
				
			||||||
	pinctrl-0 = <&btcoex_pins>;
 | 
						pinctrl-0 = <&nrf52840_reset &usb_reset>;
 | 
				
			||||||
	pinctrl-names = "default";
 | 
						pinctrl-names = "default";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	btcoex_pins: btcoex_pins {
 | 
						nrf52840_reset: nrf52840_reset_pins {
 | 
				
			||||||
		mux_0 {
 | 
							pins = "gpio54";
 | 
				
			||||||
			pins = "gpio64";
 | 
							function = "gpio";
 | 
				
			||||||
			function = "pta1_1";
 | 
							drive-strength = <8>;
 | 
				
			||||||
			drive-strength = <6>;
 | 
							bias-disable;
 | 
				
			||||||
			bias-pull-down;
 | 
							output-high;
 | 
				
			||||||
		};
 | 
					 | 
				
			||||||
		mux_1 {
 | 
					 | 
				
			||||||
			pins = "gpio65";
 | 
					 | 
				
			||||||
			function = "pta1_2";
 | 
					 | 
				
			||||||
			drive-strength = <6>;
 | 
					 | 
				
			||||||
			bias-pull-down;
 | 
					 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						usb_reset: usb_reset_pins {
 | 
				
			||||||
 | 
							pins = "gpio55";
 | 
				
			||||||
 | 
							function = "gpio";
 | 
				
			||||||
 | 
							drive-strength = <8>;
 | 
				
			||||||
 | 
							bias-disable;
 | 
				
			||||||
 | 
							output-high;
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	mdio_pins: mdio_pinmux {
 | 
						mdio_pins: mdio_pinmux {
 | 
				
			||||||
@@ -172,17 +190,7 @@
 | 
				
			|||||||
		};
 | 
							};
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	hsuart_pins: hsuart_pins {
 | 
					 | 
				
			||||||
		mux {
 | 
					 | 
				
			||||||
			pins = "gpio49";
 | 
					 | 
				
			||||||
			function = "blsp2_uart";
 | 
					 | 
				
			||||||
			drive-strength = <8>;
 | 
					 | 
				
			||||||
			bias-disable;
 | 
					 | 
				
			||||||
		};
 | 
					 | 
				
			||||||
	};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	button_pins: button_pins {
 | 
						button_pins: button_pins {
 | 
				
			||||||
 | 
					 | 
				
			||||||
		reset_button {
 | 
							reset_button {
 | 
				
			||||||
			pins = "gpio66";
 | 
								pins = "gpio66";
 | 
				
			||||||
			function = "gpio";
 | 
								function = "gpio";
 | 
				
			||||||
@@ -220,31 +228,6 @@
 | 
				
			|||||||
			bias-pull-down;
 | 
								bias-pull-down;
 | 
				
			||||||
		};
 | 
							};
 | 
				
			||||||
	};
 | 
						};
 | 
				
			||||||
 | 
					 | 
				
			||||||
	usb_mux_sel_pins: usb_mux_pins {
 | 
					 | 
				
			||||||
		mux {
 | 
					 | 
				
			||||||
			pins = "gpio27";
 | 
					 | 
				
			||||||
			function = "gpio";
 | 
					 | 
				
			||||||
			drive-strength = <8>;
 | 
					 | 
				
			||||||
			bias-pull-down;
 | 
					 | 
				
			||||||
		};
 | 
					 | 
				
			||||||
	};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	pcie0_pins: pcie_pins {
 | 
					 | 
				
			||||||
		pcie0_rst {
 | 
					 | 
				
			||||||
			pins = "gpio58";
 | 
					 | 
				
			||||||
			function = "pcie0_rst";
 | 
					 | 
				
			||||||
			drive-strength = <8>;
 | 
					 | 
				
			||||||
			bias-pull-down;
 | 
					 | 
				
			||||||
		};
 | 
					 | 
				
			||||||
		pcie0_wake {
 | 
					 | 
				
			||||||
			pins = "gpio59";
 | 
					 | 
				
			||||||
			function = "pcie0_wake";
 | 
					 | 
				
			||||||
			drive-strength = <8>;
 | 
					 | 
				
			||||||
			bias-pull-down;
 | 
					 | 
				
			||||||
		};
 | 
					 | 
				
			||||||
	};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
&soc {
 | 
					&soc {
 | 
				
			||||||
@@ -733,12 +716,6 @@
 | 
				
			|||||||
	};
 | 
						};
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
&serial_blsp2 {
 | 
					 | 
				
			||||||
	pinctrl-0 = <&hsuart_pins>;
 | 
					 | 
				
			||||||
	pinctrl-names = "default";
 | 
					 | 
				
			||||||
	status = "ok";
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
&nss0 {
 | 
					&nss0 {
 | 
				
			||||||
	qcom,low-frequency = <187200000>;
 | 
						qcom,low-frequency = <187200000>;
 | 
				
			||||||
	qcom,mid-frequency = <748800000>;
 | 
						qcom,mid-frequency = <748800000>;
 | 
				
			||||||
@@ -812,7 +789,7 @@
 | 
				
			|||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
&pcie0 {
 | 
					&pcie0 {
 | 
				
			||||||
	status = "ok";
 | 
						status = "disabled";
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
&pcie1 {
 | 
					&pcie1 {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -18,6 +18,24 @@ 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/muxi_ap3220l
 | 
				
			||||||
 | 
					  DEVICE_TITLE := MUXI AP3220L
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq5018-muxi-ap3220l
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := muxi,ap3220l
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-muxi-ap3220l ath11k-firmware-ipq50xx-spruce ath11k-firmware-qcn6122
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@mp03.5-c1
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += muxi_ap3220l
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,6 +20,24 @@ define Device/hfcl_ion4xe
 | 
				
			|||||||
endef
 | 
					endef
 | 
				
			||||||
TARGET_DEVICES += hfcl_ion4xe
 | 
					TARGET_DEVICES += hfcl_ion4xe
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/hfcl_ion4x
 | 
				
			||||||
 | 
					  DEVICE_TITLE := HFCL ION4X
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq6018-hfcl-ion4x
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@cp01-c1
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := hfcl,ion4x
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-qcom-ipq6018 uboot-envtools
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += hfcl_ion4x
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/hfcl_ion4x_2
 | 
				
			||||||
 | 
					  DEVICE_TITLE := HFCL ION4X_2
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq6018-hfcl-ion4x_2
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@cp01-c1
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := hfcl,ion4x_2
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-qcom-ipq6018 uboot-envtools
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += hfcl_ion4x_2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
define Device/hfcl_ion4xi
 | 
					define Device/hfcl_ion4xi
 | 
				
			||||||
  DEVICE_TITLE := HFCL ION4Xi
 | 
					  DEVICE_TITLE := HFCL ION4Xi
 | 
				
			||||||
  DEVICE_DTS := qcom-ipq6018-hfcl-ion4xi
 | 
					  DEVICE_DTS := qcom-ipq6018-hfcl-ion4xi
 | 
				
			||||||
@@ -38,6 +56,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
 | 
				
			||||||
@@ -140,3 +185,13 @@ define Device/meshpp_s618_cp01
 | 
				
			|||||||
  DEVICE_PACKAGES := ath11k-wifi-meshpp-s618 -kmod-usb-dwc3-of-simple kmod-usb-dwc3-qcom kmod-usb3
 | 
					  DEVICE_PACKAGES := ath11k-wifi-meshpp-s618 -kmod-usb-dwc3-of-simple kmod-usb-dwc3-qcom kmod-usb3
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
TARGET_DEVICES += meshpp_s618_cp01
 | 
					TARGET_DEVICES += meshpp_s618_cp01
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Device/yuncore_fap650
 | 
				
			||||||
 | 
					  DEVICE_TITLE := YunCore FAP 650
 | 
				
			||||||
 | 
					  DEVICE_DTS := qcom-ipq6018-yuncore-fap650
 | 
				
			||||||
 | 
					  SUPPORTED_DEVICES := yuncore,fap650
 | 
				
			||||||
 | 
					  DEVICE_DTS_CONFIG := config@cp03-c1
 | 
				
			||||||
 | 
					  DEVICE_PACKAGES := ath11k-wifi-yuncore-fap650
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					TARGET_DEVICES += yuncore_fap650
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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
 | 
				
			||||||
@@ -0,0 +1,162 @@
 | 
				
			|||||||
 | 
					From cc809a441d8f2924f785eb863dfa6aef47a25b0b Mon Sep 17 00:00:00 2001
 | 
				
			||||||
 | 
					From: John Crispin <blogic@openwrt.org>
 | 
				
			||||||
 | 
					Date: Tue, 12 Aug 2014 20:49:27 +0200
 | 
				
			||||||
 | 
					Subject: [PATCH 30/36] GPIO: add named gpio exports
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Signed-off-by: John Crispin <blogic@openwrt.org>
 | 
				
			||||||
 | 
					--- a/drivers/gpio/gpiolib-of.c
 | 
				
			||||||
 | 
					+++ b/drivers/gpio/gpiolib-of.c
 | 
				
			||||||
 | 
					@@ -23,6 +23,8 @@
 | 
				
			||||||
 | 
					 #include <linux/pinctrl/pinctrl.h>
 | 
				
			||||||
 | 
					 #include <linux/slab.h>
 | 
				
			||||||
 | 
					 #include <linux/gpio/machine.h>
 | 
				
			||||||
 | 
					+#include <linux/init.h>
 | 
				
			||||||
 | 
					+#include <linux/platform_device.h>
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #include "gpiolib.h"
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					@@ -450,3 +452,72 @@ void of_gpiochip_remove(struct gpio_chip
 | 
				
			||||||
 | 
					 	gpiochip_remove_pin_ranges(chip);
 | 
				
			||||||
 | 
					 	of_node_put(chip->of_node);
 | 
				
			||||||
 | 
					 }
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+#ifdef CONFIG_GPIO_SYSFS
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+static struct of_device_id gpio_export_ids[] = {
 | 
				
			||||||
 | 
					+	{ .compatible = "gpio-export" },
 | 
				
			||||||
 | 
					+	{ /* sentinel */ }
 | 
				
			||||||
 | 
					+};
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+static int of_gpio_export_probe(struct platform_device *pdev)
 | 
				
			||||||
 | 
					+{
 | 
				
			||||||
 | 
					+	struct device_node *np = pdev->dev.of_node;
 | 
				
			||||||
 | 
					+	struct device_node *cnp;
 | 
				
			||||||
 | 
					+	u32 val;
 | 
				
			||||||
 | 
					+	int nb = 0;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	for_each_child_of_node(np, cnp) {
 | 
				
			||||||
 | 
					+		const char *name = NULL;
 | 
				
			||||||
 | 
					+		int gpio;
 | 
				
			||||||
 | 
					+		bool dmc;
 | 
				
			||||||
 | 
					+		int max_gpio = 1;
 | 
				
			||||||
 | 
					+		int i;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+		of_property_read_string(cnp, "gpio-export,name", &name);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+		if (!name)
 | 
				
			||||||
 | 
					+			max_gpio = of_gpio_count(cnp);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+		for (i = 0; i < max_gpio; i++) {
 | 
				
			||||||
 | 
					+			unsigned flags = 0;
 | 
				
			||||||
 | 
					+			enum of_gpio_flags of_flags;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			gpio = of_get_gpio_flags(cnp, i, &of_flags);
 | 
				
			||||||
 | 
					+			if (!gpio_is_valid(gpio))
 | 
				
			||||||
 | 
					+				return gpio;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			if (of_flags == OF_GPIO_ACTIVE_LOW)
 | 
				
			||||||
 | 
					+				flags |= GPIOF_ACTIVE_LOW;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			if (!of_property_read_u32(cnp, "gpio-export,output", &val))
 | 
				
			||||||
 | 
					+				flags |= val ? GPIOF_OUT_INIT_HIGH : GPIOF_OUT_INIT_LOW;
 | 
				
			||||||
 | 
					+			else
 | 
				
			||||||
 | 
					+				flags |= GPIOF_IN;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			if (devm_gpio_request_one(&pdev->dev, gpio, flags, name ? name : of_node_full_name(np)))
 | 
				
			||||||
 | 
					+				continue;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			dmc = of_property_read_bool(cnp, "gpio-export,direction_may_change");
 | 
				
			||||||
 | 
					+			gpio_export_with_name(gpio, dmc, name);
 | 
				
			||||||
 | 
					+			nb++;
 | 
				
			||||||
 | 
					+		}
 | 
				
			||||||
 | 
					+	}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	dev_info(&pdev->dev, "%d gpio(s) exported\n", nb);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	return 0;
 | 
				
			||||||
 | 
					+}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+static struct platform_driver gpio_export_driver = {
 | 
				
			||||||
 | 
					+	.driver		= {
 | 
				
			||||||
 | 
					+		.name		= "gpio-export",
 | 
				
			||||||
 | 
					+		.owner	= THIS_MODULE,
 | 
				
			||||||
 | 
					+		.of_match_table	= of_match_ptr(gpio_export_ids),
 | 
				
			||||||
 | 
					+	},
 | 
				
			||||||
 | 
					+	.probe		= of_gpio_export_probe,
 | 
				
			||||||
 | 
					+};
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+module_platform_driver(gpio_export_driver);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+#endif
 | 
				
			||||||
 | 
					--- a/include/asm-generic/gpio.h
 | 
				
			||||||
 | 
					+++ b/include/asm-generic/gpio.h
 | 
				
			||||||
 | 
					@@ -122,6 +122,12 @@ static inline int gpio_export(unsigned g
 | 
				
			||||||
 | 
					 	return gpiod_export(gpio_to_desc(gpio), direction_may_change);
 | 
				
			||||||
 | 
					 }
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+int __gpiod_export(struct gpio_desc *desc, bool direction_may_change, const char *name);
 | 
				
			||||||
 | 
					+static inline int gpio_export_with_name(unsigned gpio, bool direction_may_change, const char *name)
 | 
				
			||||||
 | 
					+{
 | 
				
			||||||
 | 
					+	return __gpiod_export(gpio_to_desc(gpio), direction_may_change, name);
 | 
				
			||||||
 | 
					+}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 static inline int gpio_export_link(struct device *dev, const char *name,
 | 
				
			||||||
 | 
					 				   unsigned gpio)
 | 
				
			||||||
 | 
					 {
 | 
				
			||||||
 | 
					--- a/include/linux/gpio/consumer.h
 | 
				
			||||||
 | 
					+++ b/include/linux/gpio/consumer.h
 | 
				
			||||||
 | 
					@@ -427,6 +427,7 @@ static inline struct gpio_desc *devm_get
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #if IS_ENABLED(CONFIG_GPIOLIB) && IS_ENABLED(CONFIG_GPIO_SYSFS)
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+int _gpiod_export(struct gpio_desc *desc, bool direction_may_change, const char *name);
 | 
				
			||||||
 | 
					 int gpiod_export(struct gpio_desc *desc, bool direction_may_change);
 | 
				
			||||||
 | 
					 int gpiod_export_link(struct device *dev, const char *name,
 | 
				
			||||||
 | 
					 		      struct gpio_desc *desc);
 | 
				
			||||||
 | 
					@@ -434,6 +435,13 @@ void gpiod_unexport(struct gpio_desc *de
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 #else  /* CONFIG_GPIOLIB && CONFIG_GPIO_SYSFS */
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+static inline int _gpiod_export(struct gpio_desc *desc,
 | 
				
			||||||
 | 
					+			       bool direction_may_change,
 | 
				
			||||||
 | 
					+			       const char *name)
 | 
				
			||||||
 | 
					+{
 | 
				
			||||||
 | 
					+	return -ENOSYS;
 | 
				
			||||||
 | 
					+}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 static inline int gpiod_export(struct gpio_desc *desc,
 | 
				
			||||||
 | 
					 			       bool direction_may_change)
 | 
				
			||||||
 | 
					 {
 | 
				
			||||||
 | 
					--- a/drivers/gpio/gpiolib-sysfs.c
 | 
				
			||||||
 | 
					+++ b/drivers/gpio/gpiolib-sysfs.c
 | 
				
			||||||
 | 
					@@ -544,7 +544,7 @@ static struct class gpio_class = {
 | 
				
			||||||
 | 
					  *
 | 
				
			||||||
 | 
					  * Returns zero on success, else an error.
 | 
				
			||||||
 | 
					  */
 | 
				
			||||||
 | 
					-int gpiod_export(struct gpio_desc *desc, bool direction_may_change)
 | 
				
			||||||
 | 
					+int __gpiod_export(struct gpio_desc *desc, bool direction_may_change, const char *name)
 | 
				
			||||||
 | 
					 {
 | 
				
			||||||
 | 
					 	struct gpio_chip	*chip;
 | 
				
			||||||
 | 
					 	struct gpiod_data	*data;
 | 
				
			||||||
 | 
					@@ -604,6 +604,8 @@ int gpiod_export(struct gpio_desc *desc,
 | 
				
			||||||
 | 
					 	offset = gpio_chip_hwgpio(desc);
 | 
				
			||||||
 | 
					 	if (chip->names && chip->names[offset])
 | 
				
			||||||
 | 
					 		ioname = chip->names[offset];
 | 
				
			||||||
 | 
					+	if (name)
 | 
				
			||||||
 | 
					+		ioname = name;
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 	dev = device_create_with_groups(&gpio_class, chip->dev,
 | 
				
			||||||
 | 
					 					MKDEV(0, 0), data, gpio_groups,
 | 
				
			||||||
 | 
					@@ -625,6 +627,12 @@ err_unlock:
 | 
				
			||||||
 | 
					 	gpiod_dbg(desc, "%s: status %d\n", __func__, status);
 | 
				
			||||||
 | 
					 	return status;
 | 
				
			||||||
 | 
					 }
 | 
				
			||||||
 | 
					+EXPORT_SYMBOL_GPL(__gpiod_export);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+int gpiod_export(struct gpio_desc *desc, bool direction_may_change)
 | 
				
			||||||
 | 
					+{
 | 
				
			||||||
 | 
					+	return __gpiod_export(desc, direction_may_change, NULL);
 | 
				
			||||||
 | 
					+}
 | 
				
			||||||
 | 
					 EXPORT_SYMBOL_GPL(gpiod_export);
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 static int match_export(struct device *dev, const void *desc)
 | 
				
			||||||
@@ -10,6 +10,7 @@ copy_certificates() {
 | 
				
			|||||||
	chown root.network /etc/ucentral/*.pem
 | 
						chown root.network /etc/ucentral/*.pem
 | 
				
			||||||
	chmod 0440 root.network /etc/ucentral/*.pem
 | 
						chmod 0440 root.network /etc/ucentral/*.pem
 | 
				
			||||||
	chmod 0400 /etc/ucentral/dev-id
 | 
						chmod 0400 /etc/ucentral/dev-id
 | 
				
			||||||
 | 
						[ -f /certificates/restrictions.json ] && cp /certificates/restrictions.json /etc/ucentral/
 | 
				
			||||||
	exit 0
 | 
						exit 0
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,7 +20,6 @@ var callReboot = rpc.declare({
 | 
				
			|||||||
	expect: { result: 0 }
 | 
						expect: { result: 0 }
 | 
				
			||||||
});
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
var mapdata = { actions: {}, config: {} };
 | 
					var mapdata = { actions: {}, config: {} };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
return view.extend({
 | 
					return view.extend({
 | 
				
			||||||
@@ -45,6 +44,26 @@ return view.extend({
 | 
				
			|||||||
		ui.awaitReconnect('192.168.1.1', 'openwrt.lan');
 | 
							ui.awaitReconnect('192.168.1.1', 'openwrt.lan');
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						handleDiagnostics: function(ev) {
 | 
				
			||||||
 | 
							return fs.exec('/sbin/diagnostic-bundle').then(function(result) {
 | 
				
			||||||
 | 
								var form = E('form', {
 | 
				
			||||||
 | 
									method: 'post',
 | 
				
			||||||
 | 
									action: L.env.cgi_base + '/cgi-download',
 | 
				
			||||||
 | 
									enctype: 'application/x-www-form-urlencoded'
 | 
				
			||||||
 | 
								}, [
 | 
				
			||||||
 | 
									E('input', { 'type': 'hidden', 'name': 'sessionid', 'value': L.env.sessionid }),
 | 
				
			||||||
 | 
									E('input', { 'type': 'hidden', 'name': 'path',      'value': '/tmp/bundle.maverick.tar.gz' }),
 | 
				
			||||||
 | 
									E('input', { 'type': 'hidden', 'name': 'filename',  'value': 'bundle.maverick.tar.gz' }),
 | 
				
			||||||
 | 
									E('input', { 'type': 'hidden', 'name': 'mimetype',  'value': 'application/gzip' })
 | 
				
			||||||
 | 
								]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								document.body.appendChild(form);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								form.submit();
 | 
				
			||||||
 | 
								form.parentNode.removeChild(form);
 | 
				
			||||||
 | 
							});
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	handleSysupgrade: function(ev) {
 | 
						handleSysupgrade: function(ev) {
 | 
				
			||||||
		return ui.uploadFile('/tmp/firmware.bin', ev.target.firstChild)
 | 
							return ui.uploadFile('/tmp/firmware.bin', ev.target.firstChild)
 | 
				
			||||||
			.then(L.bind(function(btn, reply) {
 | 
								.then(L.bind(function(btn, reply) {
 | 
				
			||||||
@@ -171,6 +190,16 @@ return view.extend({
 | 
				
			|||||||
		o.inputtitle = _('Flash image…');
 | 
							o.inputtitle = _('Flash image…');
 | 
				
			||||||
		o.onclick = L.bind(this.handleSysupgrade, this);
 | 
							o.onclick = L.bind(this.handleSysupgrade, this);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							o = s.option(form.SectionValue, 'actions', form.NamedSection, 'actions', 'actions', _('Diagnostic bundle'),
 | 
				
			||||||
 | 
								_('Download the default diagnostic bundle from the AP.'));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							ss = o.subsection;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							o = ss.option(form.Button, 'Diagnostic');
 | 
				
			||||||
 | 
							o.inputstyle = 'action important';
 | 
				
			||||||
 | 
							o.inputtitle = _('Download Diagnostics');
 | 
				
			||||||
 | 
							o.onclick = L.bind(this.handleDiagnostics, this);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		return m.render();
 | 
							return m.render();
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										8
									
								
								feeds/tip/luci/luci-mod-ucentral/root/sbin/diagnostic-bundle
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										8
									
								
								feeds/tip/luci/luci-mod-ucentral/root/sbin/diagnostic-bundle
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,8 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/ucode
 | 
				
			||||||
 | 
					push(REQUIRE_SEARCH_PATH, '/usr/share/ucentral/*.uc');
 | 
				
			||||||
 | 
					let bundle = require('bundle');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bundle.init('maverick');
 | 
				
			||||||
 | 
					include('/usr/share/ucentral/diagnostic.uc', { bundle });
 | 
				
			||||||
 | 
					bundle.complete();
 | 
				
			||||||
 | 
					system('chmod +r /tmp/bundle.maverick.tar.gz');
 | 
				
			||||||
@@ -2,10 +2,12 @@
 | 
				
			|||||||
	"luci-mod-ucentral": {
 | 
						"luci-mod-ucentral": {
 | 
				
			||||||
		"description": "Grant access to ucentral configuration",
 | 
							"description": "Grant access to ucentral configuration",
 | 
				
			||||||
		"read": {
 | 
							"read": {
 | 
				
			||||||
 | 
								"cgi-io": [ "download" ],
 | 
				
			||||||
			"file": {
 | 
								"file": {
 | 
				
			||||||
				"/etc/ucentral/profile.json": [ "read" ],
 | 
									"/etc/ucentral/profile.json": [ "read" ],
 | 
				
			||||||
				"/proc/mounts": [ "read" ],
 | 
									"/proc/mounts": [ "read" ],
 | 
				
			||||||
				"/proc/mtd": [ "read" ]
 | 
									"/proc/mtd": [ "read" ],
 | 
				
			||||||
 | 
									"/tmp/bundle.maverick.tar.gz": [ "read" ]
 | 
				
			||||||
			},
 | 
								},
 | 
				
			||||||
			"ubus": {
 | 
								"ubus": {
 | 
				
			||||||
				"file": [ "read" ],
 | 
									"file": [ "read" ],
 | 
				
			||||||
@@ -17,6 +19,7 @@
 | 
				
			|||||||
			"file": {
 | 
								"file": {
 | 
				
			||||||
				"/etc/ucentral/profile.json": [ "write" ],
 | 
									"/etc/ucentral/profile.json": [ "write" ],
 | 
				
			||||||
				"/sbin/certupdate": [ "exec" ],
 | 
									"/sbin/certupdate": [ "exec" ],
 | 
				
			||||||
 | 
									"/sbin/diagnostic-bundle": [ "exec" ],
 | 
				
			||||||
				"/sbin/firstboot -r -y": [ "exec" ],
 | 
									"/sbin/firstboot -r -y": [ "exec" ],
 | 
				
			||||||
				"/sbin/profileupdate": [ "exec" ],
 | 
									"/sbin/profileupdate": [ "exec" ],
 | 
				
			||||||
				"/sbin/sysupgrade -n /tmp/firmware.bin": [ "exec" ],
 | 
									"/sbin/sysupgrade -n /tmp/firmware.bin": [ "exec" ],
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -52,6 +52,6 @@ start_service() {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
service_started() {
 | 
					service_started() {
 | 
				
			||||||
	ubus -t 10 wait_for atfpolicy
 | 
						ubus -t 2 wait_for atfpolicy
 | 
				
			||||||
	[ $? = 0 ] && reload_service
 | 
						[ $? = 0 ] && reload_service
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -152,13 +152,13 @@ radius_forward_gw(char *buf, enum socket_type type)
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int
 | 
					static int
 | 
				
			||||||
radius_parse(char *buf, int len, int port, enum socket_type type, int tx)
 | 
					radius_parse(char *buf, unsigned int len, int port, enum socket_type type, int tx)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct radius_header *hdr = (struct radius_header *) buf;
 | 
						struct radius_header *hdr = (struct radius_header *) buf;
 | 
				
			||||||
	struct radius_tlv *proxy_state = NULL;
 | 
						struct radius_tlv *proxy_state = NULL;
 | 
				
			||||||
	char proxy_state_str[256] = {};
 | 
						char proxy_state_str[256] = {};
 | 
				
			||||||
	void *avp = hdr->avp;
 | 
						void *avp = hdr->avp;
 | 
				
			||||||
	int len_orig = ntohs(hdr->len);
 | 
						unsigned int len_orig = ntohs(hdr->len);
 | 
				
			||||||
	uint8_t localhost[] = { 0x7f, 0, 0, 1 };
 | 
						uint8_t localhost[] = { 0x7f, 0, 0, 1 };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (len_orig != len) {
 | 
						if (len_orig != len) {
 | 
				
			||||||
@@ -170,10 +170,10 @@ radius_parse(char *buf, int len, int port, enum socket_type type, int tx)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	len -= sizeof(*hdr);
 | 
						len -= sizeof(*hdr);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	while (len > 0) {
 | 
						while (len >= sizeof(struct radius_tlv)) {
 | 
				
			||||||
		struct radius_tlv *tlv = (struct radius_tlv *)avp;
 | 
							struct radius_tlv *tlv = (struct radius_tlv *)avp;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (len < tlv->len) {
 | 
							if (len < tlv->len || tlv->len < sizeof(*tlv)) {
 | 
				
			||||||
			ULOG_ERR("invalid TLV length\n");
 | 
								ULOG_ERR("invalid TLV length\n");
 | 
				
			||||||
			return -1;
 | 
								return -1;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
@@ -312,7 +312,7 @@ sock_recv(struct uloop_fd *u, unsigned int events)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
		inet_ntop(AF_INET, &sin.sin_addr, addr_str, sizeof(addr_str));
 | 
							inet_ntop(AF_INET, &sin.sin_addr, addr_str, sizeof(addr_str));
 | 
				
			||||||
		printf("RX: src:%s:%d, len=%d\n", addr_str, sin.sin_port, len);
 | 
							printf("RX: src:%s:%d, len=%d\n", addr_str, sin.sin_port, len);
 | 
				
			||||||
		radius_parse(buf, len, sin.sin_port, sock->type, 1);
 | 
							radius_parse(buf, (unsigned int)len, sin.sin_port, sock->type, 1);
 | 
				
			||||||
	} while (1);
 | 
						} while (1);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,11 +3,15 @@
 | 
				
			|||||||
[ "${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 ] || return
 | 
				
			||||||
 | 
						kill "$(cat /tmp/run/hostapd-cli-$INTERFACE.pid)"
 | 
				
			||||||
 | 
						rm /tmp/run/hostapd-cli-$INTERFACE.pid
 | 
				
			||||||
	exit 0
 | 
						exit 0
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[ "$ACTION" == add ] && {
 | 
					[ "$ACTION" == add ] && {
 | 
				
			||||||
	ratelimit waitiface $INTERFACE &
 | 
						[ -f /tmp/run/hostapd-cli-$INTERFACE.pid ] && return
 | 
				
			||||||
 | 
						touch /tmp/run/hostapd-cli-$INTERFACE.pid
 | 
				
			||||||
 | 
						/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);
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	[ "$egress" -eq 0 -o $ingress -eq 0 ] && {
 | 
								return ret;
 | 
				
			||||||
		logger "ratelimit: no valid rates"
 | 
							},
 | 
				
			||||||
		exit 1
 | 
							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];
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	local id=$(get_id ${mac//:})
 | 
						if (update && !ops.client.set(device, client)) {
 | 
				
			||||||
 | 
							del_client(device, client.address);
 | 
				
			||||||
	logger "ratelimit: add new client entries for $1 $2 $egress $ingress"
 | 
							return false;
 | 
				
			||||||
 | 
					 | 
				
			||||||
	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() {
 | 
					 | 
				
			||||||
	local ifb=rateifb$1
 | 
					 | 
				
			||||||
	local iface=$1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	[ -d /sys/class/net/$ifb/ ] || return 0
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	logger "ratelimit: deleting old iface settings"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	IP link set $ifb down
 | 
					 | 
				
			||||||
	IP link del $ifb
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	TC qdisc del dev $iface root &2> /dev/null
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	rm -f /tmp/ratelimit.$iface
 | 
					 | 
				
			||||||
	[ -f /tmp/run/hostapd-cli-$iface.pid ] && kill "$(cat /tmp/run/hostapd-cli-$iface.pid)"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
found=0
 | 
					 | 
				
			||||||
find_ssid() {
 | 
					 | 
				
			||||||
	local ssid
 | 
					 | 
				
			||||||
	config_get ssid $1 ssid
 | 
					 | 
				
			||||||
	[ "$ssid" == "$2" ] || return
 | 
					 | 
				
			||||||
	found=1
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
addiface() {
 | 
					 | 
				
			||||||
	local ifb=rateifb$1
 | 
					 | 
				
			||||||
	local iface=$1
 | 
					 | 
				
			||||||
	local ssid
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	[ -f /tmp/ratelimit.$iface -o -d /sys/class/net/$ifb/ ] && {
 | 
					 | 
				
			||||||
		return 0
 | 
					 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	echo -n startup > /tmp/ratelimit.$iface
 | 
						return true;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	sleep 2
 | 
					function run_service() {
 | 
				
			||||||
	ssid=$(ubus call hostapd.$iface get_status | jsonfilter -e '@.ssid')
 | 
						let uctx = ubus.connect();
 | 
				
			||||||
	[ -z "$ssid" ] && {
 | 
					
 | 
				
			||||||
		rm /tmp/ratelimit.$iface
 | 
						uctx.publish("ratelimit", {
 | 
				
			||||||
		logger "ratelimit: failed to lookup ssid"
 | 
							defaults_set: {
 | 
				
			||||||
		exit 1
 | 
								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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (!name || !r_i || !r_e)
 | 
				
			||||||
 | 
										return ubus.STATUS_INVALID_ARGUMENT;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									defaults[name] = [ r_e, r_i ];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									return 0;
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								args: {
 | 
				
			||||||
 | 
									name:"",
 | 
				
			||||||
 | 
									rate:"",
 | 
				
			||||||
 | 
									rate_ingress:"",
 | 
				
			||||||
 | 
									rate_egress:"",
 | 
				
			||||||
			}
 | 
								}
 | 
				
			||||||
	config_load ratelimit
 | 
							},
 | 
				
			||||||
	config_foreach find_ssid rate $ssid
 | 
							client_set: {
 | 
				
			||||||
	[ "$found" -eq 0 ] && {
 | 
								call: function(req) {
 | 
				
			||||||
		rm /tmp/ratelimit.$iface
 | 
									let r_i = req.args.rate_ingress ?? req.args.rate;
 | 
				
			||||||
		exit 0
 | 
									let r_e = req.args.rate_egress ?? req.args.rate;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (req.args.defaults && defaults[req.args.defaults]) {
 | 
				
			||||||
 | 
										let def = defaults[req.args.defaults];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
										r_e ??= def[0];
 | 
				
			||||||
 | 
										r_i ??= def[1];
 | 
				
			||||||
				}
 | 
									}
 | 
				
			||||||
	logger "ratelimit: adding new iface settings"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	echo -n $ssid > /tmp/ratelimit.$iface
 | 
									if (!req.args.device || !req.args.address || !r_i || !r_e)
 | 
				
			||||||
 | 
										return ubus.STATUS_INVALID_ARGUMENT;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	IP link add name $ifb type ifb
 | 
									let device = get_device(devices, req.args.device);
 | 
				
			||||||
	IP link set $ifb up
 | 
									if (!device)
 | 
				
			||||||
 | 
										return ubus.STATUS_INVALID_ARGUMENT;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	sleep 1
 | 
									let client = get_client(device, req.args.address);
 | 
				
			||||||
 | 
									if (!client)
 | 
				
			||||||
 | 
										return ubus.STATUS_INVALID_ARGUMENT;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	TC qdisc add dev $iface root handle 1: htb default 30
 | 
									let data = {
 | 
				
			||||||
	TC class add dev $iface parent 1: classid 1:1 htb rate 1000mbit burst 6k
 | 
										rate_ingress: r_i,
 | 
				
			||||||
	TC qdisc add dev $iface ingress
 | 
										rate_egress: r_e
 | 
				
			||||||
	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
 | 
									if (!set_client(device, client, data))
 | 
				
			||||||
	TC class add dev $ifb parent 1: classid 1:1 htb rate 100mbit
 | 
										return ubus.STATUS_UNKNOWN_ERROR;
 | 
				
			||||||
	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
 | 
									return 0;
 | 
				
			||||||
		addclient $iface $sta
 | 
								},
 | 
				
			||||||
	done
 | 
								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}`);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for (let dev in devices) {
 | 
				
			||||||
 | 
							del_device(dev);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -33,6 +33,18 @@ static uint32_t client_gettime(void)
 | 
				
			|||||||
	return ts.tv_sec;
 | 
						return ts.tv_sec;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static bool client_is_active(const uint8_t *mac)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						struct interface *iface;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						avl_for_each_element(&interfaces, iface, node) {
 | 
				
			||||||
 | 
							if (avl_find(&iface->clients, mac))
 | 
				
			||||||
 | 
								return true;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return false;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void client_gc(struct uloop_timeout *t)
 | 
					static void client_gc(struct uloop_timeout *t)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	struct cache_entry *c, *tmp;
 | 
						struct cache_entry *c, *tmp;
 | 
				
			||||||
@@ -41,6 +53,11 @@ static void client_gc(struct uloop_timeout *t)
 | 
				
			|||||||
	avl_for_each_element_safe(&cache, c, node, tmp) {
 | 
						avl_for_each_element_safe(&cache, c, node, tmp) {
 | 
				
			||||||
		uint32_t diff;
 | 
							uint32_t diff;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (client_is_active(c->macaddr)) {
 | 
				
			||||||
 | 
								c->time = now;
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		diff = now - c->time;
 | 
							diff = now - c->time;
 | 
				
			||||||
		if (diff < CACHE_TIMEOUT)
 | 
							if (diff < CACHE_TIMEOUT)
 | 
				
			||||||
			continue;
 | 
								continue;
 | 
				
			||||||
@@ -65,6 +82,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 +115,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 +161,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,13 +156,11 @@ 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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (iface->client_autoremove)
 | 
				
			||||||
			client_free(iface, cl);
 | 
								client_free(iface, cl);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -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;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -249,6 +248,7 @@ int spotfilter_nl80211_init(void)
 | 
				
			|||||||
	genl_cb = nl_cb_alloc(NL_CB_DEFAULT);
 | 
						genl_cb = nl_cb_alloc(NL_CB_DEFAULT);
 | 
				
			||||||
	nl_cb_set(genl_cb, NL_CB_SEQ_CHECK, NL_CB_CUSTOM, no_seq_check, NULL);
 | 
						nl_cb_set(genl_cb, NL_CB_SEQ_CHECK, NL_CB_CUSTOM, no_seq_check, NULL);
 | 
				
			||||||
	nl_cb_set(genl_cb, NL_CB_VALID, NL_CB_CUSTOM, valid_msg, NULL);
 | 
						nl_cb_set(genl_cb, NL_CB_VALID, NL_CB_CUSTOM, valid_msg, NULL);
 | 
				
			||||||
 | 
						nl_socket_set_cb(genl, genl_cb);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	genl_fd.fd = nl_socket_get_fd(genl);
 | 
						genl_fd.fd = nl_socket_get_fd(genl);
 | 
				
			||||||
	genl_fd.cb = nl80211_sock_cb;
 | 
						genl_fd.cb = nl80211_sock_cb;
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -158,8 +158,8 @@ 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;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -204,9 +204,11 @@ 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);
 | 
				
			||||||
	if ((iph = skb_parse_ipv4(&info, sizeof(struct udphdr))) != NULL) {
 | 
						if ((iph = skb_parse_ipv4(&info, sizeof(struct udphdr))) != NULL) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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,7 +247,9 @@ 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_string(&b, "device", cl->device);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	blobmsg_add_u32(&b, "idle", cl->idle);
 | 
						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);
 | 
				
			||||||
@@ -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:=8e53167e08d36e43ad00819f3bbe882f6957e995f075fa37141b3e8944f3688b
 | 
				
			||||||
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:=5f69da72973409cc63b9991e4c183f8deb5ab0a9
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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:=52c322f964bf66e9d559c26dc9e7ca868a49ae1894b23c7581cb60effd48371c
 | 
				
			||||||
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:=ad84690d77cc80f9017d634fdee5053d29f17262
 | 
				
			||||||
 | 
					
 | 
				
			||||||
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
 | 
				
			||||||
@@ -96,6 +96,7 @@
 | 
				
			|||||||
			"auth-server": "radius.hotspotsystem.com",
 | 
								"auth-server": "radius.hotspotsystem.com",
 | 
				
			||||||
			"auth-port": 1812,
 | 
								"auth-port": 1812,
 | 
				
			||||||
			"auth-secret": "hotsys123",
 | 
								"auth-secret": "hotsys123",
 | 
				
			||||||
 | 
								"final-redirect-url": "uam",
 | 
				
			||||||
			"walled-garden-fqdn": [
 | 
								"walled-garden-fqdn": [
 | 
				
			||||||
				"*.google.com", "telecominfraproject.com", "customer.hotspotsystem.com"
 | 
									"*.google.com", "telecominfraproject.com", "customer.hotspotsystem.com"
 | 
				
			||||||
			]
 | 
								]
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,138 @@
 | 
				
			|||||||
 | 
					{
 | 
				
			||||||
 | 
					    "interfaces": [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            "name": "WAN-GRE",
 | 
				
			||||||
 | 
					            "role": "upstream",
 | 
				
			||||||
 | 
					            "services": [
 | 
				
			||||||
 | 
					                "wifi-steering"
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            "ssids": [
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                    "bss-mode": "ap",
 | 
				
			||||||
 | 
					                    "disassoc-low-ack": true,
 | 
				
			||||||
 | 
					                    "encryption": {
 | 
				
			||||||
 | 
					                        "proto": "none"
 | 
				
			||||||
 | 
					                    },
 | 
				
			||||||
 | 
					                    "hidden-ssid": false,
 | 
				
			||||||
 | 
					                    "isolate-clients": true,
 | 
				
			||||||
 | 
					                    "maximum-clients": 64,
 | 
				
			||||||
 | 
					                    "name": "..izzi WiFi",
 | 
				
			||||||
 | 
					                    "services": [
 | 
				
			||||||
 | 
					                        "dhcp-snooping"
 | 
				
			||||||
 | 
					                    ],
 | 
				
			||||||
 | 
					                    "wifi-bands": [
 | 
				
			||||||
 | 
					                        "2G",
 | 
				
			||||||
 | 
					                        "5G"
 | 
				
			||||||
 | 
					                    ]
 | 
				
			||||||
 | 
					                },
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            "tunnel": {
 | 
				
			||||||
 | 
					                "peer-address": "2405:200:802:600:61::2",
 | 
				
			||||||
 | 
					                "proto": "gre6"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            "ethernet": [
 | 
				
			||||||
 | 
					                {
 | 
				
			||||||
 | 
					                    "select-ports": [
 | 
				
			||||||
 | 
					                        "WAN*"
 | 
				
			||||||
 | 
					                    ]
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            "ipv4": {
 | 
				
			||||||
 | 
					                "addressing": "dynamic"
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            "name": "WAN",
 | 
				
			||||||
 | 
					            "role": "upstream",
 | 
				
			||||||
 | 
					            "ssids": []
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    ],
 | 
				
			||||||
 | 
					    "metrics": {
 | 
				
			||||||
 | 
					        "dhcp-snooping": {
 | 
				
			||||||
 | 
					            "filters": [
 | 
				
			||||||
 | 
					                "ack",
 | 
				
			||||||
 | 
					                "discover",
 | 
				
			||||||
 | 
					                "offer",
 | 
				
			||||||
 | 
					                "request",
 | 
				
			||||||
 | 
					                "solicit",
 | 
				
			||||||
 | 
					                "reply",
 | 
				
			||||||
 | 
					                "renew"
 | 
				
			||||||
 | 
					            ]
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "health": {
 | 
				
			||||||
 | 
					            "interval": 60
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "statistics": {
 | 
				
			||||||
 | 
					            "interval": 60,
 | 
				
			||||||
 | 
					            "types": [
 | 
				
			||||||
 | 
					                "ssids",
 | 
				
			||||||
 | 
					                "lldp",
 | 
				
			||||||
 | 
					                "clients"
 | 
				
			||||||
 | 
					            ]
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "wifi-frames": {
 | 
				
			||||||
 | 
					            "filters": [
 | 
				
			||||||
 | 
					                "probe",
 | 
				
			||||||
 | 
					                "auth",
 | 
				
			||||||
 | 
					                "assoc",
 | 
				
			||||||
 | 
					                "disassoc",
 | 
				
			||||||
 | 
					                "deauth",
 | 
				
			||||||
 | 
					                "local-deauth",
 | 
				
			||||||
 | 
					                "inactive-deauth",
 | 
				
			||||||
 | 
					                "key-mismatch",
 | 
				
			||||||
 | 
					                "beacon-report",
 | 
				
			||||||
 | 
					                "radar-detected"
 | 
				
			||||||
 | 
					            ]
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "radios": [
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            "band": "2G",
 | 
				
			||||||
 | 
					            "bandwidth": 20,
 | 
				
			||||||
 | 
					            "beacon-interval": 100,
 | 
				
			||||||
 | 
					            "channel": "auto",
 | 
				
			||||||
 | 
					            "channel-mode": "VHT",
 | 
				
			||||||
 | 
					            "channel-width": 20,
 | 
				
			||||||
 | 
					            "country": "CA",
 | 
				
			||||||
 | 
					            "dtim-period": 2,
 | 
				
			||||||
 | 
					            "maximum-clients": 64,
 | 
				
			||||||
 | 
					            "mimo": "2x2",
 | 
				
			||||||
 | 
					            "rates": {
 | 
				
			||||||
 | 
					                "beacon": 6000,
 | 
				
			||||||
 | 
					                "multicast": 24000
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            "require-mode": "VHT",
 | 
				
			||||||
 | 
					            "tx-power": 22
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        {
 | 
				
			||||||
 | 
					            "band": "5G",
 | 
				
			||||||
 | 
					            "bandwidth": 20,
 | 
				
			||||||
 | 
					            "beacon-interval": 100,
 | 
				
			||||||
 | 
					            "channel": "auto",
 | 
				
			||||||
 | 
					            "channel-mode": "VHT",
 | 
				
			||||||
 | 
					            "channel-width": 40,
 | 
				
			||||||
 | 
					            "country": "CA",
 | 
				
			||||||
 | 
					            "dtim-period": 2,
 | 
				
			||||||
 | 
					            "maximum-clients": 64,
 | 
				
			||||||
 | 
					            "mimo": "2x2",
 | 
				
			||||||
 | 
					            "rates": {
 | 
				
			||||||
 | 
					                "beacon": 6000,
 | 
				
			||||||
 | 
					                "multicast": 24000
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					            "require-mode": "VHT",
 | 
				
			||||||
 | 
					            "tx-power": 22
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    ],
 | 
				
			||||||
 | 
					    "services": {
 | 
				
			||||||
 | 
					        "wifi-steering": {
 | 
				
			||||||
 | 
					            "assoc-steering": true,
 | 
				
			||||||
 | 
					            "auto-channel": false,
 | 
				
			||||||
 | 
					            "load-kick-threshold": 80,
 | 
				
			||||||
 | 
					            "mode": "local",
 | 
				
			||||||
 | 
					            "required-probe-snr": -75,
 | 
				
			||||||
 | 
					            "required-roam-snr": -70,
 | 
				
			||||||
 | 
					            "required-snr": 0
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "uuid": 1660159074
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,89 @@
 | 
				
			|||||||
 | 
					{
 | 
				
			||||||
 | 
						"uuid": 2,
 | 
				
			||||||
 | 
						"radios": [
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								"band": "2G",
 | 
				
			||||||
 | 
								"country": "CA",
 | 
				
			||||||
 | 
								"channel-mode": "HE",
 | 
				
			||||||
 | 
								"channel-width": 80,
 | 
				
			||||||
 | 
								"channel": 32
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						],
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						"interfaces": [
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								"name": "WAN",
 | 
				
			||||||
 | 
								"role": "upstream",
 | 
				
			||||||
 | 
								"services": [ "lldp" ],
 | 
				
			||||||
 | 
								"ethernet": [
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										"select-ports": [
 | 
				
			||||||
 | 
											"WAN*"
 | 
				
			||||||
 | 
										]
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								],
 | 
				
			||||||
 | 
								"ipv4": {
 | 
				
			||||||
 | 
									"addressing": "dynamic"
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								"ssids": [
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										"name": "OpenWifi",
 | 
				
			||||||
 | 
										"wifi-bands": [
 | 
				
			||||||
 | 
											"2G"
 | 
				
			||||||
 | 
										],
 | 
				
			||||||
 | 
										"bss-mode": "ap",
 | 
				
			||||||
 | 
										"encryption": {
 | 
				
			||||||
 | 
											"proto": "psk2",
 | 
				
			||||||
 | 
											"key": "OpenWifi",
 | 
				
			||||||
 | 
											"ieee80211w": "optional"
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
										"quality-thresholds" : {
 | 
				
			||||||
 | 
											"probe-request-rssi": -35,
 | 
				
			||||||
 | 
											"assoctiation-request-rssi": -35,
 | 
				
			||||||
 | 
											"client-kick-rssi": -45,
 | 
				
			||||||
 | 
											"client-kick-ban-time": 60
 | 
				
			||||||
 | 
										}
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								]
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								"name": "LAN",
 | 
				
			||||||
 | 
								"role": "downstream",
 | 
				
			||||||
 | 
								"services": [ "ssh", "lldp" ],
 | 
				
			||||||
 | 
								"ethernet": [
 | 
				
			||||||
 | 
									{
 | 
				
			||||||
 | 
										"select-ports": [
 | 
				
			||||||
 | 
											"LAN*"
 | 
				
			||||||
 | 
										]
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								],
 | 
				
			||||||
 | 
								"ipv4": {
 | 
				
			||||||
 | 
									"addressing": "static",
 | 
				
			||||||
 | 
									"subnet": "192.168.1.1/24",
 | 
				
			||||||
 | 
									"dhcp": {
 | 
				
			||||||
 | 
										"lease-first": 10,
 | 
				
			||||||
 | 
										"lease-count": 100,
 | 
				
			||||||
 | 
										"lease-time": "6h"
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						],
 | 
				
			||||||
 | 
						"metrics": {
 | 
				
			||||||
 | 
							"statistics": {
 | 
				
			||||||
 | 
								"interval": 120,
 | 
				
			||||||
 | 
								"types": [ "ssids", "lldp", "clients" ]
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							"health": {
 | 
				
			||||||
 | 
								"interval": 120
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						"services": {
 | 
				
			||||||
 | 
							"lldp": {
 | 
				
			||||||
 | 
								"describe": "uCentral",
 | 
				
			||||||
 | 
								"location": "universe"
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
							"ssh": {
 | 
				
			||||||
 | 
								"port": 22
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -0,0 +1,16 @@
 | 
				
			|||||||
 | 
					bundle.wifi();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					let paths = [
 | 
				
			||||||
 | 
					        [ 'network.wireless', 'status' ],
 | 
				
			||||||
 | 
					        [ 'network.device', 'status' ],
 | 
				
			||||||
 | 
					        [ 'network.interface', 'dump' ],
 | 
				
			||||||
 | 
					        [ 'log', 'read', { stream: false } ],
 | 
				
			||||||
 | 
					];
 | 
				
			||||||
 | 
					for (let path in paths)
 | 
				
			||||||
 | 
					        bundle.ubus(path[0], path[1], path[2]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					for (let config in [ 'network', 'wireless', 'dhcp', 'firewall', 'system' ])
 | 
				
			||||||
 | 
					        bundle.uci(config);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					for (let cmd in [ "route", "ifconfig", "logread" ])
 | 
				
			||||||
 | 
					        bundle.shell(cmd);
 | 
				
			||||||
@@ -0,0 +1,64 @@
 | 
				
			|||||||
 | 
					push(REQUIRE_SEARCH_PATH, '/usr/share/ucentral/*.uc');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					let ubus = require('ubus').connect();
 | 
				
			||||||
 | 
					let uci = require('uci').cursor();
 | 
				
			||||||
 | 
					let fs = require('fs');
 | 
				
			||||||
 | 
					let w_iface = require('wifi.iface');
 | 
				
			||||||
 | 
					let w_sta = require('wifi.station');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						init: function(id) {
 | 
				
			||||||
 | 
							this.id = id || 0;
 | 
				
			||||||
 | 
							this.path = `/tmp/bundle.${this.id}/`;
 | 
				
			||||||
 | 
							fs.mkdir(this.path);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						complete: function() {
 | 
				
			||||||
 | 
							if (!this.path)
 | 
				
			||||||
 | 
								return;
 | 
				
			||||||
 | 
							system(`tar cfz /tmp/bundle.${this.id}.tar.gz ${this.path}`);
 | 
				
			||||||
 | 
							system(`rm -r ${this.path}`);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						add: function(name, data) {
 | 
				
			||||||
 | 
							if (!this.path)
 | 
				
			||||||
 | 
								return;
 | 
				
			||||||
 | 
							let file = fs.open(this.path + name, 'w');
 | 
				
			||||||
 | 
							file.write(data);
 | 
				
			||||||
 | 
							file.close();
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ubus: function(object, method, args) {
 | 
				
			||||||
 | 
							if (!object || !method)
 | 
				
			||||||
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							let data = ubus.call(object, method, args || {});
 | 
				
			||||||
 | 
							this.add(`ubus-${object}:${method}`, data);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						uci: function(config, section) {
 | 
				
			||||||
 | 
							if (!config)
 | 
				
			||||||
 | 
								return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							let data = uci.get_all(config, section) || {};
 | 
				
			||||||
 | 
							let name = `uci-${config}` + (section ? `.${section}` : '');
 | 
				
			||||||
 | 
							this.add(name, data);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						wifi: function() {
 | 
				
			||||||
 | 
							this.add('wifi-iface', w_iface);
 | 
				
			||||||
 | 
							this.add('wifi-station', w_sta);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						shell: function(name, command) {
 | 
				
			||||||
 | 
							if (!command)
 | 
				
			||||||
 | 
								command = name;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							let fp = fs.popen(command);
 | 
				
			||||||
 | 
						        let data = fp.read('all');
 | 
				
			||||||
 | 
							fp.close();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							this.add(`shell-${name}`, data);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -306,4 +306,6 @@ VALUE		Add-Port-To-IP-Address	Yes			1
 | 
				
			|||||||
#$INCLUDE /etc/radcli/dictionary.microsoft
 | 
					#$INCLUDE /etc/radcli/dictionary.microsoft
 | 
				
			||||||
#$INCLUDE /etc/radcli/dictionary.roaringpenguin
 | 
					#$INCLUDE /etc/radcli/dictionary.roaringpenguin
 | 
				
			||||||
$INCLUDE /etc/radcli/dictionary.WISPr
 | 
					$INCLUDE /etc/radcli/dictionary.WISPr
 | 
				
			||||||
 | 
					$INCLUDE /etc/radcli/dictionary.CoovaChilli
 | 
				
			||||||
 | 
					$INCLUDE /etc/radcli/dictionary.chillispot
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					VENDOR		CoovaChilli	14122	CoovaChilli
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ATTRIBUTE	CoovaChilli-Max-Input-Octets	1	integer	CoovaChilli
 | 
				
			||||||
 | 
					ATTRIBUTE	CoovaChilli-Max-Output-Octets	2	integer	CoovaChilli
 | 
				
			||||||
 | 
					ATTRIBUTE	CoovaChilli-Max-Total-Octets	3	integer	CoovaChilli
 | 
				
			||||||
@@ -0,0 +1,14 @@
 | 
				
			|||||||
 | 
					VENDOR	ChilliSpot	14559 ChilliSpot
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Max-Input-Octets		1	integer	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Max-Output-Octets		2	integer	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Max-Total-Octets		3	integer	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Bandwidth-Max-Up		4	integer	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Bandwidth-Max-Down		5	integer	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Config			6	string	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Lang				7	string	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Version			8	string	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-OriginalURL			9	string	ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-UAM-Allowed			100	string ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-MAC-Allowed			101	string ChilliSpot
 | 
				
			||||||
 | 
					ATTRIBUTE	ChilliSpot-Interval			102	integer ChilliSpot
 | 
				
			||||||
@@ -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 },
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										13
									
								
								feeds/ucentral/ucode/patches/0002-ubus-fix.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								feeds/ucentral/ucode/patches/0002-ubus-fix.patch
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,13 @@
 | 
				
			|||||||
 | 
					Index: ucode-2022-04-07-7fa59ce4/lib/uloop.c
 | 
				
			||||||
 | 
					===================================================================
 | 
				
			||||||
 | 
					--- ucode-2022-04-07-7fa59ce4.orig/lib/uloop.c
 | 
				
			||||||
 | 
					+++ ucode-2022-04-07-7fa59ce4/lib/uloop.c
 | 
				
			||||||
 | 
					@@ -971,6 +971,8 @@ uc_uloop_task(uc_vm_t *vm, size_t nargs)
 | 
				
			||||||
 | 
					 		err_return(errno);
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 	if (pid == 0) {
 | 
				
			||||||
 | 
					+		uloop_done();
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 		patch_devnull(0, false);
 | 
				
			||||||
 | 
					 		patch_devnull(1, true);
 | 
				
			||||||
 | 
					 		patch_devnull(2, true);
 | 
				
			||||||
							
								
								
									
										34
									
								
								feeds/ucentral/ucrun/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								feeds/ucentral/ucrun/Makefile
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,34 @@
 | 
				
			|||||||
 | 
					include $(TOPDIR)/rules.mk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PKG_NAME:=ucrun
 | 
				
			||||||
 | 
					PKG_RELEASE:=1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PKG_SOURCE_PROTO:=git
 | 
				
			||||||
 | 
					PKG_SOURCE_URL=https://github.com/ucentral-io/ucrun.git
 | 
				
			||||||
 | 
					PKG_MIRROR_HASH:=52aeece27348611197ae5f4b96b3bdf1b5d028ae4ae284806b216d502300d07a
 | 
				
			||||||
 | 
					PKG_SOURCE_DATE:=2022-02-19
 | 
				
			||||||
 | 
					PKG_SOURCE_VERSION:=5be6abebc4ae6057b47a5b3f0799d5ff01bc60c3
 | 
				
			||||||
 | 
					CMAKE_INSTALL:=1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PKG_LICENSE:=GPL-2.0-only
 | 
				
			||||||
 | 
					PKG_LICENSE_FILES:=GPL
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PKG_MAINTAINER:=John Crispin <john@phrozen.org>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					include $(INCLUDE_DIR)/package.mk
 | 
				
			||||||
 | 
					include $(INCLUDE_DIR)/cmake.mk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Package/ucrun
 | 
				
			||||||
 | 
					  SECTION:=utils
 | 
				
			||||||
 | 
					  CATEGORY:=Utilities
 | 
				
			||||||
 | 
					  DEPENDS:=+libubox +ucode +ucode-mod-uci +ucode-mod-ubus +ucode-mod-fs
 | 
				
			||||||
 | 
					  TITLE:=uCode main-loop daemon
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Package/ucrun/install
 | 
				
			||||||
 | 
						$(INSTALL_DIR) $(1)/usr/bin
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						$(INSTALL_BIN) $(PKG_INSTALL_DIR)/usr/bin/ucrun $(1)/usr/bin
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$(eval $(call BuildPackage,ucrun))
 | 
				
			||||||
@@ -0,0 +1,138 @@
 | 
				
			|||||||
 | 
					From b24a5a890ccd19b0f1b50340c79c5087f08d9447 Mon Sep 17 00:00:00 2001
 | 
				
			||||||
 | 
					From: John Crispin <john@phrozen.org>
 | 
				
			||||||
 | 
					Date: Fri, 4 Mar 2022 15:56:30 +0100
 | 
				
			||||||
 | 
					Subject: [PATCH] ulog: add ringbuffer and log_event notification
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Signed-off-by: John Crispin <john@phrozen.org>
 | 
				
			||||||
 | 
					---
 | 
				
			||||||
 | 
					 ucode.c | 75 +++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 | 
				
			||||||
 | 
					 1 file changed, 73 insertions(+), 2 deletions(-)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					diff --git a/ucode.c b/ucode.c
 | 
				
			||||||
 | 
					index cef50e2..9e0373a 100644
 | 
				
			||||||
 | 
					--- a/ucode.c
 | 
				
			||||||
 | 
					+++ b/ucode.c
 | 
				
			||||||
 | 
					@@ -31,6 +31,17 @@ static const char *exception_types[] = {
 | 
				
			||||||
 | 
					 	[EXCEPTION_EXIT] = "Exit"
 | 
				
			||||||
 | 
					 };
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+struct log_buffer {
 | 
				
			||||||
 | 
					+	struct list_head list;
 | 
				
			||||||
 | 
					+	int severity;
 | 
				
			||||||
 | 
					+	char entry[];
 | 
				
			||||||
 | 
					+};
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+static LIST_HEAD(log_buffer);
 | 
				
			||||||
 | 
					+static int log_count;
 | 
				
			||||||
 | 
					+static int log_max = 100;
 | 
				
			||||||
 | 
					+static uc_value_t *log_event;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 static void
 | 
				
			||||||
 | 
					 ucode_handle_exception(uc_vm_t *vm, uc_exception_t *ex)
 | 
				
			||||||
 | 
					 {
 | 
				
			||||||
 | 
					@@ -287,6 +298,7 @@ static uc_value_t *
 | 
				
			||||||
 | 
					 uc_ulog(uc_vm_t *vm, size_t nargs, int severity)
 | 
				
			||||||
 | 
					 {
 | 
				
			||||||
 | 
					 	uc_value_t *res;
 | 
				
			||||||
 | 
					+	char *entry;
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 	if (!fmtfn) {
 | 
				
			||||||
 | 
					 		fmtfn = (uc_cfunction_t *)ucv_object_get(uc_vm_scope_get(vm), "sprintf", NULL);
 | 
				
			||||||
 | 
					@@ -300,7 +312,37 @@ uc_ulog(uc_vm_t *vm, size_t nargs, int severity)
 | 
				
			||||||
 | 
					 	if (!res)
 | 
				
			||||||
 | 
					 		return ucv_int64_new(-1);
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					-	ulog(severity, "%s", ucv_string_get(res));
 | 
				
			||||||
 | 
					+	entry = ucv_string_get(res);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	if (log_max) {
 | 
				
			||||||
 | 
					+		struct log_buffer *log = calloc(1, sizeof(*log) + strlen(entry) + 1);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+		strcpy(log->entry, entry);
 | 
				
			||||||
 | 
					+		log->severity = severity;
 | 
				
			||||||
 | 
					+		list_add_tail(&log->list, &log_buffer);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+		if (log_event) {
 | 
				
			||||||
 | 
					+			uc_value_t *event = ucv_array_new(vm);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			ucv_array_push(event, ucv_int64_new(severity));
 | 
				
			||||||
 | 
					+			ucv_array_push(event, ucv_string_new(entry));
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			uc_vm_stack_push(vm, ucv_get(log_event));
 | 
				
			||||||
 | 
					+			uc_vm_stack_push(vm, ucv_get(event));
 | 
				
			||||||
 | 
					+			uc_vm_call(vm, false, 1);
 | 
				
			||||||
 | 
					+		}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+		if (log_count == log_max) {
 | 
				
			||||||
 | 
					+			struct log_buffer *first = list_first_entry(&log_buffer, struct log_buffer, list);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+			list_del(&first->list);
 | 
				
			||||||
 | 
					+			free(first);
 | 
				
			||||||
 | 
					+		} else {
 | 
				
			||||||
 | 
					+			log_count++;
 | 
				
			||||||
 | 
					+		}
 | 
				
			||||||
 | 
					+	}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	ulog(severity, "%s", entry);
 | 
				
			||||||
 | 
					 	ucv_put(res);
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 	return ucv_int64_new(0);
 | 
				
			||||||
 | 
					@@ -330,11 +372,27 @@ uc_ulog_err(uc_vm_t *vm, size_t nargs)
 | 
				
			||||||
 | 
					 	return uc_ulog(vm, nargs, LOG_ERR);
 | 
				
			||||||
 | 
					 }
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+static uc_value_t *
 | 
				
			||||||
 | 
					+uc_ulog_dump(uc_vm_t *vm, size_t nargs)
 | 
				
			||||||
 | 
					+{
 | 
				
			||||||
 | 
					+	uc_value_t *log = ucv_array_new(vm);
 | 
				
			||||||
 | 
					+	struct log_buffer *iter;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	list_for_each_entry(iter, &log_buffer, list) {
 | 
				
			||||||
 | 
					+		uc_value_t *entry = ucv_array_new(vm);
 | 
				
			||||||
 | 
					+		ucv_array_push(entry, ucv_int64_new(iter->severity));
 | 
				
			||||||
 | 
					+		ucv_array_push(entry, ucv_string_new(iter->entry));
 | 
				
			||||||
 | 
					+		ucv_array_push(log, entry);
 | 
				
			||||||
 | 
					+	}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	return log;
 | 
				
			||||||
 | 
					+}
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 static void
 | 
				
			||||||
 | 
					 ucode_init_ulog(ucrun_ctx_t *ucrun)
 | 
				
			||||||
 | 
					 {
 | 
				
			||||||
 | 
					 	uc_value_t *ulog = ucv_object_get(ucrun->scope, "ulog", NULL);
 | 
				
			||||||
 | 
					-	uc_value_t *identity, *channels;
 | 
				
			||||||
 | 
					+	uc_value_t *identity, *channels, *logsize;
 | 
				
			||||||
 | 
					 	int flags = 0, channel;
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 	/* make sure the declartion is complete */
 | 
				
			||||||
 | 
					@@ -365,6 +423,18 @@ ucode_init_ulog(ucrun_ctx_t *ucrun)
 | 
				
			||||||
 | 
					 			flags |= ULOG_STDIO;
 | 
				
			||||||
 | 
					 	}
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					+	/* set the internal ring buffer size */
 | 
				
			||||||
 | 
					+	logsize = ucv_object_get(ulog, "channels", NULL);
 | 
				
			||||||
 | 
					+	if (ucv_type(logsize) == UC_INTEGER && ucv_int64_get(logsize))
 | 
				
			||||||
 | 
					+		log_max = ucv_int64_get(logsize);
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					+	/* find out if ucrun wants a notification when a new log entry is generated */
 | 
				
			||||||
 | 
					+	log_event = ucv_object_get(ulog, "event", NULL);
 | 
				
			||||||
 | 
					+	if (ucv_is_callable(log_event))
 | 
				
			||||||
 | 
					+		ucv_get(log_event);
 | 
				
			||||||
 | 
					+	else
 | 
				
			||||||
 | 
					+		log_event = NULL;
 | 
				
			||||||
 | 
					+
 | 
				
			||||||
 | 
					 	/* open the log */
 | 
				
			||||||
 | 
					 	ucrun->ulog_identity = strdup(ucv_string_get(identity));
 | 
				
			||||||
 | 
					 	ulog_open(flags, LOG_DAEMON, ucrun->ulog_identity);
 | 
				
			||||||
 | 
					@@ -404,6 +474,7 @@ ucode_init(ucrun_ctx_t *ucrun, int argc, const char **argv, int *rc)
 | 
				
			||||||
 | 
					 	uc_function_register(ucrun->scope, "ulog_note", uc_ulog_note);
 | 
				
			||||||
 | 
					 	uc_function_register(ucrun->scope, "ulog_warn", uc_ulog_warn);
 | 
				
			||||||
 | 
					 	uc_function_register(ucrun->scope, "ulog_err", uc_ulog_err);
 | 
				
			||||||
 | 
					+	uc_function_register(ucrun->scope, "ulog_dump", uc_ulog_dump);
 | 
				
			||||||
 | 
					 
 | 
				
			||||||
 | 
					 	/* add commandline parameters */
 | 
				
			||||||
 | 
					 	ARGV = ucv_array_new(&ucrun->vm);
 | 
				
			||||||
 | 
					-- 
 | 
				
			||||||
 | 
					2.25.1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -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
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -27,6 +27,11 @@ struct vlan_hdr {
 | 
				
			|||||||
	uint16_t proto;
 | 
						uint16_t proto;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct gre_hdr {
 | 
				
			||||||
 | 
						uint16_t flags;
 | 
				
			||||||
 | 
						uint16_t proto;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct packet {
 | 
					struct packet {
 | 
				
			||||||
	void *buffer;
 | 
						void *buffer;
 | 
				
			||||||
	unsigned int len;
 | 
						unsigned int len;
 | 
				
			||||||
@@ -91,6 +96,7 @@ dhcpsnoop_packet_cb(struct packet *pkt)
 | 
				
			|||||||
	bool ipv6 = false;
 | 
						bool ipv6 = false;
 | 
				
			||||||
	uint32_t rebind = 0;
 | 
						uint32_t rebind = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					inside_tunnel:
 | 
				
			||||||
	eth = pkt_pull(pkt, sizeof(*eth));
 | 
						eth = pkt_pull(pkt, sizeof(*eth));
 | 
				
			||||||
	if (!eth)
 | 
						if (!eth)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
@@ -129,6 +135,15 @@ dhcpsnoop_packet_cb(struct packet *pkt)
 | 
				
			|||||||
		return;
 | 
							return;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (proto == IPPROTO_GRE) {
 | 
				
			||||||
 | 
							struct gre_hdr *gre;
 | 
				
			||||||
 | 
							gre = pkt_pull(pkt, sizeof(*gre));
 | 
				
			||||||
 | 
							if (!gre) return;
 | 
				
			||||||
 | 
							proto = be16_to_cpu(gre->proto);
 | 
				
			||||||
 | 
							if (proto != 0x6558) return;
 | 
				
			||||||
 | 
							goto inside_tunnel;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (proto != IPPROTO_UDP)
 | 
						if (proto != IPPROTO_UDP)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -217,11 +232,37 @@ prepare_filter_cmd(char *buf, int len, const char *dev, int prio, bool add, bool
 | 
				
			|||||||
			add ? "add" : "del", dev, egress ? "e" : "in", prio);
 | 
								add ? "add" : "del", dev, egress ? "e" : "in", prio);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MATCH_GRE_ETH_IP_UDP_DHCP_67 \
 | 
				
			||||||
 | 
						" match u16 0x6558 0xffff at 22 " \
 | 
				
			||||||
 | 
						" match u16 0x0800 0xffff at 36 " \
 | 
				
			||||||
 | 
						" match u8 17 0xff at 47 " \
 | 
				
			||||||
 | 
						" match u16 67 0xffff at 58 "
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MATCH_GRE_ETH_VLAN_IP_UDP_DHCP_67 \
 | 
				
			||||||
 | 
						" match u16 0x6558 0xffff at 22 " \
 | 
				
			||||||
 | 
						" match u16 0x8100 0xffff at 36 " \
 | 
				
			||||||
 | 
						" match u16 0x0800 0xffff at 40 " \
 | 
				
			||||||
 | 
						" match u8 17 0xff at 51 " \
 | 
				
			||||||
 | 
						" match u16 67 0xffff at 62 "
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MATCH_GRE_ETH_IP_UDP_DHCP_68 \
 | 
				
			||||||
 | 
						" match u16 0x6558 0xffff at 22 " \
 | 
				
			||||||
 | 
						" match u16 0x0800 0xffff at 36 " \
 | 
				
			||||||
 | 
						" match u8 17 0xff at 47 " \
 | 
				
			||||||
 | 
						" match u16 68 0xffff at 58 "
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define MATCH_GRE_ETH_VLAN_IP_UDP_DHCP_68 \
 | 
				
			||||||
 | 
						" match u16 0x6558 0xffff at 22 " \
 | 
				
			||||||
 | 
						" match u16 0x8100 0xffff at 36 " \
 | 
				
			||||||
 | 
						" match u16 0x0800 0xffff at 40 " \
 | 
				
			||||||
 | 
						" match u8 17 0xff at 51 " \
 | 
				
			||||||
 | 
						" match u16 68 0xffff at 62 "
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static void
 | 
					static void
 | 
				
			||||||
dhcpsnoop_dev_attach_filters(struct device *dev, bool egress)
 | 
					dhcpsnoop_dev_attach_filters(struct device *dev, bool egress)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	int prio = DHCPSNOOP_PRIO_BASE;
 | 
						int prio = DHCPSNOOP_PRIO_BASE;
 | 
				
			||||||
	char buf[256];
 | 
						char buf[350];
 | 
				
			||||||
	int ofs;
 | 
						int ofs;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
						ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
				
			||||||
@@ -244,6 +285,32 @@ dhcpsnoop_dev_attach_filters(struct device *dev, bool egress)
 | 
				
			|||||||
			 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
								 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
				
			||||||
	dhcpsnoop_run_cmd(buf, false);
 | 
						dhcpsnoop_run_cmd(buf, false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* GRE */
 | 
				
			||||||
 | 
						ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
				
			||||||
 | 
						APPEND(buf, ofs, " protocol ip u32 match ip protocol 47 0xff"
 | 
				
			||||||
 | 
								 MATCH_GRE_ETH_IP_UDP_DHCP_67
 | 
				
			||||||
 | 
								 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
				
			||||||
 | 
						dhcpsnoop_run_cmd(buf, false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
				
			||||||
 | 
						APPEND(buf, ofs, " protocol ip u32 match ip protocol 47 0xff"
 | 
				
			||||||
 | 
								 MATCH_GRE_ETH_IP_UDP_DHCP_68
 | 
				
			||||||
 | 
								 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
				
			||||||
 | 
						dhcpsnoop_run_cmd(buf, false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
				
			||||||
 | 
						APPEND(buf, ofs, " protocol ip u32 match ip protocol 47 0xff "
 | 
				
			||||||
 | 
								 MATCH_GRE_ETH_VLAN_IP_UDP_DHCP_67
 | 
				
			||||||
 | 
								 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
				
			||||||
 | 
						dhcpsnoop_run_cmd(buf, false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
				
			||||||
 | 
						APPEND(buf, ofs, " protocol ip u32 match ip protocol 47 0xff"
 | 
				
			||||||
 | 
								 MATCH_GRE_ETH_VLAN_IP_UDP_DHCP_68
 | 
				
			||||||
 | 
								 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
				
			||||||
 | 
						dhcpsnoop_run_cmd(buf, false);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* IPv6 */
 | 
				
			||||||
	ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
						ofs = prepare_filter_cmd(buf, sizeof(buf), dev->ifname, prio++, true, egress);
 | 
				
			||||||
	APPEND(buf, ofs, " protocol ipv6 u32 match ip6 sport 546 0xfffe"
 | 
						APPEND(buf, ofs, " protocol ipv6 u32 match ip6 sport 546 0xfffe"
 | 
				
			||||||
			 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
								 " flowid 1:1 action mirred ingress mirror dev " DHCPSNOOP_IFB_NAME);
 | 
				
			||||||
@@ -261,7 +328,7 @@ dhcpsnoop_dev_cleanup_filters(struct device *dev, bool egress)
 | 
				
			|||||||
	char buf[128];
 | 
						char buf[128];
 | 
				
			||||||
	int i;
 | 
						int i;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for (i = DHCPSNOOP_PRIO_BASE; i < DHCPSNOOP_PRIO_BASE + 6; i++) {
 | 
						for (i = DHCPSNOOP_PRIO_BASE; i < DHCPSNOOP_PRIO_BASE + 10; i++) {
 | 
				
			||||||
		prepare_filter_cmd(buf, sizeof(buf), dev->ifname, i, false, egress);
 | 
							prepare_filter_cmd(buf, sizeof(buf), dev->ifname, i, false, egress);
 | 
				
			||||||
		dhcpsnoop_run_cmd(buf, true);
 | 
							dhcpsnoop_run_cmd(buf, true);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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:
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -68,11 +68,11 @@ out:
 | 
				
			|||||||
int main(int argc, char **argv)
 | 
					int main(int argc, char **argv)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	ulog_open(ULOG_STDIO | ULOG_SYSLOG, LOG_DAEMON, "udhcpsnoop");
 | 
						ulog_open(ULOG_STDIO | ULOG_SYSLOG, LOG_DAEMON, "udhcpsnoop");
 | 
				
			||||||
 | 
					 | 
				
			||||||
	uloop_init();
 | 
						uloop_init();
 | 
				
			||||||
	dhcpsnoop_ubus_init();
 | 
						dhcpsnoop_ubus_init();
 | 
				
			||||||
	dhcpsnoop_dev_init();
 | 
						dhcpsnoop_dev_init();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ulog_threshold(LOG_INFO);
 | 
				
			||||||
	uloop_run();
 | 
						uloop_run();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	dhcpsnoop_ubus_done();
 | 
						dhcpsnoop_ubus_done();
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -13,12 +13,12 @@ define Package/uspot
 | 
				
			|||||||
  SECTION:=net
 | 
					  SECTION:=net
 | 
				
			||||||
  CATEGORY:=Network
 | 
					  CATEGORY:=Network
 | 
				
			||||||
  TITLE:=hotspot daemon
 | 
					  TITLE:=hotspot daemon
 | 
				
			||||||
  DEPENDS:=+spotfilter +uhttpd-mod-ucode +libradcli
 | 
					  DEPENDS:=+spotfilter +uhttpd-mod-ucode +libradcli +iptables-mod-conntrack-extra +conntrack
 | 
				
			||||||
endef
 | 
					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;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										263
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/accounting.uc
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										263
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/accounting.uc
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,263 @@
 | 
				
			|||||||
 | 
					#!/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, payload) {
 | 
				
			||||||
 | 
						if (!radius_available(mac))
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						debug(mac, 'stopping accounting');
 | 
				
			||||||
 | 
						ubus.call('spotfilter', 'client_set', payload);
 | 
				
			||||||
 | 
						system('conntrack -D -s ' + clients[mac].ip4addr  + ' -m 2');
 | 
				
			||||||
 | 
						if (clients[mac].accounting)
 | 
				
			||||||
 | 
							clients[mac].timeout.cancel();
 | 
				
			||||||
 | 
						delete clients[mac];
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					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;
 | 
				
			||||||
 | 
						if (state.data?.radius?.reply?.Class)
 | 
				
			||||||
 | 
							payload.class = state.data.radius.reply.Class;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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_logoff(mac) {
 | 
				
			||||||
 | 
						if (!radius_available(mac))
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						let payload = {
 | 
				
			||||||
 | 
							acct_type: 2,
 | 
				
			||||||
 | 
							terminate_cause: 1,
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
						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);
 | 
				
			||||||
 | 
						let max_total = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						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);
 | 
				
			||||||
 | 
							max_total = (state.data?.radius?.reply['ChilliSpot-Max-Total-Octets'] || 0);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						clients[mac] = {
 | 
				
			||||||
 | 
							accounting,
 | 
				
			||||||
 | 
							interval,
 | 
				
			||||||
 | 
							session,
 | 
				
			||||||
 | 
							idle,
 | 
				
			||||||
 | 
							max_total,
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
						if (state.ip4addr)
 | 
				
			||||||
 | 
							clients[mac].ip4addr = state.ip4addr;
 | 
				
			||||||
 | 
						if (state.ip6addr)
 | 
				
			||||||
 | 
							clients[mac].ip6addr = state.ip6addr;
 | 
				
			||||||
 | 
						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);
 | 
				
			||||||
 | 
						radius_stop(mac, {
 | 
				
			||||||
 | 
							interface: "hotspot",
 | 
				
			||||||
 | 
							address: mac
 | 
				
			||||||
 | 
						});
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function client_flush(mac) {
 | 
				
			||||||
 | 
						syslog(mac, 'logoff event');
 | 
				
			||||||
 | 
						radius_stop(mac, {
 | 
				
			||||||
 | 
							interface: 'hotspot',
 | 
				
			||||||
 | 
							address: mac,
 | 
				
			||||||
 | 
							state: 0,
 | 
				
			||||||
 | 
							dns_state: 1,
 | 
				
			||||||
 | 
							accounting: [],
 | 
				
			||||||
 | 
							flush: true
 | 
				
			||||||
 | 
						});
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function client_timeout(mac, reason) {
 | 
				
			||||||
 | 
						syslog(mac, reason);
 | 
				
			||||||
 | 
						radius_stop(mac, {
 | 
				
			||||||
 | 
							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].data?.logoff) {
 | 
				
			||||||
 | 
								radius_logoff(k);
 | 
				
			||||||
 | 
								client_flush(k);
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (!list[k] || !list[k].state) {
 | 
				
			||||||
 | 
								radius_disconnect(k);
 | 
				
			||||||
 | 
								client_remove(k, 'disconnect event');
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (list[k].idle > get_idle_timeout(k)) {
 | 
				
			||||||
 | 
								if (clients[k])
 | 
				
			||||||
 | 
									radius_idle_time(k);
 | 
				
			||||||
 | 
								client_remove(k, 'idle event');
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							let timeout = get_session_timeout(k);
 | 
				
			||||||
 | 
							if (timeout && ((t - list[k].data.connect) > timeout)) {
 | 
				
			||||||
 | 
								if (clients[k])
 | 
				
			||||||
 | 
									radius_session_time(k);
 | 
				
			||||||
 | 
								client_timeout(k, 'session timeout');
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if (clients[k].max_total) {
 | 
				
			||||||
 | 
								let total = list[k].bytes_ul + list[k].bytes_dl;
 | 
				
			||||||
 | 
								if (total >= clients[k].max_total) {
 | 
				
			||||||
 | 
									radius_session_time(k);
 | 
				
			||||||
 | 
									client_timeout(k, 'max octets reached');
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						this.set(1000);
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					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,104 @@ 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, uam) {
 | 
				
			||||||
 | 
							this.syslog(ctx, 'logging client off');
 | 
				
			||||||
 | 
							ctx.ubus.call('spotfilter', 'client_set', {
 | 
				
			||||||
 | 
								interface: 'hotspot',
 | 
				
			||||||
 | 
								address: ctx.mac,
 | 
				
			||||||
 | 
								state: 0,
 | 
				
			||||||
 | 
								dns_state: 1,
 | 
				
			||||||
 | 
								accounting: [],
 | 
				
			||||||
 | 
								data: {
 | 
				
			||||||
 | 
									logoff : 1
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (uam)
 | 
				
			||||||
 | 
								include('redir.uc', { redir_location: this.uam_url(ctx, 'logoff') });
 | 
				
			||||||
 | 
							else
 | 
				
			||||||
 | 
								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 type = payload.acct ? 'acct' : 'auth';
 | 
				
			||||||
 | 
							let cfg = fs.open('/tmp/' + type + 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/' + type + ctx.mac + '.json');
 | 
				
			||||||
	},
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	handle_request: function(env) {
 | 
						uam_url: function(ctx, res) {
 | 
				
			||||||
 | 
							let uam_url = this.config.uam.uam_server +
 | 
				
			||||||
 | 
								'?res=' + res +
 | 
				
			||||||
 | 
								'&uamip=' + ctx.env.SERVER_ADDR +
 | 
				
			||||||
 | 
								'&uamport=' + this.config.uam.uam_port +
 | 
				
			||||||
 | 
								'&challenge=' + this.uam.md5(this.config.uam.challenge, ctx.format_mac) +
 | 
				
			||||||
 | 
								'&mac=' + ctx.format_mac +
 | 
				
			||||||
 | 
								'&ip=' + ctx.env.REMOTE_ADDR +
 | 
				
			||||||
 | 
								'&called=' + this.config.uam.nasmac +
 | 
				
			||||||
 | 
								'&nasid=' + this.config.uam.nasid +
 | 
				
			||||||
 | 
								'&ssid=' + ctx.ssid;
 | 
				
			||||||
 | 
							if (ctx.query_string?.redir)
 | 
				
			||||||
 | 
								uam_url += '&userurl=' + ctx.query_string.redir;
 | 
				
			||||||
 | 
							if (this.config.uam.uam_secret)
 | 
				
			||||||
 | 
								uam_url += '&md=' + this.uam.md5(uam_url, this.config.uam.uam_secret);
 | 
				
			||||||
 | 
							return uam_url;
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						handle_request: function(env, uam) {
 | 
				
			||||||
		let mac;
 | 
							let mac;
 | 
				
			||||||
		let form_data = {};
 | 
							let form_data = {};
 | 
				
			||||||
		let query_string = {};
 | 
							let query_string = {};
 | 
				
			||||||
@@ -91,25 +189,40 @@ 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'
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
								connected.data.ssid = hapd.ssid;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							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 }}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										3
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/firewall.ipt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								feeds/ucentral/uspot/files/usr/share/uspot/firewall.ipt
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,3 @@
 | 
				
			|||||||
 | 
					*mangle
 | 
				
			||||||
 | 
					-A POSTROUTING -m mark --mark 0x2 -j CONNMARK --set-mark 0x2
 | 
				
			||||||
 | 
					COMMIT
 | 
				
			||||||
@@ -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/', 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,53 @@ 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);
 | 
							if (portal.config.uam.final_redirect_url == 'uam')
 | 
				
			||||||
 | 
								ctx.query_string.userurl = portal.uam_url(ctx, 'success');
 | 
				
			||||||
 | 
							portal.allow_client(ctx, { radius: { reply: radius.reply, request: payload } } );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							payload = portal.radius_init(ctx, payload.acct_session);
 | 
				
			||||||
 | 
							payload.acct = true;
 | 
				
			||||||
 | 
							payload.username = ctx.query_string.username;
 | 
				
			||||||
 | 
							payload.acct_type = 1;
 | 
				
			||||||
 | 
							if (radius.reply.Class)
 | 
				
			||||||
 | 
								payload.class = radius.reply.Class;
 | 
				
			||||||
 | 
							portal.radius_call(ctx, payload);
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (portal.config.uam.final_redirect_url == 'uam')
 | 
				
			||||||
 | 
							include('redir.uc', { redir_location: portal.uam_url(ctx, 'reject') });
 | 
				
			||||||
 | 
						else
 | 
				
			||||||
		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, true);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	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 '/logout':
 | 
				
			||||||
 | 
						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);
 | 
				
			||||||
@@ -18,16 +19,7 @@ function request_start(ctx) {
 | 
				
			|||||||
		include('radius.uc', ctx);
 | 
							include('radius.uc', ctx);
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	case 'uam':
 | 
						case 'uam':
 | 
				
			||||||
		ctx.redir_location = portal.config.uam.uam_server +
 | 
							ctx.redir_location = portal.uam_url(ctx, 'notyet');
 | 
				
			||||||
			'?res=notyet' +
 | 
					 | 
				
			||||||
			'&uamip=' + ctx.env.SERVER_ADDR +
 | 
					 | 
				
			||||||
			'&uamport=' + portal.config.uam.uam_port +
 | 
					 | 
				
			||||||
			'&challenge=' + portal.uam.md5(portal.config.uam.challenge, ctx.mac) +
 | 
					 | 
				
			||||||
			'&mac=' + replace(ctx.mac, ':', '-') +
 | 
					 | 
				
			||||||
			'&ip=' + ctx.env.REMOTE_ADDR +
 | 
					 | 
				
			||||||
			'&called=' + portal.config.uam.nasmac +
 | 
					 | 
				
			||||||
			'&nasid=' + portal.config.uam.nasid;
 | 
					 | 
				
			||||||
		ctx.redir_location += '&md=' + portal.uam.md5(ctx.uam_location, portal.config.uam.uam_secret);
 | 
					 | 
				
			||||||
		include('redir.uc', ctx);
 | 
							include('redir.uc', ctx);
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
	default:
 | 
						default:
 | 
				
			||||||
@@ -46,6 +38,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 +48,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 +70,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 +89,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,24 @@ 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_CLASS,
 | 
				
			||||||
        __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 +51,18 @@ 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 },
 | 
				
			||||||
 | 
					        [RADIUS_CLASS] = { .name = "class", .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 +113,162 @@ 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]) {
 | 
				
			||||||
		return result(rh, 0, NULL);
 | 
							val = blobmsg_get_u32(tb[RADIUS_ACCT_TYPE]);
 | 
				
			||||||
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_STATUS_TYPE, &val, 4, 0) == NULL)
 | 
				
			||||||
	rc_apply_config(rh);
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
	if (rc_auth(rh, 0, send, &received, NULL) == OK_RC)
 | 
						}
 | 
				
			||||||
		return result(rh, 1, received);
 | 
					
 | 
				
			||||||
 | 
						if (tb[RADIUS_USERNAME])
 | 
				
			||||||
	return result(rh, 0, NULL);
 | 
							if (rc_avpair_add(rh, &send, PW_USER_NAME, blobmsg_get_string(tb[RADIUS_USERNAME]), -1, 0) == NULL)
 | 
				
			||||||
}
 | 
						                return result(rh, 0, NULL);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int
 | 
						if (tb[RADIUS_PASSWORD])
 | 
				
			||||||
uam_auth(void)
 | 
							if (rc_avpair_add(rh, &send, PW_USER_PASSWORD, blobmsg_get_string(tb[RADIUS_PASSWORD]), -1, 0) == NULL)
 | 
				
			||||||
{
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
	VALUE_PAIR *send = NULL, *received;
 | 
					
 | 
				
			||||||
	rc_handle *rh = NULL;
 | 
						if (tb[RADIUS_CHAP_PASSWORD]) {
 | 
				
			||||||
 | 
							str_to_hex(blobmsg_get_string(tb[RADIUS_CHAP_PASSWORD]), &chap_password[1], 16);
 | 
				
			||||||
	if (!config.server || !config.username || !config.password ||
 | 
							if (rc_avpair_add(rh, &send, PW_CHAP_PASSWORD, chap_password, 17, 0) == NULL)
 | 
				
			||||||
	    !config.acct_session || !config.called_station ||
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
	    !config.calling_station || !config.nas_id)
 | 
						}
 | 
				
			||||||
		return result(NULL, 0, NULL);
 | 
					
 | 
				
			||||||
 | 
						if (tb[RADIUS_CHAP_CHALLENGE]) {
 | 
				
			||||||
	rh = radius_init();
 | 
							str_to_hex(blobmsg_get_string(tb[RADIUS_CHAP_CHALLENGE]), chap_challenge, 16);
 | 
				
			||||||
	if (!rh)
 | 
							if (rc_avpair_add(rh, &send, PW_CHAP_CHALLENGE, chap_challenge, 16, 0) == NULL)
 | 
				
			||||||
		return result(NULL, 0, NULL);
 | 
						                return result(rh, 0, NULL);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_USER_NAME, config.username, -1, 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)
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_USER_PASSWORD, config.password, -1, 0) == NULL)
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
		return result(rh, 0, NULL);
 | 
					
 | 
				
			||||||
 | 
						if (tb[RADIUS_CLIENT_IP]) {
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_ACCT_SESSION_ID, config.acct_session, -1, 0) == NULL)
 | 
							inet_pton(AF_INET, blobmsg_get_string(tb[RADIUS_CLIENT_IP]), &(client_ip.sin_addr));
 | 
				
			||||||
		return result(rh, 0, NULL);
 | 
							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)
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_FRAMED_IP_ADDRESS, &config.client_ip.sin_addr, 4, 0) == NULL)
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
		return result(rh, 0, NULL);
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	//if (rc_avpair_add(rh, &send, PW_NAS_PORT_TYPE, , -1, 0) == NULL)
 | 
						if (tb[RADIUS_CALLED_STATION])
 | 
				
			||||||
	//	return result(rh, 0, NULL);
 | 
							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 (rc_avpair_add(rh, &send, PW_NAS_PORT, , -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)
 | 
				
			||||||
//	if (rc_avpair_add(rh, &send, PW_NAS_PORT_ID_STRING, , -1, 0) == NULL)
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
//		return result(rh, 0, NULL);
 | 
					
 | 
				
			||||||
 | 
						if (tb[RADIUS_CALLING_STATION])
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_CALLED_STATION_ID, config.called_station, -1, 0) == NULL)
 | 
							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);
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_CALLING_STATION_ID, config.calling_station, -1, 0) == NULL)
 | 
						if (tb[RADIUS_NAS_IP]) {
 | 
				
			||||||
		return result(rh, 0, NULL);
 | 
							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, &config.nas_ip.sin_addr, 4, 0) == NULL)
 | 
							if (rc_avpair_add(rh, &send, PW_NAS_IP_ADDRESS, &nas_ip.sin_addr, 4, 0) == NULL)
 | 
				
			||||||
		return result(rh, 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);
 | 
						if (tb[RADIUS_NAS_ID])
 | 
				
			||||||
 | 
							if (rc_avpair_add(rh, &send, PW_NAS_IDENTIFIER, blobmsg_get_string(tb[RADIUS_NAS_ID]), -1, 0) == NULL)
 | 
				
			||||||
	rc_apply_config(rh);
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
	if (rc_auth(rh, 0, send, &received, NULL) == OK_RC)
 | 
					
 | 
				
			||||||
		return result(rh, 1, received);
 | 
						if (tb[RADIUS_TERMINATE_CAUSE]) {
 | 
				
			||||||
 | 
							val = blobmsg_get_u32(tb[RADIUS_TERMINATE_CAUSE]);
 | 
				
			||||||
	return result(rh, 0, NULL);
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_TERMINATE_CAUSE, &val, 4, 0) == NULL)
 | 
				
			||||||
}
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
static int
 | 
					
 | 
				
			||||||
uam_chap_auth(void)
 | 
						if (tb[RADIUS_SESSION_TIME]) {
 | 
				
			||||||
{
 | 
							val = blobmsg_get_u32(tb[RADIUS_SESSION_TIME]);
 | 
				
			||||||
	VALUE_PAIR *send = NULL, *received;
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_SESSION_TIME, &val, 4, 0) == NULL)
 | 
				
			||||||
	rc_handle *rh = NULL;
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	if (!config.server || !config.username ||
 | 
					
 | 
				
			||||||
	    !config.acct_session || !config.called_station ||
 | 
						if (tb[RADIUS_INPUT_OCTETS]) {
 | 
				
			||||||
	    !config.calling_station || !config.nas_id)
 | 
							val = blobmsg_get_u32(tb[RADIUS_INPUT_OCTETS]);
 | 
				
			||||||
		return result(NULL, 0, NULL);
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_INPUT_OCTETS, &val, 4, 0) == NULL)
 | 
				
			||||||
 | 
								return result(rh, 0, NULL);
 | 
				
			||||||
	rh = radius_init();
 | 
						}
 | 
				
			||||||
	if (!rh)
 | 
					
 | 
				
			||||||
		return result(NULL, 0, NULL);
 | 
						if (tb[RADIUS_OUTPUT_OCTETS]) {
 | 
				
			||||||
 | 
							val = blobmsg_get_u32(tb[RADIUS_OUTPUT_OCTETS]);
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_USER_NAME, config.username, -1, 0) == NULL)
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_OUTPUT_OCTETS, &val, 4, 0) == NULL)
 | 
				
			||||||
		return result(rh, 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 (tb[RADIUS_INPUT_GIGAWORDS]) {
 | 
				
			||||||
 | 
							val = blobmsg_get_u32(tb[RADIUS_INPUT_GIGAWORDS]);
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_CHAP_CHALLENGE, config.chap_challenge, 16, 0) == NULL)
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_INPUT_GIGAWORDS, &val, 4, 0) == NULL)
 | 
				
			||||||
		return result(rh, 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 (tb[RADIUS_OUTPUT_GIGAWORDS]) {
 | 
				
			||||||
 | 
							val = blobmsg_get_u32(tb[RADIUS_OUTPUT_GIGAWORDS]);
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_FRAMED_IP_ADDRESS, &config.client_ip.sin_addr, 4, 0) == NULL)
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_OUTPUT_GIGAWORDS, &val, 4, 0) == NULL)
 | 
				
			||||||
		return result(rh, 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 (tb[RADIUS_INPUT_PACKETS]) {
 | 
				
			||||||
 | 
							val = blobmsg_get_u32(tb[RADIUS_INPUT_PACKETS]);
 | 
				
			||||||
	//if (rc_avpair_add(rh, &send, PW_NAS_PORT, , -1, 0) == NULL)
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_INPUT_PACKETS, &val, 4, 0) == NULL)
 | 
				
			||||||
	//	return result(rh, 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 (tb[RADIUS_OUTPUT_PACKETS]) {
 | 
				
			||||||
 | 
							val = blobmsg_get_u32(tb[RADIUS_OUTPUT_PACKETS]);
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_CALLED_STATION_ID, config.called_station, -1, 0) == NULL)
 | 
							if (rc_avpair_add(rh, &send, PW_ACCT_OUTPUT_PACKETS, &val, 4, 0) == NULL)
 | 
				
			||||||
		return result(rh, 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 (tb[RADIUS_CLASS])
 | 
				
			||||||
 | 
							if (rc_avpair_add(rh, &send, PW_CLASS, blobmsg_get_string(tb[RADIUS_CLASS]), -1, 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);
 | 
				
			||||||
		return result(rh, 0, NULL);
 | 
					
 | 
				
			||||||
 | 
						val = 19;
 | 
				
			||||||
	if (rc_avpair_add(rh, &send, PW_NAS_IDENTIFIER, config.nas_id, -1, 0) == NULL)
 | 
						if (rc_avpair_add(rh, &send, PW_NAS_PORT_TYPE, &val, 4, 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);
 | 
							return result(rh, 0, NULL);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	rc_apply_config(rh);
 | 
						rc_apply_config(rh);
 | 
				
			||||||
 | 
						if (tb[RADIUS_ACCT] && blobmsg_get_bool(tb[RADIUS_ACCT])) {
 | 
				
			||||||
 | 
							if (rc_acct(rh, 0, send) == OK_RC)
 | 
				
			||||||
 | 
								return result(rh, 1, NULL);
 | 
				
			||||||
 | 
						} else {
 | 
				
			||||||
		if (rc_auth(rh, 0, send, &received, NULL) == OK_RC)
 | 
							if (rc_auth(rh, 0, send, &received, NULL) == OK_RC)
 | 
				
			||||||
			return result(rh, 1, received);
 | 
								return result(rh, 1, received);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return result(rh, 0, NULL);
 | 
						return result(rh, 0, NULL);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -380,21 +285,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);
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										27
									
								
								feeds/ucentral/usteer2/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								feeds/ucentral/usteer2/Makefile
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,27 @@
 | 
				
			|||||||
 | 
					include $(TOPDIR)/rules.mk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PKG_NAME:=usteer2
 | 
				
			||||||
 | 
					PKG_RELEASE:=1
 | 
				
			||||||
 | 
					PKG_LICENSE:=ISC
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					PKG_MAINTAINER:=John Crispin <john@phrozen.org>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					include $(INCLUDE_DIR)/package.mk
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Package/usteer2
 | 
				
			||||||
 | 
					  SECTION:=utils
 | 
				
			||||||
 | 
					  CATEGORY:=Utilities
 | 
				
			||||||
 | 
					  DEPENDS:=+ucrun
 | 
				
			||||||
 | 
					  TITLE:=wifi client steering
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Build/Compile/Default
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					Build/Compile = $(Build/Compile/Default)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Package/usteer2/install
 | 
				
			||||||
 | 
						$(CP) ./files/* $(1)/
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$(eval $(call BuildPackage,usteer2))
 | 
				
			||||||
							
								
								
									
										9
									
								
								feeds/ucentral/usteer2/files/etc/config/usteer2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								feeds/ucentral/usteer2/files/etc/config/usteer2
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,9 @@
 | 
				
			|||||||
 | 
					config base
 | 
				
			||||||
 | 
						option station_update 1000
 | 
				
			||||||
 | 
						option station_expiry 120
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					config policy
 | 
				
			||||||
 | 
						option name snr
 | 
				
			||||||
 | 
						option min_snr_kick_delay 5
 | 
				
			||||||
 | 
						option kick_reason 5
 | 
				
			||||||
 | 
						option interval 1000
 | 
				
			||||||
							
								
								
									
										13
									
								
								feeds/ucentral/usteer2/files/etc/init.d/usteer2
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										13
									
								
								feeds/ucentral/usteer2/files/etc/init.d/usteer2
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,13 @@
 | 
				
			|||||||
 | 
					#!/bin/sh /etc/rc.common
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					START=99
 | 
				
			||||||
 | 
					STOP=01
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					USE_PROCD=1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					start_service() {
 | 
				
			||||||
 | 
						procd_open_instance
 | 
				
			||||||
 | 
						procd_set_param command /usr/bin/usteer.uc
 | 
				
			||||||
 | 
						procd_set_param respawn 3600 5 0
 | 
				
			||||||
 | 
						procd_close_instance
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										75
									
								
								feeds/ucentral/usteer2/files/usr/bin/usteer.uc
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										75
									
								
								feeds/ucentral/usteer2/files/usr/bin/usteer.uc
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,75 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/ucrun
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					push(REQUIRE_SEARCH_PATH, '/usr/share/usteer/*.uc');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					global.ulog = {
 | 
				
			||||||
 | 
						identity: 'usteer',
 | 
				
			||||||
 | 
						channels: [ 'stdio', 'syslog' ],
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					global.ubus = {
 | 
				
			||||||
 | 
						object: 'usteer2',
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						connect: function() {
 | 
				
			||||||
 | 
							printf('connected to ubus\n');
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						methods: {
 | 
				
			||||||
 | 
							interfaces: {
 | 
				
			||||||
 | 
								cb: function(msg) {
 | 
				
			||||||
 | 
									return global.local.status();
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							stations: {
 | 
				
			||||||
 | 
								cb: function(msg) {
 | 
				
			||||||
 | 
									return global.station.list(msg);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							status: {
 | 
				
			||||||
 | 
								cb: function(msg) {
 | 
				
			||||||
 | 
									return global.station.status();
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							command: {
 | 
				
			||||||
 | 
								cb: function(msg) {
 | 
				
			||||||
 | 
									return global.command.handle(msg);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							get_beacon_request: {
 | 
				
			||||||
 | 
								cb: function(msg) {
 | 
				
			||||||
 | 
									let val = global.station.list(msg);
 | 
				
			||||||
 | 
									return val?.beacon_report || {};
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							policy: {
 | 
				
			||||||
 | 
								cb: function(msg) {
 | 
				
			||||||
 | 
									return global.policy.status(msg);
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					global.start = function() {
 | 
				
			||||||
 | 
						try {
 | 
				
			||||||
 | 
							global.uci = require('uci').cursor();
 | 
				
			||||||
 | 
							global.ubus.conn = require('ubus').connect();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							for (let module in [ 'config', 'local', 'station', 'command', 'policy' ]) {
 | 
				
			||||||
 | 
								printf('loading ' + module + '\n');
 | 
				
			||||||
 | 
								global[module] = require(module);
 | 
				
			||||||
 | 
								if (exists(global[module], 'init'))
 | 
				
			||||||
 | 
									global[module].init();
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						} catch(e) {
 | 
				
			||||||
 | 
							printf('exception %s\n', e);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					global.stop = function() {
 | 
				
			||||||
 | 
						ulog_info('stopping\n');
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										35
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/command.uc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/command.uc
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,35 @@
 | 
				
			|||||||
 | 
					function result(error, text, data) {
 | 
				
			||||||
 | 
						return {
 | 
				
			||||||
 | 
							error: error,
 | 
				
			||||||
 | 
							text: text || 'unknown',
 | 
				
			||||||
 | 
							...(data ? { data } : {}),
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const actions = {
 | 
				
			||||||
 | 
						// ubus call usteer2 command '{"action": "kick", "mac": "1c:57:dc:37:3c:b1", "params": {"reason": 5, "ban_time": 30}}'
 | 
				
			||||||
 | 
						kick: function(msg) {
 | 
				
			||||||
 | 
							if (global.station.kick(msg.mac, msg.params?.reason, msg.params?.ban_time))
 | 
				
			||||||
 | 
								return result(1, 'station ' + msg.mac + ' is unknown');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return result(0, 'station ' + msg.mac + ' was kicked');
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// ubus call usteer2 command '{"action": "beacon_request", "mac": "1c:57:dc:37:3c:b1", "params": {"channel": 36}}'
 | 
				
			||||||
 | 
						// ubus call usteer2 get_beacon_request '{"mac": "1c:57:dc:37:3c:b1"}'
 | 
				
			||||||
 | 
						beacon_request: function(msg) {
 | 
				
			||||||
 | 
							if (!global.station.beacon_request(msg.mac, msg.params?.channel, msg.params?.op_class, msg.param?.duration))
 | 
				
			||||||
 | 
								return result(1, 'station ' + msg.mac + ' is unknown');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return result(0, 'station ' + msg.mac + ' beacon-request sent');
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						handle: function(msg) {
 | 
				
			||||||
 | 
							if (!actions[msg.action])
 | 
				
			||||||
 | 
								return result(1, 'unknown action ' + msg.action);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return actions[msg.action](msg);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										10
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/config.uc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/config.uc
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,10 @@
 | 
				
			|||||||
 | 
					return {
 | 
				
			||||||
 | 
						station_update: 1000,
 | 
				
			||||||
 | 
						station_expiry: 120,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						init: function() {
 | 
				
			||||||
 | 
							let options = uci.get_all('usteer2', '@base[-1]');
 | 
				
			||||||
 | 
							for (let key in options)
 | 
				
			||||||
 | 
								this[key] = options[key];
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										142
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/local.uc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										142
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/local.uc
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,142 @@
 | 
				
			|||||||
 | 
					let nl80211 = require("nl80211");
 | 
				
			||||||
 | 
					let def = nl80211.const;
 | 
				
			||||||
 | 
					let subscriber;
 | 
				
			||||||
 | 
					let state = {};
 | 
				
			||||||
 | 
					let hapd = {};
 | 
				
			||||||
 | 
					let handlers = {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function channel_survey(dev) {
 | 
				
			||||||
 | 
						/* trigger the nl80211 call that gathers channel survey data */
 | 
				
			||||||
 | 
						let res = nl80211.request(def.NL80211_CMD_GET_SURVEY, def.NLM_F_DUMP, { dev });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (!res) {
 | 
				
			||||||
 | 
							ulog_err(sprintf('failed to update survey for %s', dev));
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* iterate over the result and filter out the correct channel */
 | 
				
			||||||
 | 
						for (let survey in res) {
 | 
				
			||||||
 | 
							if (survey?.survey_info?.frequency != hapd[dev].freq)
 | 
				
			||||||
 | 
								continue;
 | 
				
			||||||
 | 
							if (survey.survey_info.noise)
 | 
				
			||||||
 | 
								hapd[dev].noise = survey.survey_info.noise;
 | 
				
			||||||
 | 
							if (survey.survey_info.time && survey.survey_info.busy) {
 | 
				
			||||||
 | 
								let time = survey.survey_info.time - (state[dev].time || 0);
 | 
				
			||||||
 | 
								let busy = survey.survey_info.busy - (state[dev].busy || 0);
 | 
				
			||||||
 | 
								state[dev].time = survey.survey_info.time;
 | 
				
			||||||
 | 
								state[dev].busy = survey.survey_info.busy;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								let load = (100 * busy) / time;
 | 
				
			||||||
 | 
								if (hapd[dev].load)
 | 
				
			||||||
 | 
									hapd[dev].load = 0.85 * hapd[dev].load + 0.15 * load;
 | 
				
			||||||
 | 
								else
 | 
				
			||||||
 | 
									hapd[dev].load = load;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function hapd_update() {
 | 
				
			||||||
 | 
						/* todo: prefilter frequency */
 | 
				
			||||||
 | 
						for (let key in state)
 | 
				
			||||||
 | 
							channel_survey(key);
 | 
				
			||||||
 | 
						return 5000;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function hapd_subunsub(path, sub) {
 | 
				
			||||||
 | 
						/* check if this is a hostapd instance */
 | 
				
			||||||
 | 
						let name = split(path, '.');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (length(name) != 2 || name[0] != 'hostapd')
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						name = name[1];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						ulog_info(sprintf('%s %s\n', sub ? 'add' : 'remove', path));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* the hostapd instance disappeared */
 | 
				
			||||||
 | 
						if (!sub) {
 | 
				
			||||||
 | 
							delete hapd[name];
 | 
				
			||||||
 | 
							delete state[name];
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* gather initial data from hostapd */
 | 
				
			||||||
 | 
						let status = global.ubus.conn.call(path, 'get_status');
 | 
				
			||||||
 | 
						if (!status)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						let cfg = uci.get_all('usteer2', status.uci_section);
 | 
				
			||||||
 | 
						if (!cfg)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* subscibe to hostapd */
 | 
				
			||||||
 | 
						subscriber.subscribe(path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* tell hostapd to wait for a reply before answering probe requests */
 | 
				
			||||||
 | 
						//global.ubus.conn.call(path, 'notify_response', { 'notify_response': 1 });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* tell hostapd to enable rrm/roaming */
 | 
				
			||||||
 | 
						global.ubus.conn.call(path, 'bss_mgmt_enable', { 'neighbor_report': 1, 'beacon_report': 1, 'bss_transition': 1 });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* instantiate state */
 | 
				
			||||||
 | 
						hapd[name] = { };
 | 
				
			||||||
 | 
						state[name] = { };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for (let prop in [ 'ssid', 'bssid', 'freq', 'channel', 'op_class', 'uci_section' ])
 | 
				
			||||||
 | 
							if (status[prop])
 | 
				
			||||||
 | 
								hapd[name][prop] = status[prop];
 | 
				
			||||||
 | 
						hapd[name].config = cfg;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* ask hostapd for the local neighbourhood report data */
 | 
				
			||||||
 | 
						let rrm = global.ubus.conn.call(path, 'rrm_nr_get_own');
 | 
				
			||||||
 | 
						if (rrm && rrm.value)
 | 
				
			||||||
 | 
							hapd[name].rrm_nr = rrm.value;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* trigger an initial channel survey */
 | 
				
			||||||
 | 
						channel_survey(name);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function hapd_listener(event, msg) {
 | 
				
			||||||
 | 
						hapd_subunsub(msg.path, event == 'ubus.object.add');
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function hapd_handle_event(req) {
 | 
				
			||||||
 | 
						/* iterate over all handlers for this event type, if 1 or more handlers replied with false, do not reply to the notification */
 | 
				
			||||||
 | 
						let reply = true;
 | 
				
			||||||
 | 
						for (let handler in handlers[req.type])
 | 
				
			||||||
 | 
							if (!handler(req.type, req.data))
 | 
				
			||||||
 | 
								reply = false;
 | 
				
			||||||
 | 
						if (!reply)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
						req.reply();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						status: function() {
 | 
				
			||||||
 | 
							return hapd;
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						init: function() {
 | 
				
			||||||
 | 
							subscriber = global.ubus.conn.subscriber(
 | 
				
			||||||
 | 
								hapd_handle_event,
 | 
				
			||||||
 | 
								function(msg) {
 | 
				
			||||||
 | 
					//				printf('2 %.J\n', msg);
 | 
				
			||||||
 | 
								});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* register a callback that will monitor hostapd instances spawning and disappearing */
 | 
				
			||||||
 | 
							global.ubus.conn.listener('ubus.object.add', hapd_listener);
 | 
				
			||||||
 | 
							global.ubus.conn.listener('ubus.object.remove', hapd_listener);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* iterade over all existing hostapd instances and subscribe to them */
 | 
				
			||||||
 | 
							for (let path in global.ubus.conn.list())
 | 
				
			||||||
 | 
								hapd_subunsub(path, true);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							uloop_timeout(hapd_update, 5000);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						register_handler: function(event, handler) {
 | 
				
			||||||
 | 
							/* a policy requested to be notified of action frames, register the callback */
 | 
				
			||||||
 | 
							handlers[event] ??= [];
 | 
				
			||||||
 | 
							push(handlers[event], handler);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										36
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/policy.uc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/policy.uc
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,36 @@
 | 
				
			|||||||
 | 
					let policies = {};
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						init: function() {
 | 
				
			||||||
 | 
							let config = global.uci.get_all('usteer2');
 | 
				
			||||||
 | 
							for (let section in config) {
 | 
				
			||||||
 | 
								if (config[section]['.type'] != 'policy' || !config[section].name)
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
								let policy = require(`policy_${config[section].name}`);
 | 
				
			||||||
 | 
								if (type(policy) != 'object' || type(policy.init) != 'function') {
 | 
				
			||||||
 | 
									ulog_info('failed to load policy "%s"\n', config[section].name);
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								try {
 | 
				
			||||||
 | 
									policy.init(config[section]);
 | 
				
			||||||
 | 
								} catch(e) {
 | 
				
			||||||
 | 
									ulog_info('failed to initialze policy "%s"\n', config[section].name);
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								ulog_info('loaded policy "%s"\n', config[section].name);
 | 
				
			||||||
 | 
								policies[config[section].name] = policy;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						status: function(msg) {
 | 
				
			||||||
 | 
							/* if no specific policies state was requested, dump the list of loaded policies */
 | 
				
			||||||
 | 
							if (msg?.name === null)
 | 
				
			||||||
 | 
								return { policies: keys(policies) };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* check if the requested policy exists and dump its state */
 | 
				
			||||||
 | 
							if (policies[msg.name])
 | 
				
			||||||
 | 
								return policies[msg.name].status(msg);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* return an empty dictionary */
 | 
				
			||||||
 | 
							return {};
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										91
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/policy_snr.uc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/policy_snr.uc
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,91 @@
 | 
				
			|||||||
 | 
					let config = {
 | 
				
			||||||
 | 
						/* how many seconds must a client be below the thershold before we kick it */
 | 
				
			||||||
 | 
						min_snr_kick_delay: 5,
 | 
				
			||||||
 | 
						/* the reson code sent when triggering the deauth (IEEE Std 802.11-2016, 9.4.1.7, Table 9-45) */
 | 
				
			||||||
 | 
						kick_reason: 5,
 | 
				
			||||||
 | 
						/* the periodicity for checking client kick conditions */
 | 
				
			||||||
 | 
						interval: 1000,
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					/* counter of how often a station was kicked */
 | 
				
			||||||
 | 
					let kick_count = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					let foo = 0;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function snr_update() {
 | 
				
			||||||
 | 
						try {
 | 
				
			||||||
 | 
							let iface = global.local.status();
 | 
				
			||||||
 | 
							let stations = global.station.list();
 | 
				
			||||||
 | 
							let now = time();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* iterate over all stations and kick anything that had a signal worse than the threshold for too long */
 | 
				
			||||||
 | 
							for (let addr in stations) {
 | 
				
			||||||
 | 
								let station = stations[addr];
 | 
				
			||||||
 | 
								if (!station.signal || !station.device)
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
								let device = iface[station.device].config;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if (!device?.client_kick_rssi)
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								if (0) {
 | 
				
			||||||
 | 
									foo++;
 | 
				
			||||||
 | 
									if (foo > 10)
 | 
				
			||||||
 | 
										station.signal = -80;
 | 
				
			||||||
 | 
									printf(`snr check ${addr} ${station.seen} ${station.signal} ${device.client_kick_rssi}\n`);
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								printf(`${addr} ${station.signal} ${device.client_kick_rssi}\n`);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								/* ignore old stations and ones that have a good signal */
 | 
				
			||||||
 | 
								if (now - station.seen > 2 || station.signal >= device.client_kick_rssi) {
 | 
				
			||||||
 | 
									station.snr_kick_timer = 0;
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								/* find out how long the station had a bad signal for */
 | 
				
			||||||
 | 
								if (!station.snr_kick_timer)
 | 
				
			||||||
 | 
									station.snr_kick_timer = now;
 | 
				
			||||||
 | 
								if (now - station.snr_kick_timer < config.min_snr_kick_delay)
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								printf(`${now - station.seen}\n`);
 | 
				
			||||||
 | 
								if ((now - station.seen) > 2)
 | 
				
			||||||
 | 
									return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								/* kick the station and ban it for the configured timeout */
 | 
				
			||||||
 | 
								ulog_info(`kick ${addr} as signal (${station.signal}) is too low\n`);
 | 
				
			||||||
 | 
								global.station.kick(addr, config.kick_reason, device.client_kick_ban_time);
 | 
				
			||||||
 | 
								kick_count++;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						} catch(e) {
 | 
				
			||||||
 | 
							printf(`snr exception ${e}\n`);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return config.interval;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function probe_handler(type, data) {
 | 
				
			||||||
 | 
						/* only send a probe request if the signal is good enough */
 | 
				
			||||||
 | 
						return (data.signal > config.min_connect_snr)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						init: function(data) {
 | 
				
			||||||
 | 
							/* load config and override defaults if they were set in UCI */
 | 
				
			||||||
 | 
							for (let key in config)
 | 
				
			||||||
 | 
								if (data[key])
 | 
				
			||||||
 | 
									config[key] = +data[key];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* register a callback that will inspect probe-requests and prevent a reply if SNR is too low */
 | 
				
			||||||
 | 
							//global.local.register_handler('probe', probe_handler);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* register the timer that periodically checks if a client should be kicked */
 | 
				
			||||||
 | 
							uloop_timeout(snr_update, config.interval);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						status: function(data) {
 | 
				
			||||||
 | 
							/* dump the status of this policy */
 | 
				
			||||||
 | 
							return { config, kick_count };
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
							
								
								
									
										201
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/station.uc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								feeds/ucentral/usteer2/files/usr/share/usteer/station.uc
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,201 @@
 | 
				
			|||||||
 | 
					let stations = {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function station_add(device, addr, data, seen) {
 | 
				
			||||||
 | 
						/* only honour stations that are authenticated */
 | 
				
			||||||
 | 
						if (!data.auth || !data.assoc)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* if the station is new, add the initial entry */
 | 
				
			||||||
 | 
						if (!stations[addr]) {
 | 
				
			||||||
 | 
							ulog_info(`add station ${ addr }\n`);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* extract the rrm bits and give them meaningful names */
 | 
				
			||||||
 | 
							let rrm = {
 | 
				
			||||||
 | 
								link_measure: !!(data.rrm[0] & 0x1),
 | 
				
			||||||
 | 
								beacon_passive_measure: !!(data.rrm[0] & 0x10),
 | 
				
			||||||
 | 
								beacon_active_measure: !!(data.rrm[0] & 0x20),
 | 
				
			||||||
 | 
								beacon_table_measure: !!(data.rrm[0] & 0x40),
 | 
				
			||||||
 | 
								statistics_measure: !!(data.rrm[1] & 0x8),
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* add the new station */
 | 
				
			||||||
 | 
							stations[addr] = {
 | 
				
			||||||
 | 
								rrm,
 | 
				
			||||||
 | 
								beacon_report: {},
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* update device, seen and signal data */
 | 
				
			||||||
 | 
						stations[addr].device = device;
 | 
				
			||||||
 | 
						stations[addr].seen = seen;
 | 
				
			||||||
 | 
						if (data.signal)
 | 
				
			||||||
 | 
							stations[addr].signal = data.signal;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function station_del(addr) {
 | 
				
			||||||
 | 
						ulog_info(`deleting ${ addr }\n`);
 | 
				
			||||||
 | 
						delete stations[addr];
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function stations_update() {
 | 
				
			||||||
 | 
						try {
 | 
				
			||||||
 | 
							/* lets not call time() multiple times */
 | 
				
			||||||
 | 
							let seen = time();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* iterate over all ssids and ask hapd for the list of associations */
 | 
				
			||||||
 | 
							for (let device in global.local.status()) {
 | 
				
			||||||
 | 
								let clients = global.ubus.conn.call(`hostapd.${ device}`, 'get_clients');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								for (let client in clients.clients)
 | 
				
			||||||
 | 
									if (clients.clients[client].auth)
 | 
				
			||||||
 | 
										station_add(device, client, clients.clients[client], seen);
 | 
				
			||||||
 | 
									else
 | 
				
			||||||
 | 
										station_del(client);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* purge all stations that have not been seen in a while */
 | 
				
			||||||
 | 
							for (let station in stations) {
 | 
				
			||||||
 | 
								if (seen - stations[station].seen <= +global.config.station_expiry)
 | 
				
			||||||
 | 
									continue;
 | 
				
			||||||
 | 
								station_del(station);
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						} catch (e) {
 | 
				
			||||||
 | 
							printf('%.J', e);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* restart the timer */
 | 
				
			||||||
 | 
						return +global.config.station_update;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function beacon_report(type, report) {
 | 
				
			||||||
 | 
						/* make sure that the station exists */
 | 
				
			||||||
 | 
						if (!stations[report.address]) {
 | 
				
			||||||
 | 
							ulog_err(`beacon report on unknown station ${report.address}\n`);
 | 
				
			||||||
 | 
							return false;
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* store the report */
 | 
				
			||||||
 | 
						stations[report.address].beacon_report[report.bssid] = {
 | 
				
			||||||
 | 
							seen: time(),
 | 
				
			||||||
 | 
							channel: report.channel,
 | 
				
			||||||
 | 
							rcpi: report.rcpi,
 | 
				
			||||||
 | 
							rsni: report.rsni,
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function probe_handler(type, data) {
 | 
				
			||||||
 | 
						/* track non-associated stations SNR */
 | 
				
			||||||
 | 
						stations[data.address] = {
 | 
				
			||||||
 | 
							signal: data.signal,
 | 
				
			||||||
 | 
							connected: false,
 | 
				
			||||||
 | 
							seen: time(),
 | 
				
			||||||
 | 
						};
 | 
				
			||||||
 | 
						return true;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function disassoc_handler(type, data) {
 | 
				
			||||||
 | 
						station_del(data.address);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return true;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					return {
 | 
				
			||||||
 | 
						init: function() {
 | 
				
			||||||
 | 
							/* register the mgmt frame handlers */
 | 
				
			||||||
 | 
							global.local.register_handler('beacon-report', beacon_report);
 | 
				
			||||||
 | 
							//global.local.register_handler('probe', probe_handler);
 | 
				
			||||||
 | 
							global.local.register_handler('disassoc', disassoc_handler);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* initial probe of associated stations */
 | 
				
			||||||
 | 
							uloop_timeout(stations_update, 100);
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						status: function() {
 | 
				
			||||||
 | 
							let ret = { };
 | 
				
			||||||
 | 
							let now = time();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* get the list of our local APs */
 | 
				
			||||||
 | 
							let local = global.local.status();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* iterate over all APs and aggregate their associations */
 | 
				
			||||||
 | 
							for (let device in local) {
 | 
				
			||||||
 | 
								/* iterate over all known stations */
 | 
				
			||||||
 | 
								for (let addr, station in stations) {
 | 
				
			||||||
 | 
									/* match for the current AP */
 | 
				
			||||||
 | 
									if (station.device != device)
 | 
				
			||||||
 | 
										continue;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									/* add the station info to the return data */
 | 
				
			||||||
 | 
									ret[addr] = {
 | 
				
			||||||
 | 
										[device]: {
 | 
				
			||||||
 | 
											signal: station.signal,
 | 
				
			||||||
 | 
											rrm: station.rrm,
 | 
				
			||||||
 | 
											last_seen: now - station.seen,
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
									if (length(station.beacon_report))
 | 
				
			||||||
 | 
										ret[addr][device].beacon_report = station.beacon_report;
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							return ret;
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						beacon_request: function(addr, channel, mode, op_class, duration) {
 | 
				
			||||||
 | 
							let station = stations[addr];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* make sure that the station exists */
 | 
				
			||||||
 | 
							if (!station) {
 | 
				
			||||||
 | 
								ulog_err(`beacon request on unknown station ${addr}`);
 | 
				
			||||||
 | 
								return false;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* make sure that the station supports active beacon requests */
 | 
				
			||||||
 | 
							if (!station.rrm?.beacon_active_measure) {
 | 
				
			||||||
 | 
								ulog_err(`${addr} does not support beacon requests`);
 | 
				
			||||||
 | 
								return false;
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							station.beacon_report = {};
 | 
				
			||||||
 | 
							let payload = {
 | 
				
			||||||
 | 
								addr,
 | 
				
			||||||
 | 
								channel,
 | 
				
			||||||
 | 
								mode: mode || 1,
 | 
				
			||||||
 | 
								op_class: op_class || 128,
 | 
				
			||||||
 | 
								duration: duration || 100,
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
							global.ubus.conn.call(`hostapd.${station.device}`, 'rrm_beacon_req', payload);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return true;
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						kick: function(addr, reason, ban_time) {
 | 
				
			||||||
 | 
							if (!exists(stations, addr))
 | 
				
			||||||
 | 
								return -1;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							let payload = {
 | 
				
			||||||
 | 
								addr,
 | 
				
			||||||
 | 
								reason: reason || 5,
 | 
				
			||||||
 | 
								deauth: 1
 | 
				
			||||||
 | 
							};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if (ban_time)
 | 
				
			||||||
 | 
								payload.ban_time = ban_time * 1000;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							/* tell hostapd to kick a station via ubus */
 | 
				
			||||||
 | 
							global.ubus.conn.call(`hostapd.${stations[addr].device}`, 'del_client', payload);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							return 0;
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						list: function(msg) {
 | 
				
			||||||
 | 
							if (msg?.mac)
 | 
				
			||||||
 | 
								return stations[msg.mac] || {};
 | 
				
			||||||
 | 
							return stations;
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						steer: function(addr, imminent, neighbors) {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -115,6 +115,11 @@ define Package/ath11k-firmware-qcn9000/install
 | 
				
			|||||||
		$(1)/lib/firmware/ath11k/QCN9074/hw1.0/
 | 
							$(1)/lib/firmware/ath11k/QCN9074/hw1.0/
 | 
				
			||||||
endef
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					define Package/ath11k-wifi-yuncore-ax840/install
 | 
				
			||||||
 | 
						$(INSTALL_DIR) $(1)/lib/firmware/ath11k/IPQ6018/hw1.0/
 | 
				
			||||||
 | 
						$(INSTALL_DATA) ./board-2.bin.IPQ6018 $(1)/lib/firmware/ath11k/IPQ6018/hw1.0/board-2.bin
 | 
				
			||||||
 | 
					endef
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(eval $(call BuildPackage,ath11k-firmware-ipq50xx))
 | 
					$(eval $(call BuildPackage,ath11k-firmware-ipq50xx))
 | 
				
			||||||
$(eval $(call BuildPackage,ath11k-firmware-ipq50xx-spruce))
 | 
					$(eval $(call BuildPackage,ath11k-firmware-ipq50xx-spruce))
 | 
				
			||||||
$(eval $(call BuildPackage,ath11k-firmware-ipq60xx))
 | 
					$(eval $(call BuildPackage,ath11k-firmware-ipq60xx))
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -36,12 +36,18 @@ 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 \
 | 
				
			||||||
 | 
						muxi-ap3220l \
 | 
				
			||||||
	plasmacloud-pax1800 \
 | 
						plasmacloud-pax1800 \
 | 
				
			||||||
	wallys-dr6018 \
 | 
						wallys-dr6018 \
 | 
				
			||||||
	wallys-dr6018-v4 \
 | 
						wallys-dr6018-v4 \
 | 
				
			||||||
	tplink-ex227 \
 | 
						tplink-ex227 \
 | 
				
			||||||
	tplink-ex447 \
 | 
						tplink-ex447 \
 | 
				
			||||||
	yuncore-ax840 \
 | 
						yuncore-ax840 \
 | 
				
			||||||
 | 
						yuncore-fap650 \
 | 
				
			||||||
	meshpp-s618
 | 
						meshpp-s618
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ALLWIFIPACKAGES:=$(foreach BOARD,$(ALLWIFIBOARDS),ath11k-wifi-$(BOARD))
 | 
					ALLWIFIPACKAGES:=$(foreach BOARD,$(ALLWIFIBOARDS),ath11k-wifi-$(BOARD))
 | 
				
			||||||
@@ -240,10 +246,16 @@ $(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))
 | 
				
			||||||
$(eval $(call generate-ath11k-wifi-package,meshpp-s618,Mesh++ S618))
 | 
					$(eval $(call generate-ath11k-wifi-package,meshpp-s618,Mesh++ S618))
 | 
				
			||||||
 | 
					$(eval $(call generate-ath11k-wifi-package,muxi-ap3220l,MUXI AP3220L))
 | 
				
			||||||
 | 
					$(eval $(call generate-ath11k-wifi-package,yuncore-fap650,YunCore FAP650))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
$(foreach PACKAGE,$(ALLWIFIPACKAGES),$(eval $(call BuildPackage,$(PACKAGE))))
 | 
					$(foreach PACKAGE,$(ALLWIFIPACKAGES),$(eval $(call BuildPackage,$(PACKAGE))))
 | 
				
			||||||
$(eval $(call BuildPackage,ath11k-wifi-qcom-ipq5018))
 | 
					$(eval $(call BuildPackage,ath11k-wifi-qcom-ipq5018))
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										
											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.
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user