mirror of
				https://github.com/Telecominfraproject/wlan-ap.git
				synced 2025-10-31 02:17:58 +00:00 
			
		
		
		
	Compare commits
	
		
			269 Commits
		
	
	
		
			release/v2
			...
			v2.9.0-rc1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 94d154c628 | ||
|   | 071962440e | ||
|   | 5171b52570 | ||
|   | fb282e2aff | ||
|   | 5013b9c7fe | ||
|   | 0e2fcfcb95 | ||
|   | a7ea6ef398 | ||
|   | b4a2291dce | ||
|   | 9348c426e5 | ||
|   | 678c4db8f0 | ||
|   | e979df64d1 | ||
|   | 43fa167f14 | ||
|   | 2a8858a3a2 | ||
|   | 977d16557a | ||
|   | 3db254c306 | ||
|   | 9274c3a719 | ||
|   | 993ff2624e | ||
|   | 60f6565d18 | ||
|   | 924d30af74 | ||
|   | c55d19c3c5 | ||
|   | 9221c3e7e7 | ||
|   | eb862cf2d2 | ||
|   | 1e3cef1a26 | ||
|   | 50fd49fd3d | ||
|   | 8e8a763485 | ||
|   | ab47566e82 | ||
|   | e9a834c205 | ||
|   | 6dc524e67b | ||
|   | b61b3aa06f | ||
|   | b9d43eb897 | ||
|   | c069ba71cc | ||
|   | df01a9acc0 | ||
|   | e0aa0eec98 | ||
|   | 2a145ba46a | ||
|   | 9f34e57df8 | ||
|   | 9c8affad09 | ||
|   | cd76797336 | ||
|   | feb26f21fd | ||
|   | 5ff23ce3cf | ||
|   | cacb8a23dd | ||
|   | f5604d42f6 | ||
|   | 8f74933b37 | ||
|   | 2d92eeab07 | ||
|   | c44ab8b4e6 | ||
|   | d3ad594940 | ||
|   | 8f53da4f79 | ||
|   | 1cc9673e8c | ||
|   | 258e484d5f | ||
|   | 7edbe99599 | ||
|   | fbcfddfbdc | ||
|   | 0e75b82eb6 | ||
|   | 492db67f64 | ||
|   | 6129f525d5 | ||
|   | 2ec381534e | ||
|   | 29d6d9f1ea | ||
|   | a530af9354 | ||
|   | e42fd1e3a4 | ||
|   | 30cfc34e1c | ||
|   | 0737a706ec | ||
|   | b3589c92dc | ||
|   | 0f40cb8e77 | ||
|   | a051edcd00 | ||
|   | 18b19c92be | ||
|   | a2eabf35e3 | ||
|   | 0dfe43f1e6 | ||
|   | 20cda84f47 | ||
|   | 0228173d53 | ||
|   | 0db604ad1e | ||
|   | c53d342b6a | ||
|   | 42e77e6f5a | ||
|   | e8bd819e39 | ||
|   | 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 | ||
|   | dc2feb3cc7 | ||
|   | ed397f5ce4 | ||
|   | 19f0260c0a | ||
|   | 49c55bdec5 | ||
|   | 2ab86ee29d | ||
|   | 888aa40057 | ||
|   | 2291ccf198 | ||
|   | 1d031a0535 | ||
|   | cb7ed7a37b | ||
|   | e692aea19e | ||
|   | a8bb06fb1c | ||
|   | 63b5803086 | ||
|   | 68689674b7 | ||
|   | fccdccdba3 | ||
|   | 21176badf7 | ||
|   | 87adc56e60 | ||
|   | 0f8be3bbde | ||
|   | a3fc407f25 | ||
|   | 30c2c68579 | ||
|   | 736e3e58cf | ||
|   | b38cd9bb9f | ||
|   | d69a8f159d | ||
|   | baaa31f445 | ||
|   | cf18242ee5 | ||
|   | fdcfffd81d | ||
|   | c9a76b8d76 | ||
|   | 9bd53e7d91 | ||
|   | 812fb18160 | ||
|   | 0571cc73da | ||
|   | 6bdd93ce0f | ||
|   | 0603953d9f | ||
|   | 098c81376f | ||
|   | 7ef10fcfb4 | ||
|   | 823ac590ff | ||
|   | 9b68205dc0 | ||
|   | d8216dc583 | ||
|   | 2e3c52160c | ||
|   | 8686846a09 | ||
|   | 8de22ca44b | ||
|   | 3e692ed95a | ||
|   | 128bd3a17e | ||
|   | cc54c8654f | ||
|   | 200f627a9c | ||
|   | 0134c1cb64 | ||
|   | 5519ab913b | ||
|   | 530332fb51 | ||
|   | 8bb8c16b34 | ||
|   | a6a7d82607 | ||
|   | f78dc0cd77 | ||
|   | aaf830ae27 | ||
|   | 555e1a2b1b | ||
|   | 0fbe2e9089 | ||
|   | e87c1ca2dd | ||
|   | c0b3e38215 | ||
|   | 0bf5ea74b3 | ||
|   | 1c4c82a9df | ||
|   | 4d1022f29b | ||
|   | a652e6c8d2 | ||
|   | 7b91863cba | ||
|   | c7ad6eaf2c | ||
|   | c06923a022 | ||
|   | d9a8e771ae | ||
|   | 7e2cec9d91 | ||
|   | 84add765fe | ||
|   | f050d53ed4 | ||
|   | 26be8ab162 | ||
|   | 3f93f7c972 | ||
|   | 7bab50dd3c | 
| @@ -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', 'tp-link_ec420-g1', 'tplink_ex227', 'tplink_ex228', 'tplink_ex447', 'udaya_a5-id2', 'wallys_dr40x9', '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 | ||||||
|   | |||||||
| @@ -14,3 +14,4 @@ patch_folders: | |||||||
|   - patches/ipq807x |   - patches/ipq807x | ||||||
|   - patches/rtkmipsel |   - patches/rtkmipsel | ||||||
|   - patches/rest |   - patches/rest | ||||||
|  |   - patches/x86 | ||||||
|   | |||||||
| @@ -1,77 +0,0 @@ | |||||||
| # Copyright (c) Facebook, Inc. and its affiliates. |  | ||||||
| # All rights reserved. |  | ||||||
| # |  | ||||||
| # This source code is licensed under the license found in the |  | ||||||
| # LICENSE file in the root directory of this source tree. |  | ||||||
| # |  | ||||||
|  |  | ||||||
|  |  | ||||||
| include $(TOPDIR)/rules.mk |  | ||||||
|  |  | ||||||
| PKG_NAME:=fbwifi |  | ||||||
| PKG_VERSION:=2 |  | ||||||
| PKG_RELEASE:=0 |  | ||||||
| PKG_LICENSE:=GPL-2.0 |  | ||||||
|  |  | ||||||
| PKG_MAINTAINER:=Simon Kinane <skinane@fb.com> |  | ||||||
|  |  | ||||||
| PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_NAME) |  | ||||||
|  |  | ||||||
| include $(INCLUDE_DIR)/package.mk |  | ||||||
|  |  | ||||||
| define Package/fbwifi |  | ||||||
|   SUBMENU:=Captive Portals |  | ||||||
|   SECTION:=net |  | ||||||
|   CATEGORY:=Network |  | ||||||
|   DEPENDS:=+iptables +luasec +luasocket \ |  | ||||||
| 	+libuci-lua +luaposix \ |  | ||||||
| 	+lua-cjson +uhttpd |  | ||||||
|   TITLE:=Facebook Wi-Fi |  | ||||||
|   PKGARCH:=all |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/fbwifi/description |  | ||||||
|   Facebook Wi-Fi, an AP authorisation solution |  | ||||||
| endef |  | ||||||
|  |  | ||||||
|  |  | ||||||
| define Package/luci-app-fbwifi |  | ||||||
|   SUBMENU:=3. Applications |  | ||||||
|   SECTION:=luci |  | ||||||
|   CATEGORY:=LuCI |  | ||||||
|   TITLE:=LuCI support for Facebook Wi-Fi |  | ||||||
|   DEPENDS:= \ |  | ||||||
| 	+fbwifi \ |  | ||||||
| 	+luci-base +luci-mod-network +luci-mod-status +luci-theme-bootstrap |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/luci-app-fbwifi/description |  | ||||||
|   LuCI support for Facebook Wi-Fi |  | ||||||
| endef |  | ||||||
|  |  | ||||||
|  |  | ||||||
| define Package/fbwifi/conffiles |  | ||||||
| /etc/config/fbwifi |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Build/Prepare |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Build/Configure |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Build/Compile |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/fbwifi/install |  | ||||||
| 	$(INSTALL_DIR) $(1) |  | ||||||
| 	$(CP) ./files/fbwifi/* $(1)/ |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/luci-app-fbwifi/install |  | ||||||
| 	$(INSTALL_DIR) $(1) |  | ||||||
| 	$(CP) ./files/luci-app-fbwifi/* $(1) |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| $(eval $(call BuildPackage,fbwifi)) |  | ||||||
| $(eval $(call BuildPackage,luci-app-fbwifi)) |  | ||||||
| @@ -1,22 +0,0 @@ | |||||||
| # Facebook Wi-Fi v2.0 Reference Implementation for OpenWrt  |  | ||||||
|  |  | ||||||
| ## Getting started |  | ||||||
|  |  | ||||||
| Case studies for OEM customers are available at the official page of [Facebook Wi-Fi](https://www.facebook.com/facebook-wifi). |  | ||||||
|  |  | ||||||
| For OEM engineers, start by reading the init script in [files/etc/init.d/fbwifi](https://github.com/facebookincubator/fbc_owrt_feed/blob/master/fbwifi/files/etc/init.d/fbwifi) |  | ||||||
|  |  | ||||||
| To enable Facebook Wi-Fi, configure the gateway_token in `/etc/config/fbwifi`, and run `fbwifi enable`. |  | ||||||
| To disable Facebook Wi-Fi, run `fbwifi disable`. |  | ||||||
|  |  | ||||||
| ## Contents |  | ||||||
|  |  | ||||||
| The 'files' subdirectory contains two subdirectories, one for the fbwifi |  | ||||||
| package that implements the Facebook Wi-Fi v2.0 standard for OpenWrt, and |  | ||||||
| another one containing a LuCI application to configure Facebook Wi-Fi. |  | ||||||
|  |  | ||||||
| The folder structures follow *nix conventions: |  | ||||||
| - 'etc' is the boot time scripts and configuration |  | ||||||
| - 'usr' contains procedural scripts, lua common code module and GUI prototype for luci |  | ||||||
| - 'www' contains the HTTP endpoints as CGI handlers  |  | ||||||
|  |  | ||||||
| @@ -1,6 +0,0 @@ | |||||||
| config fbwifi 'main' |  | ||||||
| 	option enabled '0' |  | ||||||
| 	option gateway_token 'FBWIFI:GATEWAY|123456789|0123456789|abcdeABCDE123456789' |  | ||||||
| 	option http_port '2060' |  | ||||||
| 	option https_port '2061' |  | ||||||
| 	option zone 'lan' |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| #!/bin/sh |  | ||||||
|  |  | ||||||
| [ "$ACTION" = ifup ] || exit 0 |  | ||||||
|  |  | ||||||
| /etc/init.d/fbwifi enabled || exit 0 |  | ||||||
|  |  | ||||||
| ip route get fibmatch 1.1.1.1 | grep -q "$DEVICE" || exit 0 |  | ||||||
|  |  | ||||||
| logger -t fbwifi "Reloading fbwifi due to $ACTION of $INTERFACE ($DEVICE)" |  | ||||||
| /etc/init.d/fbwifi restart |  | ||||||
| @@ -1,43 +0,0 @@ | |||||||
| #!/bin/sh /etc/rc.common |  | ||||||
|  |  | ||||||
| START=90 |  | ||||||
|  |  | ||||||
| USE_PROCD=1 |  | ||||||
|  |  | ||||||
| reload_service() { |  | ||||||
| 	restart |  | ||||||
| } |  | ||||||
|  |  | ||||||
| service_triggers() { |  | ||||||
| 	procd_add_reload_trigger fbwifi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| start_service() { |  | ||||||
|  |  | ||||||
| 	config_load fbwifi |  | ||||||
| 	config_get_bool enabled 'main' 'enabled' '0' |  | ||||||
| 	[ "$enabled" -eq 0 ] && return |  | ||||||
|  |  | ||||||
| 	config_get http_port main http_port |  | ||||||
| 	[ -z "$http_port" ] && { |  | ||||||
| 		logger -t fbwifi "required option http_port not set" |  | ||||||
| 		exit 1 |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	config_get https_port main https_port |  | ||||||
| 	[ -z "$https_port" ] && { |  | ||||||
| 		logger -t fbwifi "required option https_port not set" |  | ||||||
| 		exit 1 |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	logger "[fbwifi] Enabled; starting" |  | ||||||
|  |  | ||||||
| 	mkdir -p /tmp/fbwifi |  | ||||||
|  |  | ||||||
| 	/usr/sbin/fbwifi reload |  | ||||||
|  |  | ||||||
| 	procd_open_instance |  | ||||||
| 	procd_set_param command /usr/sbin/fbwifi_validate_token_db |  | ||||||
| 	procd_set_param respawn 1 300 0 |  | ||||||
| 	procd_close_instance |  | ||||||
| } |  | ||||||
| @@ -1,156 +0,0 @@ | |||||||
| -- SPDX-License-Identifier: GPL-2.0-only |  | ||||||
| -- Copyright (c) Facebook, Inc. and its affiliates. |  | ||||||
| -- |  | ||||||
| -- FBWIFI Lua library |  | ||||||
| -- function table |  | ||||||
| local fbwifi = {} |  | ||||||
|  |  | ||||||
| local http = require("ssl.https") |  | ||||||
| local json = require("cjson") |  | ||||||
| local log = require("posix.syslog") |  | ||||||
| local uci = require("uci") |  | ||||||
|  |  | ||||||
| function fbwifi.gateway_token() |  | ||||||
| 	token = uci.get("fbwifi.main.gateway_token") |  | ||||||
| 	if token and string.len(token) > 0 then |  | ||||||
| 		return token |  | ||||||
| 	else |  | ||||||
| 		log.syslog( log.LOG_WARNING, "[fbwifi] UCI option fbwifi.main.gateway_token is missing" ) |  | ||||||
| 		return nil |  | ||||||
| 	end  |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function fbwifi.validate_token( token ) |  | ||||||
|  |  | ||||||
| 	local valid = false |  | ||||||
|  |  | ||||||
| 	if string.len(token or '' ) > 0 then |  | ||||||
|  |  | ||||||
| 	        GATEWAY_TOKEN = fbwifi.gateway_token() |  | ||||||
|  |  | ||||||
| 	        URL="https://api.fbwifi.com/v2.0/token" |  | ||||||
| 	        BODY="token="..token |  | ||||||
| 	        body, code, headers = http.request(URL.."?access_token="..GATEWAY_TOKEN, BODY) |  | ||||||
|  |  | ||||||
| 	        if code==200 then |  | ||||||
| 	                valid = true |  | ||||||
| 	        else |  | ||||||
| 	                log.syslog(log.LOG_WARNING, "[fbwifi] validate_token:"..body) |  | ||||||
| 	        end |  | ||||||
|  |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	return valid |  | ||||||
| end |  | ||||||
|  |  | ||||||
| local mac_to_purge='' |  | ||||||
| function remove_client_by_mac(client) |  | ||||||
| 	state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
|  |  | ||||||
| 	for key, value in pairs(client) do |  | ||||||
| 		if |  | ||||||
| 			key == 'mac' and |  | ||||||
| 			value == mac_to_purge |  | ||||||
| 		then |  | ||||||
| 			log.syslog(log.LOG_INFO, string.format("[fbwifi] Purging DB entry %s for MAC %s", client['.name'] or 'unknown', mac_to_purge) ) |  | ||||||
| 			state:delete("fbwifi", client['.name']) |  | ||||||
| 			return |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function fbwifi.instate_client_rule( token, client_mac ) |  | ||||||
|  |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] Validating client "..client_mac) |  | ||||||
|  |  | ||||||
| 	state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
| 	state_name = "token_" .. token |  | ||||||
|  |  | ||||||
| 	RULE_COND="iptables -w -L FBWIFI_CLIENT_TO_INTERNET -t mangle | grep -i -q \"%s\"" |  | ||||||
| 	RULE_FMT="iptables -w -t mangle -%s FBWIFI_CLIENT_TO_INTERNET -m mac --mac-source \"%s\" -j MARK --set-mark 0xfb" |  | ||||||
| 	local RULE |  | ||||||
|  |  | ||||||
| 	log.syslog(log.LOG_INFO, string.format("[fbwifi] Cleaning DB for MAC %s", client_mac) ) |  | ||||||
| 	mac_to_purge = client_mac |  | ||||||
| 	state:foreach("fbwifi", "client", remove_client_by_mac) |  | ||||||
| 	 |  | ||||||
| 		 |  | ||||||
| 	log.syslog(log.LOG_INFO, string.format("[fbwifi] Adding DB entry %s for MAC %s", state_name, client_mac) ) |  | ||||||
| 	state:set("fbwifi", state_name, "client") |  | ||||||
| 	state:set("fbwifi", state_name, "token", token) |  | ||||||
| 	state:set("fbwifi", state_name, "mac", client_mac) |  | ||||||
| 	state:set("fbwifi", state_name, "authenticated", "true") |  | ||||||
| 				 |  | ||||||
| 	-- verify a rule exists for the given client MAC,  |  | ||||||
| 	--   OR install it |  | ||||||
| 	RULE=string.format(RULE_COND.." || "..RULE_FMT, client_mac, "A", client_mac) |  | ||||||
|  |  | ||||||
| 	log.syslog(log.LOG_INFO, string.format( "[fbwifi] Opening iptables for %s", client_mac ) ) |  | ||||||
| 	res = os.execute(RULE) |  | ||||||
| 	if res ~= 0 then  |  | ||||||
| 		log.syslog(log.LOG_WARNING, string.format( "[fbwifi] Failed to update iptables (%s)", res ) ) |  | ||||||
| 	end |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] "..RULE) |  | ||||||
|  |  | ||||||
| 	state:save('fbwifi') |  | ||||||
| 	state:commit('fbwifi') |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function fbwifi.revoke_client_rule( token ) |  | ||||||
|          |  | ||||||
|         if (token == nil) then |  | ||||||
|                 log.syslog(log.LOG_INFO, "[fbwifi] Invalidating token, but token is Nil") |  | ||||||
|                 return |  | ||||||
|         end |  | ||||||
|  |  | ||||||
| 	log.syslog(log.LOG_INFO, string.format( "[fbwifi] Invalidating token (%s)", token) ) |  | ||||||
|  |  | ||||||
| 	state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
| 	state_name = "token_" .. token |  | ||||||
| 	 |  | ||||||
| 	client_mac = state:get("fbwifi", state_name, "mac") |  | ||||||
|  |  | ||||||
| 	if client_mac then |  | ||||||
| 		RULE_COND="iptables -w -L FBWIFI_CLIENT_TO_INTERNET -t mangle | grep -i -q \"%s\"" |  | ||||||
| 		RULE_FMT="iptables -w -t mangle -%s FBWIFI_CLIENT_TO_INTERNET -m mac --mac-source \"%s\" -j MARK --set-mark 0xfb" |  | ||||||
|  |  | ||||||
| 		-- verify a rule exists for the given client MAC,  |  | ||||||
| 		--  AND delete it |  | ||||||
| 		RULE=string.format(RULE_COND.." && "..RULE_FMT, client_mac, "D", client_mac) |  | ||||||
|  |  | ||||||
| 		res = os.execute(RULE) |  | ||||||
| 		if res ~= 0 then  |  | ||||||
| 			log.syslog(log.LOG_WARNING, string.format( "[fbwifi] Failed to update iptables (%s)", res ) ) |  | ||||||
| 		end |  | ||||||
| 		log.syslog(log.LOG_INFO, "[fbwifi] "..RULE) |  | ||||||
|  |  | ||||||
| 		state:delete("fbwifi", state_name) |  | ||||||
| 		state:save('fbwifi') |  | ||||||
| 		state:commit('fbwifi') |  | ||||||
| 	else |  | ||||||
| 		log.syslog(log.LOG_WARNING, string.format( "[fbwifi] Client MAC not found in DB (%s)", state_name ) ) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function fbwifi.reset() |  | ||||||
|  |  | ||||||
| 	local success = false |  | ||||||
|         GATEWAY_TOKEN = fbwifi.gateway_token() |  | ||||||
|         URL="https://api.fbwifi.com/v2.0/gateway/reset" |  | ||||||
| 	BODY="{}" |  | ||||||
|         body, code, headers = http.request(URL.."?access_token="..GATEWAY_TOKEN, BODY) |  | ||||||
|  |  | ||||||
|         if code==200 then |  | ||||||
|                 log.syslog(log.LOG_INFO, "[fbwifi] Reset committed") |  | ||||||
|                 success = true |  | ||||||
|         else |  | ||||||
|                 log.syslog(log.LOG_WARNING, "[fbwifi] Reset failed : "..body) |  | ||||||
|         end |  | ||||||
|  |  | ||||||
| 	return success |  | ||||||
| end |  | ||||||
|  |  | ||||||
| -- |  | ||||||
| -- Return the function table to the host script |  | ||||||
| -- |  | ||||||
| return fbwifi |  | ||||||
| @@ -1,58 +0,0 @@ | |||||||
| #!/bin/sh |  | ||||||
|  |  | ||||||
| case "$1" in |  | ||||||
| disable) |  | ||||||
| 	uci set fbwifi.main.enabled=0 |  | ||||||
|  |  | ||||||
| 	uci delete firewall.fbwifi |  | ||||||
|  |  | ||||||
| 	uci delete uhttpd.fbwifi_redirect |  | ||||||
|  |  | ||||||
| 	uci delete uhttpd.main.json_script |  | ||||||
| 	uci set uhttpd.main.cert='/etc/uhttpd.crt' |  | ||||||
| 	uci set uhttpd.main.key='/etc/uhttpd.key' |  | ||||||
| 	uci set uhttpd.main.rfc1918_filter=1 |  | ||||||
| 	;; |  | ||||||
| enable) |  | ||||||
| 	uci set fbwifi.main.enabled=1 |  | ||||||
|  |  | ||||||
| 	uci set firewall.fbwifi=include |  | ||||||
| 	uci set firewall.fbwifi.enabled=1 |  | ||||||
| 	uci set firewall.fbwifi.family=ipv4 |  | ||||||
| 	uci set firewall.fbwifi.path=/usr/share/fbwifi/firewall.include |  | ||||||
| 	uci set firewall.fbwifi.reload=1 |  | ||||||
| 	uci set firewall.fbwifi.type=script |  | ||||||
|  |  | ||||||
| 	uci set uhttpd.fbwifi_redirect=uhttpd |  | ||||||
| 	uci set uhttpd.fbwifi_redirect.enabled=1 |  | ||||||
| 	uci set uhttpd.fbwifi_redirect.cert='/tmp/fbwifi/https_server_cert' |  | ||||||
| 	uci set uhttpd.fbwifi_redirect.home='/dev/null' |  | ||||||
| 	uci set uhttpd.fbwifi_redirect.json_script='/tmp/fbwifi/uhttpd-redirect.json' |  | ||||||
| 	uci set uhttpd.fbwifi_redirect.key='/tmp/fbwifi/https_server_key' |  | ||||||
| 	uci set uhttpd.fbwifi_redirect.listen_http='0.0.0.0:2060' |  | ||||||
| 	uci set uhttpd.fbwifi_redirect.listen_https='0.0.0.0:2061' |  | ||||||
|  |  | ||||||
| 	uci set uhttpd.main.cert='/tmp/fbwifi/https_server_cert' |  | ||||||
| 	uci set uhttpd.main.json_script='/usr/share/fbwifi/uhttpd.json' |  | ||||||
| 	uci set uhttpd.main.key='/tmp/fbwifi/https_server_key' |  | ||||||
| 	uci set uhttpd.main.rfc1918_filter=0 |  | ||||||
| 	;; |  | ||||||
| reload) |  | ||||||
| 	/usr/sbin/fbwifi_get_config |  | ||||||
|  |  | ||||||
| 	login_url=$(uci -c /var/state get fbwifi.main.captive_portal_url) |  | ||||||
| 	[ -z "$login_url" ] && { |  | ||||||
| 		logger -t fbwifi "captive_portal_url not available yet" |  | ||||||
| 		exit 1 |  | ||||||
| 	} |  | ||||||
| 	printf '{ "request": [ ["redirect", "%s", 302] ] }' "$login_url" > /tmp/fbwifi/uhttpd-redirect.json |  | ||||||
|  |  | ||||||
| 	/etc/init.d/uhttpd restart |  | ||||||
|  |  | ||||||
| 	exit 0 |  | ||||||
| 	;; |  | ||||||
| esac |  | ||||||
|  |  | ||||||
| uci commit |  | ||||||
| /etc/init.d/uhttpd restart |  | ||||||
| reload_config |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| echo -e "Runtime configuration and token DB\n" |  | ||||||
| uci -c /var/state export fbwifi |  | ||||||
|  |  | ||||||
| echo -e "\nDynamic firewall flow rules\n" |  | ||||||
| iptables -t mangle -L FBWIFI_CLIENT_TO_INTERNET |  | ||||||
|  |  | ||||||
| echo -e "\nDHCP leases\n" |  | ||||||
| cat /tmp/dhcp.leases |  | ||||||
| @@ -1,39 +0,0 @@ | |||||||
| #!/usr/bin/lua |  | ||||||
|  |  | ||||||
| http = require("ssl.https") |  | ||||||
| json = require("cjson") |  | ||||||
| log = require("posix.syslog") |  | ||||||
| socket = require("socket") |  | ||||||
| require("uci") |  | ||||||
| fbwifi = require("fbwifi") |  | ||||||
|  |  | ||||||
| GATEWAY_TOKEN = fbwifi.gateway_token() |  | ||||||
| state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
|  |  | ||||||
| payload="name="..socket.dns.gethostname() |  | ||||||
|  |  | ||||||
| function queue_ssid_update(iface) |  | ||||||
| 	bssid_file="/sys/class/net/br-"..iface["network"].."/address" |  | ||||||
| 	local file = io.open(bssid_file) |  | ||||||
|         if file then |  | ||||||
|             for line in file:lines() do |  | ||||||
| 		payload=payload.."&bssid[]="..line |  | ||||||
|             end |  | ||||||
| 	    file:close() |  | ||||||
| 	    payload=payload.."ssid[]="..iface["ssid"] |  | ||||||
|         else |  | ||||||
| 	    log.syslog(log.LOG_WARNING, "[fbwifi] Failed to find BSSID for interface br-"..iface["network"]) |  | ||||||
|         end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| state:foreach("wireless", "wifi-iface", queue_ssid_update) |  | ||||||
|  |  | ||||||
| URL="https://api.fbwifi.com/v2.0/gateway" |  | ||||||
| body, code, headers = http.request(URL.."?access_token="..GATEWAY_TOKEN, payload) |  | ||||||
| if code == 200 then  |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] gateway information updated "..body) |  | ||||||
| 	os.exit(0) |  | ||||||
| else |  | ||||||
| 	log.syslog(log.LOG_WARNING, "[fbwifi] gateway API failed "..body) |  | ||||||
| 	os.exit(code) |  | ||||||
| end |  | ||||||
| @@ -1,111 +0,0 @@ | |||||||
| #!/usr/bin/lua |  | ||||||
| http = require("ssl.https") |  | ||||||
| json = require("cjson") |  | ||||||
| require("uci") |  | ||||||
| log = require("posix.syslog") |  | ||||||
| fbwifi = require("fbwifi") |  | ||||||
|  |  | ||||||
| GATEWAY_TOKEN = fbwifi.gateway_token() |  | ||||||
|  |  | ||||||
| http_port = uci.get("fbwifi.main.http_port") |  | ||||||
| https_port = uci.get("fbwifi.main.https_port") |  | ||||||
|  |  | ||||||
| statefile = assert(io.open("/var/state/fbwifi", "a"), "could not create state file") |  | ||||||
| statefile:close() |  | ||||||
|  |  | ||||||
| state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
|  |  | ||||||
| URL="https://api.fbwifi.com/v2.0/gateway" |  | ||||||
| body, code, headers = http.request(URL.."?access_token="..GATEWAY_TOKEN.."&fields=config,config_version") |  | ||||||
|  |  | ||||||
| if code == 200 then |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] Got gateway config ("..code..")") |  | ||||||
| else |  | ||||||
| 	log.syslog(log.LOG_CRIT, "[fbwifi] Failed to get gateway config ("..code..")") |  | ||||||
| 	os.exit(1) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| obj = json.decode(body) |  | ||||||
|  |  | ||||||
| function save_cert(name, value) |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] Saving cert "..name) |  | ||||||
| 	local f = assert(io.open("/tmp/fbwifi/"..name, "w")) |  | ||||||
| 	f:write(value) |  | ||||||
| 	f:close() |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function process_redirect(ix, host) |  | ||||||
| 	IP_SET = "ip addr replace dev lo "..host |  | ||||||
| 	local result = os.execute(IP_SET) |  | ||||||
| 	if result == 0 then |  | ||||||
| 		log.syslog(log.LOG_INFO, "[fbwifi] Redirect address applied "..host) |  | ||||||
| 	else |  | ||||||
| 		log.syslog(log.LOG_WARNING, "[fbwifi] Failed to apply redirect address "..host) |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	ip = string.match(host, '([0-9\.]*)/([0-9]*)') |  | ||||||
| 	RULE_FMT="grep -q \"%s\" /etc/hosts || echo \"%s\tstar.fbwifigateway.net\" >> /etc/hosts" |  | ||||||
| 	HOSTS_RULE = string.format(RULE_FMT, ip, ip) |  | ||||||
| 	result = os.execute(HOSTS_RULE) |  | ||||||
| 	if result == 0 then |  | ||||||
| 		log.syslog(log.LOG_INFO, "[fbwifi] Cached redirect host for DNS") |  | ||||||
| 	else |  | ||||||
| 		log.syslog(log.LOG_WARNING, "[fbwifi] Failed to amend /etc/hosts") |  | ||||||
| 		log.syslog(log.LOG_INFO, "[fbwifi] "..HOSTS_RULE) |  | ||||||
| 	end |  | ||||||
|  |  | ||||||
| 	result = os.execute("iptables -t nat -A FBWIFI_HOST_REDIRLIST -p tcp --dport 80 -d "..ip.." -j ACCEPT # REDIRECT --to-ports "..http_port) |  | ||||||
| 	--print(result) |  | ||||||
| 	result = os.execute("iptables -t nat -A FBWIFI_HOST_REDIRLIST -p tcp --dport 443 -d "..ip.."  -j ACCEPT # REDIRECT --to-ports "..https_port) |  | ||||||
| 	--print(result) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| save_cert("https_server_cert", obj['config']['https_server_cert']) |  | ||||||
| save_cert("https_server_key", obj['config']['https_server_key']) |  | ||||||
|  |  | ||||||
| result = os.execute("iptables -t nat -F FBWIFI_HOST_REDIRLIST") |  | ||||||
| --print(result) |  | ||||||
| table.foreach(obj['config']['host_redirect_ips'], process_redirect) |  | ||||||
|  |  | ||||||
| RULE_FORMAT = "iptables -t mangle -A FBWIFI_TRAFFIC_ALLOWLIST -d %s -p %s --dport %s -j MARK --set-mark 0xfb" |  | ||||||
| function process_traffic_rule(ix, rule) |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] Traffic rule "..ix) |  | ||||||
| 	 |  | ||||||
| 	if rule["protocol"] == 6 then |  | ||||||
| 		PROTO = "tcp" |  | ||||||
| 	elseif rule["protocol"] == 17 then |  | ||||||
| 		PROTO = "udp" |  | ||||||
| 	end |  | ||||||
| 	RULE = string.format(RULE_FORMAT, rule["ip"], PROTO, rule["port"]) |  | ||||||
| 	local result = os.execute(RULE) |  | ||||||
| 	if result == 0 then |  | ||||||
| 		log.syslog(log.LOG_INFO, "[fbwifi] Traffic rule "..ix) |  | ||||||
| 	else |  | ||||||
| 		log.syslog(log.LOG_WARNING, "[fbwifi] Failed to install traffic rule ; "..RULE) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| local cross_origin_list = {} |  | ||||||
| function process_cross_origin_rule(ix, url) |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] Cross origin rule "..url) |  | ||||||
| 	table.insert(cross_origin_list, url) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function process_url(url_purpose, fqdn) |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] Caching "..url_purpose) |  | ||||||
| 	state:set("fbwifi", "main", url_purpose, fqdn)	 |  | ||||||
| end |  | ||||||
|  |  | ||||||
| state:set("fbwifi", "main", "config") |  | ||||||
|  |  | ||||||
| result = os.execute("iptables -t mangle -F FBWIFI_TRAFFIC_ALLOWLIST ") |  | ||||||
| --print(result) |  | ||||||
| table.foreach(obj['config']['traffic_allowlist'], process_traffic_rule) |  | ||||||
| table.foreach(obj['config']['cross_origin_allowlist'], process_cross_origin_rule) |  | ||||||
| table.foreach(obj['config']['urls'], process_url) |  | ||||||
|  |  | ||||||
| state:set("fbwifi", "main", "cross_origin_allow_rules", cross_origin_list) |  | ||||||
| state:set("fbwifi", "main", "config_version", obj['config_version']) |  | ||||||
|  |  | ||||||
| state:save('fbwifi') |  | ||||||
| state:commit('fbwifi') |  | ||||||
| @@ -1,75 +0,0 @@ | |||||||
| #!/usr/bin/lua |  | ||||||
|  |  | ||||||
| https = require("ssl.https") |  | ||||||
| json = require("cjson") |  | ||||||
| log = require("posix.syslog") |  | ||||||
| fbwifi = require("fbwifi") |  | ||||||
| require("uci") |  | ||||||
|  |  | ||||||
| state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
| GATEWAY_TOKEN = fbwifi.gateway_token() |  | ||||||
|  |  | ||||||
| request = {  |  | ||||||
| 	tokens = {},  |  | ||||||
| 	traffic_type = "total", |  | ||||||
| 	config_version = state:get("fbwifi", "main", "config_version") |  | ||||||
| } |  | ||||||
|  |  | ||||||
| function queue_token(client) |  | ||||||
|  |  | ||||||
| 	request.tokens[client.token]={ |  | ||||||
| 		incoming = json.null, |  | ||||||
| 		outgoing = json.null, |  | ||||||
| 		connected_time_sec = json.null, |  | ||||||
| 		inactive_time_sec = json.null, |  | ||||||
| 		signal_rssi_dbm = json.null, |  | ||||||
| 		--expected_tpus_mbps = json.null, |  | ||||||
| 		is_connected = true |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| end |  | ||||||
|  |  | ||||||
| state:foreach("fbwifi", "client", queue_token) |  | ||||||
| print( "\nRequest:\n"..json.encode(request) ) |  | ||||||
|  |  | ||||||
| URL="https://api.fbwifi.com/v2.0/tokens" |  | ||||||
| BODY=string.format( |  | ||||||
| 	"tokens=%s&traffic_type=%s&config_version=%s", |  | ||||||
| 	json.encode(request.tokens), |  | ||||||
| 	"total", |  | ||||||
| 	state:get("fbwifi", "main", "config_version") |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| body, code, headers = https.request(URL.."?access_token="..GATEWAY_TOKEN, BODY) |  | ||||||
|  |  | ||||||
| if code then |  | ||||||
| 	print( "\nResponse:\n"..body ) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| response = json.decode(body) |  | ||||||
| --print(response) |  | ||||||
| --table.foreach(response,print) |  | ||||||
| --table.foreach(response.tokens,print) |  | ||||||
|  |  | ||||||
| if response.config_valid then |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] Config validated") |  | ||||||
| else |  | ||||||
| 	log.syslog(log.LOG_WARNING, "[fbwifi] config is stale, refreshing config") |  | ||||||
|         local result = os.execute("/usr/sbin/fbwifi reload") |  | ||||||
|         if result == 0 then |  | ||||||
|                 log.syslog(log.LOG_INFO, "[fbwifi] successfully fetched and loaded new config ") |  | ||||||
|         else |  | ||||||
|                 log.syslog(log.LOG_WARNING, "[fbwifi] failed to fetch and load new config, possible stale config") |  | ||||||
|         end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function process_token(token, metadata) |  | ||||||
| 	table.foreach(metadata,print) |  | ||||||
| 	if metadata.valid then |  | ||||||
| 		print("OK: "..token)	 |  | ||||||
| 	else |  | ||||||
| 		print("Nok: "..token)	 |  | ||||||
| 		fbwifi.revoke_client_rule( token ) |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
| table.foreach(response.tokens,process_token) |  | ||||||
| @@ -1,75 +0,0 @@ | |||||||
| #!/bin/sh |  | ||||||
|  |  | ||||||
| # SPDX-License-Identifier: GPL-2.0-only |  | ||||||
| # Copyright (c) Facebook, Inc. and its affiliates. |  | ||||||
|  |  | ||||||
| IPT4="/usr/sbin/iptables" |  | ||||||
|  |  | ||||||
| set -- --wait 1 --wait-interval 100 |  | ||||||
|  |  | ||||||
| fbwifi_http_port="$(uci get fbwifi.main.http_port)" |  | ||||||
| [ -n "$fbwifi_http_port" ] || { |  | ||||||
| 	logger -t fbwifi "required option http_port not set" |  | ||||||
| 	exit 1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fbwifi_https_port="$(uci get fbwifi.main.https_port)" |  | ||||||
| [ -n "$fbwifi_https_port" ] || { |  | ||||||
| 	logger -t fbwifi "required option https_port not set" |  | ||||||
| 	exit 1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fbwifi_zone="$(uci get fbwifi.main.zone)" |  | ||||||
| [ -n "$fbwifi_zone" ] || { |  | ||||||
| 	logger -t fbwifi "required option zone  not set" |  | ||||||
| 	exit 1 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fbwifi_ifaces="$(fw3 -q zone "$fbwifi_zone")" |  | ||||||
|  |  | ||||||
| ## Create custom chains |  | ||||||
| "$IPT4" "$@" -t filter -N FBWIFI_FORWARD 2>/dev/null |  | ||||||
| "$IPT4" "$@" -t filter -N FBWIFI_INPUT 2>/dev/null |  | ||||||
| "$IPT4" "$@" -t mangle -N FBWIFI_CLIENT_TO_INTERNET 2>/dev/null |  | ||||||
| "$IPT4" "$@" -t mangle -N FBWIFI_PREROUTING 2>/dev/null |  | ||||||
| "$IPT4" "$@" -t mangle -N FBWIFI_TRAFFIC_ALLOWLIST 2>/dev/null |  | ||||||
| "$IPT4" "$@" -t nat -N FBWIFI_CLIENT_TO_INTERNET 2>/dev/null |  | ||||||
| "$IPT4" "$@" -t nat -N FBWIFI_PREROUTING 2>/dev/null |  | ||||||
| "$IPT4" "$@" -t nat -N FBWIFI_HOST_REDIRLIST 2>/dev/null |  | ||||||
|  |  | ||||||
| ## Flush custom chains |  | ||||||
| "$IPT4" "$@" -t filter -F FBWIFI_FORWARD |  | ||||||
| "$IPT4" "$@" -t filter -F FBWIFI_INPUT |  | ||||||
| "$IPT4" "$@" -t mangle -F FBWIFI_CLIENT_TO_INTERNET |  | ||||||
| "$IPT4" "$@" -t mangle -F FBWIFI_PREROUTING |  | ||||||
| "$IPT4" "$@" -t mangle -F FBWIFI_TRAFFIC_ALLOWLIST |  | ||||||
| "$IPT4" "$@" -t nat -F FBWIFI_CLIENT_TO_INTERNET |  | ||||||
| "$IPT4" "$@" -t nat -F FBWIFI_PREROUTING |  | ||||||
| "$IPT4" "$@" -t nat -F FBWIFI_HOST_REDIRLIST |  | ||||||
|  |  | ||||||
| ## Populate custom chains |  | ||||||
| "$IPT4" "$@" -t filter -A FBWIFI_FORWARD -p udp --dport 53 -m conntrack --ctstate NEW -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t filter -A FBWIFI_FORWARD -m conntrack --ctstate NEW -m mark --mark 0xfb -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t filter -A FBWIFI_FORWARD -j REJECT |  | ||||||
| "$IPT4" "$@" -t filter -A FBWIFI_INPUT -p tcp --dport "$fbwifi_http_port" -m conntrack --ctstate NEW -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t filter -A FBWIFI_INPUT -p tcp --dport "$fbwifi_https_port"  -m conntrack --ctstate NEW -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t filter -A FBWIFI_INPUT -p tcp --dport 443 -m conntrack --ctstate NEW -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t mangle -A FBWIFI_PREROUTING -j FBWIFI_CLIENT_TO_INTERNET |  | ||||||
| "$IPT4" "$@" -t mangle -A FBWIFI_PREROUTING -j FBWIFI_TRAFFIC_ALLOWLIST |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_PREROUTING -j FBWIFI_CLIENT_TO_INTERNET |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_CLIENT_TO_INTERNET -p tcp --dport 80 -m conntrack --ctstate NEW -j FBWIFI_HOST_REDIRLIST |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_CLIENT_TO_INTERNET -p tcp --dport 443 -m conntrack --ctstate NEW -j FBWIFI_HOST_REDIRLIST |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_CLIENT_TO_INTERNET -p udp --dport 443 -m conntrack --ctstate NEW -j FBWIFI_HOST_REDIRLIST |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_CLIENT_TO_INTERNET -p tcp --dport 80 -m conntrack --ctstate NEW -m mark --mark 0xfb -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_CLIENT_TO_INTERNET -p tcp --dport 443 -m conntrack --ctstate NEW -m mark --mark 0xfb -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_CLIENT_TO_INTERNET -p udp --dport 443 -m conntrack --ctstate NEW -m mark --mark 0xfb -j ACCEPT |  | ||||||
| "$IPT4" "$@" -t nat -A FBWIFI_CLIENT_TO_INTERNET -p tcp --dport 80 -m conntrack --ctstate NEW -j REDIRECT --to-ports "$fbwifi_http_port" |  | ||||||
|  |  | ||||||
| ## Hook custom chains in firewall3 chains |  | ||||||
| "$IPT4" "$@" -t filter -I "zone_${fbwifi_zone}_input" 2 -j FBWIFI_INPUT |  | ||||||
| "$IPT4" "$@" -t filter -I "zone_${fbwifi_zone}_forward" 2 -j FBWIFI_FORWARD |  | ||||||
| "$IPT4" "$@" -t nat -I "zone_${fbwifi_zone}_prerouting" 2 -j FBWIFI_PREROUTING |  | ||||||
| # There are no firewall3 zone chains in the mangle table so we need to do this for all interfaces in the zone |  | ||||||
| for iface in $fbwifi_ifaces; do |  | ||||||
| 	"$IPT4" "$@" -t mangle -I PREROUTING -i "$iface" -j FBWIFI_PREROUTING |  | ||||||
| done |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| { |  | ||||||
|   "request": [ |  | ||||||
|     [ "if", |  | ||||||
|       [ "regex", "REQUEST_URI", "^/fbwifi" ], |  | ||||||
|       [ "rewrite", "/cgi-bin%REQUEST_URI%" ] |  | ||||||
|     ] |  | ||||||
|   ] |  | ||||||
| } |  | ||||||
| @@ -1,70 +0,0 @@ | |||||||
| #!/usr/bin/lua |  | ||||||
| require("uci") |  | ||||||
| log = require("posix.syslog") |  | ||||||
| fbwifi = require("fbwifi") |  | ||||||
|  |  | ||||||
| state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
| function process_cors() |  | ||||||
| 	origin = os.getenv("HTTP_ORIGIN") |  | ||||||
| 	log.syslog(log.LOG_INFO, string.format("[fbwifi] [auth] process_cors origin %s", origin or 'not found') ) |  | ||||||
| 	if string.len(origin or '') > 0 then |  | ||||||
| 		allow_list = state:get("fbwifi", "main", "cross_origin_allow_rules") |  | ||||||
| 		for _, value in pairs(allow_list) do |  | ||||||
|     			if value == origin then |  | ||||||
| 				log.syslog(log.LOG_INFO, "[fbwifi] [auth] process_cors Appending CORS Headers to HTTP") |  | ||||||
| 				print("Access-Control-Allow-Origin: "..origin) |  | ||||||
| 				print("Vary: Origin") |  | ||||||
| 				break |  | ||||||
| 			end |  | ||||||
| 		end |  | ||||||
| 	else	 |  | ||||||
| 		log.syslog(log.LOG_INFO, "[fbwifi] [auth] process_cors No CORS Headers added to Response") |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| method = os.getenv("REQUEST_METHOD") |  | ||||||
| if method == 'GET' then |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] [auth] GET handler") |  | ||||||
| 	print("Status: 302 Found") |  | ||||||
| 	print("Location: "..state:get("fbwifi", "main", "landing_page_url")) |  | ||||||
| 	process_cors() |  | ||||||
| 	print ('\n') |  | ||||||
|  |  | ||||||
| elseif method == 'POST' then |  | ||||||
| 	local token |  | ||||||
| 	 |  | ||||||
| 	log.syslog(log.LOG_INFO, "[fbwifi] [auth] POST handler") |  | ||||||
| 	process_cors() |  | ||||||
| 	print("Status: 200 OK") |  | ||||||
|  |  | ||||||
| 	form_data=io.read() |  | ||||||
| 	while form_data do |  | ||||||
| 		token = string.match(form_data, '[%d]+') |  | ||||||
| 		if string.len(token or '') > 14 then |  | ||||||
|  |  | ||||||
| 			client = os.getenv("REMOTE_ADDR") |  | ||||||
| 			f = io.popen("awk '/"..client..".*0x2/ { printf(\"%s\", $4) }' /proc/net/arp", 'r') |  | ||||||
| 			client_mac = assert(f:read('*a')) |  | ||||||
| 			f:close() |  | ||||||
|  |  | ||||||
| 			if fbwifi.validate_token(token) then |  | ||||||
|                                 log.syslog(log.LOG_INFO, string.format( "[fbwifi] [auth] POST handler : Validating Token (%s) for MAC (%s)", token or 'nil', client_mac or 'nil') ) |  | ||||||
| 				fbwifi.instate_client_rule(token, client_mac) |  | ||||||
| 				print("\n{\"valid\":true}\n") |  | ||||||
| 			else |  | ||||||
|                                 log.syslog(log.LOG_WARNING, string.format( "[fbwifi] [auth] POST handler : ! Invalid token (%s) for mac (%s) !", token or 'nil', client_mac or 'nil') ) |  | ||||||
| 				fbwifi.revoke_client_rule(token) |  | ||||||
| 				print("\n{\"valid\":false}\n") |  | ||||||
| 			end |  | ||||||
| 			log.syslog(log.LOG_INFO, "[fbwifi] [auth] POST handler completed") |  | ||||||
| 			return |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 		form_data=io.read() |  | ||||||
| 	end |  | ||||||
| 	print ('\n') |  | ||||||
|  |  | ||||||
| 	log.syslog(log.LOG_WARNING, string.format("[fbwifi] [auth] POST handler : token not found" )) |  | ||||||
| 	fbwifi.revoke_client_rule(token) |  | ||||||
| 	print("\n{\"valid\":false}\n") |  | ||||||
| end |  | ||||||
| @@ -1,42 +0,0 @@ | |||||||
| #!/usr/bin/lua |  | ||||||
| json = require("cjson") |  | ||||||
| require("uci") |  | ||||||
|  |  | ||||||
| state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
| client_mac = "" |  | ||||||
| token = "" |  | ||||||
|  |  | ||||||
| response = {} |  | ||||||
| response['venue-info-url'] = state:get("fbwifi", "main", "capport_venue_info_url") |  | ||||||
|  |  | ||||||
| function map_remote_mac_to_token(client) |  | ||||||
|         for key, value in pairs(client) do |  | ||||||
|                 if |  | ||||||
|                         key == 'mac' and |  | ||||||
|                         value == client_mac |  | ||||||
|                 then |  | ||||||
| 			token = client.token |  | ||||||
|                         return false |  | ||||||
|                 end |  | ||||||
|         end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function hasValidToken(client_ip) |  | ||||||
| 	f = io.popen("awk '/"..client_ip..".*0x2/ { printf(\"%s\", $4) }' /proc/net/arp", 'r') |  | ||||||
| 	client_mac = assert(f:read('*a')) |  | ||||||
| 	f:close() |  | ||||||
| 	state:foreach("fbwifi", "client", map_remote_mac_to_token) |  | ||||||
|  |  | ||||||
| 	return 0 < string.len(token) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| print("Content-type: application/captive+json; charset=utf-8\n") |  | ||||||
|  |  | ||||||
| client = os.getenv("REMOTE_ADDR") |  | ||||||
| response['captive'] = not hasValidToken(client) |  | ||||||
|  |  | ||||||
| if response['captive'] then |  | ||||||
| 	response['user-portal-url'] = state:get("fbwifi", "main", "captive_portal_url") |  | ||||||
| end |  | ||||||
|  |  | ||||||
| print( json.encode(response) ) |  | ||||||
| @@ -1,57 +0,0 @@ | |||||||
| #!/usr/bin/lua |  | ||||||
| json = require("cjson") |  | ||||||
| fbwifi = require("fbwifi") |  | ||||||
|  |  | ||||||
| state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
| GATEWAY_TOKEN = fbwifi.gateway_token() |  | ||||||
|  |  | ||||||
| response = { api_version = "2.0", token = json.null } |  | ||||||
| client_mac = "" |  | ||||||
|  |  | ||||||
| function process_cors() |  | ||||||
|         origin = os.getenv("HTTP_ORIGIN") |  | ||||||
|         if string.len(origin or '') > 0 then |  | ||||||
|                 allow_list = state:get("fbwifi", "main", "cross_origin_allow_rules") |  | ||||||
|                 for _, value in pairs(allow_list) do |  | ||||||
|                         if value == origin then |  | ||||||
|                                 print("Access-Control-Allow-Origin: "..origin) |  | ||||||
|                                 print("Vary: Origin") |  | ||||||
|                                 break |  | ||||||
|                         end |  | ||||||
|                 end |  | ||||||
|         end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function map_remote_mac_to_token(client) |  | ||||||
|  |  | ||||||
| 	for key, value in pairs(client) do |  | ||||||
| 		if |  | ||||||
| 			key == 'mac' and |  | ||||||
| 			value == client_mac |  | ||||||
| 		then |  | ||||||
| 			response.token = client.token |  | ||||||
| 			return false -- escape outer loop |  | ||||||
| 		end |  | ||||||
| 	end |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function getClientToken(client_ip) |  | ||||||
| 	f = io.popen("awk '/"..client_ip..".*0x2/ { printf(\"%s\", $4) }' /proc/net/arp", 'r') |  | ||||||
| 	client_mac = assert(f:read('*a')) |  | ||||||
| 	f:close() |  | ||||||
|  |  | ||||||
| 	state:foreach("fbwifi", "client", map_remote_mac_to_token) |  | ||||||
| end |  | ||||||
|  |  | ||||||
| function getGatewayId() |  | ||||||
| 	id = string.match(GATEWAY_TOKEN, 'FBWIFI:GATEWAY|[0-9]*|([0-9]*)') |  | ||||||
| 	return id |  | ||||||
| end |  | ||||||
|  |  | ||||||
| process_cors() |  | ||||||
| print("Content-type: application/json; charset=utf-8\n") |  | ||||||
|  |  | ||||||
| getClientToken(os.getenv("REMOTE_ADDR")) |  | ||||||
| response.gateway_id = getGatewayId() |  | ||||||
|  |  | ||||||
| print( json.encode(response) ) |  | ||||||
| @@ -1,12 +0,0 @@ | |||||||
| -- SPDX-License-Identifier: GPL-2.0-only |  | ||||||
| -- Copyright (c) Facebook, Inc. and its affiliates. |  | ||||||
|  |  | ||||||
| module("luci.controller.fbwifi", package.seeall) |  | ||||||
|  |  | ||||||
| sys = require "luci.sys" |  | ||||||
| ut = require "luci.util" |  | ||||||
|  |  | ||||||
| function index() |  | ||||||
|     entry({"admin", "network", "fbwifi"}, template("fbwifi"), "Facebook Wi-Fi", 90).dependent=false |  | ||||||
| end |  | ||||||
|  |  | ||||||
| @@ -1,16 +0,0 @@ | |||||||
| <%# |  | ||||||
|  Copyright |  | ||||||
|  Licensed to the public under the GNU General Public License v2. |  | ||||||
| -%> |  | ||||||
|  |  | ||||||
| <%+header%> |  | ||||||
|  |  | ||||||
| <h1>Facebook Wi-Fi</h1> |  | ||||||
| <% |  | ||||||
| 	require("uci") |  | ||||||
| 	state = uci.cursor("/var/state", "/tmp/fbwifi") |  | ||||||
| 	url = state:get("fbwifi", "main", "captive_portal_config_url") |  | ||||||
| %> |  | ||||||
| <a href="<% print(url) %>">Configure FB business page</a> |  | ||||||
|  |  | ||||||
| <%+footer%> |  | ||||||
| @@ -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,10 +33,15 @@ 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|\ | ||||||
| 	sercomm,wallaby) | 	sercomm,wallaby|\ | ||||||
|  | 	plasmacloud,pax1800-v1|\ | ||||||
|  | 	plasmacloud,pax1800-v2) | ||||||
| 		ucidef_set_interface_lan "eth0" | 		ucidef_set_interface_lan "eth0" | ||||||
| 		ucidef_set_interface_wan "eth1" | 		ucidef_set_interface_wan "eth1" | ||||||
| 		;; | 		;; | ||||||
| @@ -44,19 +51,29 @@ 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" | ||||||
| 		;; | 		;; | ||||||
|  |        cig,wf660a) | ||||||
|  |                 ucidef_set_interface_lan "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" | ||||||
| 		;; | 		;; | ||||||
| 	wallys,dr6018-v4|\ | 	wallys,dr6018-v4|\ | ||||||
| 	glinet,ax1800) | 	glinet,ax1800|\ | ||||||
|  | 	meshpp,s618-cp03|\ | ||||||
|  | 	meshpp,s618-cp01) | ||||||
| 		ucidef_set_interface_lan "eth1 eth2 eth3 eth4" | 		ucidef_set_interface_lan "eth1 eth2 eth3 eth4" | ||||||
| 		ucidef_set_interface_wan "eth0" | 		ucidef_set_interface_wan "eth0" | ||||||
| 		;; | 		;; | ||||||
| @@ -68,6 +85,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 | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -76,14 +99,32 @@ qcom_setup_macs() | |||||||
| 	local board="$1" | 	local board="$1" | ||||||
|  |  | ||||||
| 	case $board in | 	case $board in | ||||||
|  | 	cig,wf188n|\ | ||||||
| 	cig,wf194c|\ | 	cig,wf194c|\ | ||||||
| 	cig,wf194c4|\ | 	cig,wf194c4) | ||||||
| 	cig,wf196) | 		mtd=$(find_mtd_chardev "0:APPSBLENV") | ||||||
| 		mac=$(grep BaseMacAddress= /dev/mtd14 | cut -dx -f2) | 		[ -z "$mtd" ] && return; | ||||||
|  | 		mac=$(grep BaseMacAddress= $mtd | cut -dx -f2) | ||||||
|  | 		[ -z "$mac" ] && return; | ||||||
| 		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) | ||||||
|  | 		mtd=$(find_mtd_chardev "0:APPSBLENV") | ||||||
|  | 		[ -z "$mtd" ] && return; | ||||||
|  | 		mac=$(grep BaseMacAddress= $mtd | cut -dx -f2) | ||||||
|  | 		[ -z "$mac" ] && return; | ||||||
|  | 		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) | ||||||
| @@ -95,6 +136,25 @@ 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) | ||||||
|  | 		wan_mac=$(cat /sys/class/net/eth1/address) | ||||||
|  | 		lan_mac=$(macaddr_add "$wan_mac" 1) | ||||||
|  | 		;; | ||||||
|  | 	yuncore,fap650) | ||||||
|  | 		wan_mac=$(cat /sys/class/net/eth4/address) | ||||||
|  | 		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) | ||||||
|   | |||||||
| @@ -49,6 +49,15 @@ ath11k_generate_macs_ion4x() { | |||||||
| 	echo -ne \\x${wifimac2//:/\\x} >> /lib/firmware/ath11k-macs | 	echo -ne \\x${wifimac2//:/\\x} >> /lib/firmware/ath11k-macs | ||||||
| } | } | ||||||
|  |  | ||||||
|  | ath11k_generate_macs_pax1800() { | ||||||
|  | 	touch /lib/firmware/ath11k-macs | ||||||
|  | 	eth=$(cat /sys/class/net/eth0/address) | ||||||
|  | 	mac1=$(macaddr_add $eth 10) | ||||||
|  | 	mac2=$(macaddr_add $eth 2) | ||||||
|  | 	echo -ne \\x${mac1//:/\\x} >> /lib/firmware/ath11k-macs | ||||||
|  | 	echo -ne \\x${mac2//:/\\x} >> /lib/firmware/ath11k-macs | ||||||
|  | } | ||||||
|  |  | ||||||
| caldata_die() { | caldata_die() { | ||||||
|         echo "caldata: " "$*" |         echo "caldata: " "$*" | ||||||
|         exit 1 |         exit 1 | ||||||
| @@ -77,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 | ||||||
| 		;; | 		;; | ||||||
| @@ -91,14 +102,24 @@ case "$FIRMWARE" in | |||||||
| 	case "$board" in | 	case "$board" in | ||||||
| 	cig,wf188|\ | 	cig,wf188|\ | ||||||
| 	cig,wf188n|\ | 	cig,wf188n|\ | ||||||
|  | 	cig,wf660a|\ | ||||||
| 	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|\ | ||||||
|  | 	meshpp,ipq6018-cp01|\ | ||||||
|  | 	meshpp,ipq6018-cp03|\ | ||||||
|  | 	qcom,ipq6018-cp03|\ | ||||||
| 	qcom,ipq6018-cp01|\ | 	qcom,ipq6018-cp01|\ | ||||||
| 	xiaomi,ax1800|\ | 	xiaomi,ax1800|\ | ||||||
| 	glinet,ax1800) | 	glinet,ax1800|\ | ||||||
|  | 	yuncore,ax840|\ | ||||||
|  | 	yuncore,fap650|\ | ||||||
|  | 	plasmacloud,pax1800-v1|\ | ||||||
|  | 	plasmacloud,pax1800-v2) | ||||||
|                 caldata_extract "0:ART" 0x1000 0x20000   |                 caldata_extract "0:ART" 0x1000 0x20000   | ||||||
| 		;; | 		;; | ||||||
| 	esac | 	esac | ||||||
| @@ -107,7 +128,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   | ||||||
| 		;; | 		;; | ||||||
| @@ -123,14 +146,19 @@ 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) | ||||||
| 	case "$board" in | 	case "$board" in | ||||||
| 	cig,wf196|\ | 	cig,wf196|\ | ||||||
|  | 	wallys,dr6018-v4|\ | ||||||
| 	cybertan,eww622-a1|\ | 	cybertan,eww622-a1|\ | ||||||
| 	qcom,ipq5018-mp03.1|\ | 	qcom,ipq5018-mp03.1|\ | ||||||
| 	qcom,ipq807x-hk14) | 	qcom,ipq807x-hk14) | ||||||
| @@ -149,21 +177,33 @@ 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 | ||||||
| 		;; | 		;; | ||||||
| 	edgecore,eap101) | 	edgecore,eap101) | ||||||
| 		ath11k_generate_macs_eap101 | 		ath11k_generate_macs_eap101 | ||||||
| 		;; | 		;; | ||||||
|  | 	yuncore,ax840|\ | ||||||
| 	edgecore,eap102|\ | 	edgecore,eap102|\ | ||||||
| 	edgecore,eap106|\ | 	edgecore,eap106|\ | ||||||
|  | 	indio,um-310ax-v1|\ | ||||||
|  | 	indio,um-510axp-v1|\ | ||||||
|  | 	indio,um-510axm-v1|\ | ||||||
|  | 	cig,wf660a|\ | ||||||
| 	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-v2) | ||||||
|  | 		ath11k_generate_macs_pax1800 | ||||||
|  | 		;; | ||||||
| 	esac | 	esac | ||||||
| 	;; | 	;; | ||||||
| *) | *) | ||||||
|   | |||||||
							
								
								
									
										126
									
								
								feeds/ipq807x/ipq807x/base-files/lib/upgrade/dualboot_datachk.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										126
									
								
								feeds/ipq807x/ipq807x/base-files/lib/upgrade/dualboot_datachk.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,126 @@ | |||||||
|  | # The U-Boot loader with the datachk patchset for dualbooting requires image | ||||||
|  | # sizes and checksums to be provided in the U-Boot environment. | ||||||
|  | # The devices come with 2 main partitions - while one is active | ||||||
|  | # sysupgrade will flash the other. The boot order is changed to boot the | ||||||
|  | # newly flashed partition. If the new partition can't be booted due to | ||||||
|  | # upgrade failures the previously used partition is loaded. | ||||||
|  |  | ||||||
|  | platform_post_upgrade_sanity_check() | ||||||
|  | { | ||||||
|  | 	local part_name=$1 | ||||||
|  | 	local inactive_mtd=$2 | ||||||
|  | 	local cfg_md5=$3 | ||||||
|  | 	local part_offset=$4 | ||||||
|  | 	local part_size=$5 | ||||||
|  |  | ||||||
|  | 	md5_part_disk=$(dd if=/dev/${inactive_mtd} bs=$((64*1024)) skip=$((part_offset / (64*1024))) count=$((part_size / (64*1024))) 2>&- | md5sum | awk '{print $1}') | ||||||
|  |  | ||||||
|  | 	if [ "${cfg_md5}" != "${md5_part_disk}" ]; then | ||||||
|  | 	      echo "post-flashing checksum mismatch: ${part_name}" >&2 | ||||||
|  | 	      echo "${cfg_md5} != ${md5_part_disk}" | ||||||
|  | 	      return 1 | ||||||
|  | 	fi | ||||||
|  |  | ||||||
|  | 	return 0 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | platform_do_upgrade_dualboot_datachk() { | ||||||
|  | 	local tar_file="$1" | ||||||
|  | 	local restore_backup | ||||||
|  | 	local primary_kernel_mtd | ||||||
|  |  | ||||||
|  | 	local setenv_script="/tmp/fw_env_upgrade" | ||||||
|  |  | ||||||
|  | 	local kernel_mtd="$(find_mtd_index $PART_NAME)" | ||||||
|  | 	local kernel_offset="$(cat /sys/class/mtd/mtd${kernel_mtd}/offset)" | ||||||
|  | 	local total_size="$(cat /sys/class/mtd/mtd${kernel_mtd}/size)" | ||||||
|  |  | ||||||
|  | 	# detect to which flash region the new image is written to. | ||||||
|  | 	# | ||||||
|  | 	# 1. check what is the mtd index for the first flash region on this | ||||||
|  | 	#    device | ||||||
|  | 	# 2. check if the target partition ("inactive") has the mtd index of | ||||||
|  | 	#    the first flash region | ||||||
|  | 	# | ||||||
|  | 	#    - when it is: the new bootseq will be 1,2 and the first region is | ||||||
|  | 	#      modified | ||||||
|  | 	#    - when it isnt: bootseq will be 2,1 and the second region is | ||||||
|  | 	#      modified | ||||||
|  | 	# | ||||||
|  | 	# The detection has to be done via the hardcoded mtd partition because | ||||||
|  | 	# the current boot might be done with the fallback region. Let us | ||||||
|  | 	# assume that the current bootseq is 1,2. The bootloader detected that | ||||||
|  | 	# the image in flash region 1 is corrupt and thus switches to flash | ||||||
|  | 	# region 2. The bootseq in the u-boot-env is now still the same and | ||||||
|  | 	# the sysupgrade code can now only rely on the actual mtd indexes and | ||||||
|  | 	# not the bootseq variable to detect the currently booted flash | ||||||
|  | 	# region/image. | ||||||
|  | 	# | ||||||
|  | 	# In the above example, an implementation which uses bootseq ("1,2") to | ||||||
|  | 	# detect the currently booted image would assume that region 1 is booted | ||||||
|  | 	# and then overwrite the variables for the wrong flash region (aka the | ||||||
|  | 	# one which isn't modified). This could result in a device which doesn't | ||||||
|  | 	# boot anymore to Linux until it was reflashed with ap51-flash. | ||||||
|  | 	local next_boot_part="1" | ||||||
|  | 	case "$(board_name)" in | ||||||
|  | 	plasmacloud,pax1800-v1|\ | ||||||
|  | 	plasmacloud,pax1800-v2) | ||||||
|  | 		primary_kernel_mtd=9 | ||||||
|  | 		;; | ||||||
|  | 	*) | ||||||
|  | 		echo "failed to detect primary kernel mtd partition for board" | ||||||
|  | 		return 1 | ||||||
|  | 		;; | ||||||
|  | 	esac | ||||||
|  | 	[ "$kernel_mtd" = "$primary_kernel_mtd" ] || next_boot_part="2" | ||||||
|  |  | ||||||
|  | 	local board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$') | ||||||
|  | 	board_dir=${board_dir%/} | ||||||
|  |  | ||||||
|  | 	local kernel_length=$(tar xf $tar_file ${board_dir}/kernel -O | wc -c) | ||||||
|  | 	local rootfs_length=$(tar xf $tar_file ${board_dir}/root -O | wc -c) | ||||||
|  | 	# rootfs without EOF marker | ||||||
|  | 	rootfs_length=$((rootfs_length-4)) | ||||||
|  |  | ||||||
|  | 	local kernel_md5=$(tar xf $tar_file ${board_dir}/kernel -O | md5sum); kernel_md5="${kernel_md5%% *}" | ||||||
|  | 	# md5 checksum of rootfs with EOF marker | ||||||
|  | 	local rootfs_md5=$(tar xf $tar_file ${board_dir}/root -O | dd bs=1 count=$rootfs_length | md5sum); rootfs_md5="${rootfs_md5%% *}" | ||||||
|  |  | ||||||
|  | 	# | ||||||
|  | 	# add tar support to get_image() to use default_do_upgrade() instead? | ||||||
|  | 	# | ||||||
|  |  | ||||||
|  | 	# take care of restoring a saved config | ||||||
|  | 	[ -n "$UPGRADE_BACKUP" ] && restore_backup="${MTD_CONFIG_ARGS} -j ${UPGRADE_BACKUP}" | ||||||
|  |  | ||||||
|  | 	mtd -q erase inactive | ||||||
|  | 	tar xf $tar_file ${board_dir}/root -O | mtd -n -p $kernel_length $restore_backup write - $PART_NAME | ||||||
|  | 	tar xf $tar_file ${board_dir}/kernel -O | mtd -n write - $PART_NAME | ||||||
|  |  | ||||||
|  | 	platform_post_upgrade_sanity_check "kernel" "mtd${kernel_mtd}" $kernel_md5 0 $kernel_length || return 1 | ||||||
|  | 	platform_post_upgrade_sanity_check "rootfs" "mtd${kernel_mtd}" $rootfs_md5 $kernel_length $rootfs_length || return 1 | ||||||
|  |  | ||||||
|  | 	# prepare new u-boot env | ||||||
|  | 	if [ "$next_boot_part" = "1" ]; then | ||||||
|  | 		echo "bootseq 1,2" > $setenv_script | ||||||
|  | 	else | ||||||
|  | 		echo "bootseq 2,1" > $setenv_script | ||||||
|  | 	fi | ||||||
|  |  | ||||||
|  | 	printf "kernel_size_%i 0x%08x\n" $next_boot_part $kernel_length >> $setenv_script | ||||||
|  | 	printf "vmlinux_start_addr 0x%08x\n" ${kernel_offset} >> $setenv_script | ||||||
|  | 	printf "vmlinux_size 0x%08x\n" ${kernel_length} >> $setenv_script | ||||||
|  | 	printf "vmlinux_checksum %s\n" ${kernel_md5} >> $setenv_script | ||||||
|  |  | ||||||
|  | 	printf "rootfs_size_%i 0x%08x\n" $next_boot_part $((total_size-kernel_length)) >> $setenv_script | ||||||
|  | 	printf "rootfs_start_addr 0x%08x\n" $((kernel_offset+kernel_length)) >> $setenv_script | ||||||
|  | 	printf "rootfs_size 0x%08x\n" ${rootfs_length} >> $setenv_script | ||||||
|  | 	printf "rootfs_checksum %s\n" ${rootfs_md5} >> $setenv_script | ||||||
|  |  | ||||||
|  | 	# store u-boot env changes | ||||||
|  | 	mkdir -p /var/lock | ||||||
|  | 	fw_setenv -s $setenv_script || { | ||||||
|  | 		echo "failed to update U-Boot environment" | ||||||
|  | 		return 1 | ||||||
|  | 	} | ||||||
|  | } | ||||||
| @@ -1,7 +1,8 @@ | |||||||
| . /lib/functions/system.sh | . /lib/functions/system.sh | ||||||
|  |  | ||||||
| RAMFS_COPY_BIN='fw_printenv fw_setenv' |  | ||||||
| RAMFS_COPY_DATA='/etc/fw_env.config /var/lock/fw_printenv.lock' | RAMFS_COPY_BIN='fw_setenv' | ||||||
|  | RAMFS_COPY_DATA='/etc/fw_env.config /var/lock/fw_printenv.lock /tmp/downgrade' | ||||||
|  |  | ||||||
| qca_do_upgrade() { | qca_do_upgrade() { | ||||||
|         local tar_file="$1" |         local tar_file="$1" | ||||||
| @@ -49,6 +50,22 @@ do_flash_emmc() { | |||||||
| 	tar Oxf $tar_file ${board_dir}/$part | dd of=${emmcblock} | 	tar Oxf $tar_file ${board_dir}/$part | dd of=${emmcblock} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | emmc_do_upgrade_cig() { | ||||||
|  |         local tar_file="$1" | ||||||
|  |  | ||||||
|  |         local board_dir=$(tar tf $tar_file | grep -m 1 '^sysupgrade-.*/$') | ||||||
|  |         board_dir=${board_dir%/} | ||||||
|  | 	 | ||||||
|  |         do_flash_emmc $tar_file '0:HLOS_1' $board_dir kernel | ||||||
|  |         do_flash_emmc $tar_file 'rootfs_1' $board_dir root | ||||||
|  |  | ||||||
|  |         local emmcblock="$(find_mmc_part "rootfs_data")" | ||||||
|  |         if [ -e "$emmcblock" ]; then | ||||||
|  |                 mkfs.ext4 -F "$emmcblock" | ||||||
|  |         fi | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| emmc_do_upgrade() { | emmc_do_upgrade() { | ||||||
| 	local tar_file="$1" | 	local tar_file="$1" | ||||||
|  |  | ||||||
| @@ -68,6 +85,7 @@ platform_check_image() { | |||||||
| 	board=$(board_name) | 	board=$(board_name) | ||||||
| 	case $board in | 	case $board in | ||||||
| 	cig,wf188|\ | 	cig,wf188|\ | ||||||
|  | 	cig,wf660a|\ | ||||||
| 	cig,wf188n|\ | 	cig,wf188n|\ | ||||||
| 	cig,wf194c|\ | 	cig,wf194c|\ | ||||||
| 	cig,wf194c4|\ | 	cig,wf194c4|\ | ||||||
| @@ -75,18 +93,29 @@ 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-v2|\ | ||||||
| 	tplink,ex227|\ | 	tplink,ex227|\ | ||||||
| 	tplink,ex447|\ | 	tplink,ex447|\ | ||||||
| 	yuncore,ax840|\ | 	yuncore,ax840|\ | ||||||
|  | 	yuncore,fap650|\ | ||||||
| 	motorola,q14|\ | 	motorola,q14|\ | ||||||
|  | 	muxi,ap3220l|\ | ||||||
| 	qcom,ipq6018-cp01|\ | 	qcom,ipq6018-cp01|\ | ||||||
| 	qcom,ipq807x-hk01|\ | 	qcom,ipq807x-hk01|\ | ||||||
| 	qcom,ipq807x-hk14|\ | 	qcom,ipq807x-hk14|\ | ||||||
| @@ -107,6 +136,9 @@ platform_do_upgrade() { | |||||||
| 	cig,wf188) | 	cig,wf188) | ||||||
| 		qca_do_upgrade $1 | 		qca_do_upgrade $1 | ||||||
| 		;; | 		;; | ||||||
|  | 	cig,wf660a) | ||||||
|  | 		emmc_do_upgrade_cig $1 | ||||||
|  | 		;; | ||||||
| 	motorola,q14) | 	motorola,q14) | ||||||
| 		emmc_do_upgrade $1 | 		emmc_do_upgrade $1 | ||||||
| 		;; | 		;; | ||||||
| @@ -115,9 +147,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|\ | ||||||
| @@ -125,11 +159,16 @@ platform_do_upgrade() { | |||||||
| 	wallys,dr6018|\ | 	wallys,dr6018|\ | ||||||
| 	wallys,dr6018-v4|\ | 	wallys,dr6018-v4|\ | ||||||
| 	yuncore,ax840|\ | 	yuncore,ax840|\ | ||||||
|  | 	yuncore,fap650|\ | ||||||
| 	tplink,ex447|\ | 	tplink,ex447|\ | ||||||
| 	tplink,ex227)	 | 	tplink,ex227|\ | ||||||
|  | 	meshpp,s618-cp03|\ | ||||||
|  | 	meshpp,s618-cp01) | ||||||
| 		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" | ||||||
| @@ -140,6 +179,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" | ||||||
| @@ -150,7 +191,11 @@ platform_do_upgrade() { | |||||||
| 		if [ "$(find_mtd_chardev rootfs)" ]; then | 		if [ "$(find_mtd_chardev rootfs)" ]; then | ||||||
| 			CI_UBIPART="rootfs" | 			CI_UBIPART="rootfs" | ||||||
| 		else | 		else | ||||||
| 			if grep -q rootfs1 /proc/cmdline; then | 			if [ -e /tmp/downgrade ]; then | ||||||
|  | 				CI_UBIPART="rootfs1" | ||||||
|  | 				fw_setenv active 1 || exit 1 | ||||||
|  | 				fw_setenv upgrade_available 0 || exit 1 | ||||||
|  | 			elif grep -q rootfs1 /proc/cmdline; then | ||||||
| 				CI_UBIPART="rootfs2" | 				CI_UBIPART="rootfs2" | ||||||
| 				fw_setenv active 2 || exit 1 | 				fw_setenv active 2 || exit 1 | ||||||
| 			else | 			else | ||||||
| @@ -160,5 +205,10 @@ platform_do_upgrade() { | |||||||
| 		fi | 		fi | ||||||
| 		nand_upgrade_tar "$1" | 		nand_upgrade_tar "$1" | ||||||
| 		;; | 		;; | ||||||
|  | 	plasmacloud,pax1800-v1|\ | ||||||
|  | 	plasmacloud,pax1800-v2) | ||||||
|  | 		PART_NAME="inactive" | ||||||
|  | 		platform_do_upgrade_dualboot_datachk "$1" | ||||||
|  | 		;; | ||||||
| 	esac | 	esac | ||||||
| } | } | ||||||
|   | |||||||
| @@ -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-cig-wf660a.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.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,2 @@ | |||||||
|  | #include "../../../arm64/boot/dts/qcom/qcom-ipq6018-meshpp-s618-cp01.dts" | ||||||
|  | #include "qcom-ipq6018.dtsi" | ||||||
| @@ -0,0 +1,2 @@ | |||||||
|  | #include "../../../arm64/boot/dts/qcom/qcom-ipq6018-meshpp-s618-cp03.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-pax1800-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-pax1800-v2.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,590 @@ | |||||||
|  | /* | ||||||
|  |  * 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 <dt-bindings/input/input.h> | ||||||
|  | #include <dt-bindings/gpio/gpio.h> | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	#address-cells = <0x2>; | ||||||
|  | 	#size-cells = <0x2>; | ||||||
|  | 	compatible = "cig,wf660a", "qcom,ipq6018-cp01", "qcom,ipq6018"; | ||||||
|  | 	interrupt-parent = <&intc>; | ||||||
|  | 	qcom,msm-id = <0x192 0x0>, <0x193 0x0>; | ||||||
|  |  | ||||||
|  | 	aliases { | ||||||
|  | 		serial0 = &blsp1_uart3; | ||||||
|  | 		serial1 = &blsp1_uart2; | ||||||
|  | 		sdhc1 = &sdhc_1; | ||||||
|  | 		/* | ||||||
|  | 		 * 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"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	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 | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &tlmm { | ||||||
|  | 	pinctrl-0 = <&sd_ldo_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 	uart_pins: uart_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio44", "gpio45"; | ||||||
|  | 			function = "blsp2_uart"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	sd_ldo_pins: sd_ldo_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio66"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-disable; | ||||||
|  | 			output-low; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	spi_0_pins: spi_0_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio38", "gpio39", "gpio40", "gpio41"; | ||||||
|  | 			function = "blsp0_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	spi_1_pins: spi_1_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio69", "gpio71", "gpio72"; | ||||||
|  | 			function = "blsp1_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		spi_cs { | ||||||
|  | 			pins = "gpio70"; | ||||||
|  | 			function = "blsp1_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 		quartz_interrupt { | ||||||
|  | 			pins = "gpio78"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			input; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 		quartz_reset { | ||||||
|  | 			pins = "gpio79"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			output-low; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	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; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	sd_pins: sd_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio62"; | ||||||
|  | 			function = "sd_card"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	extcon_usb_pins: extcon_usb_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio26"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	button_pins: button_pins { | ||||||
|  | 		wps_button { | ||||||
|  | 			pins = "gpio9"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 		reset_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; | ||||||
|  | 		}; | ||||||
|  | 		mux_3 { | ||||||
|  | 			pins = "gpio77"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds_pins: leds_pins { | ||||||
|  | 		led_5g { | ||||||
|  | 			pins = "gpio35"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		led_2g { | ||||||
|  | 			pins = "gpio37"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		led_usb0 { | ||||||
|  | 			pins = "gpio50"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	hsuart_pins: hsuart_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio71", "gpio72"; | ||||||
|  | 			function = "blsp1_uart"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	btcoex_pins: btcoex_pins { | ||||||
|  | 		mux_0 { | ||||||
|  | 			pins = "gpio51"; | ||||||
|  | 			function = "pta1_1"; | ||||||
|  | 			drive-strength = <6>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		mux_1 { | ||||||
|  | 			pins = "gpio53"; | ||||||
|  | 			function = "pta1_0"; | ||||||
|  | 			drive-strength = <6>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		mux_2 { | ||||||
|  | 			pins = "gpio52"; | ||||||
|  | 			function = "pta1_2"; | ||||||
|  | 			drive-strength = <6>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | 	pwm_pins: pwm_pinmux { | ||||||
|  |         mux_1 { | ||||||
|  |                 pins = "gpio22"; | ||||||
|  |                 function = "pwm02"; | ||||||
|  |                 drive-strength = <8>; | ||||||
|  |         }; | ||||||
|  | 		mux_2 { | ||||||
|  | 			pins = "gpio23"; | ||||||
|  |             function = "pwm12"; | ||||||
|  |             drive-strength = <8>; | ||||||
|  | 		}; | ||||||
|  | 		mux_3 { | ||||||
|  | 			pins = "gpio24"; | ||||||
|  |             function = "pwm22"; | ||||||
|  |             drive-strength = <8>; | ||||||
|  | 		}; | ||||||
|  | 		 | ||||||
|  |         }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &soc { | ||||||
|  | 	pwm { | ||||||
|  |                 pinctrl-0 = <&pwm_pins>; | ||||||
|  |                 pinctrl-names = "default"; | ||||||
|  |                 used-pwm-indices = <1>, <1>, <1>, <0>; | ||||||
|  |                 status = "ok"; | ||||||
|  |         }; | ||||||
|  | 	extcon_usb: extcon_usb { | ||||||
|  | 		pinctrl-0 = <&extcon_usb_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		id-gpio = <&tlmm 26 GPIO_ACTIVE_LOW>; | ||||||
|  | 		status = "ok"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	mdio: mdio@90000 { | ||||||
|  | 		pinctrl-0 = <&mdio_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		phy-reset-gpio = <&tlmm 75 0 &tlmm 77 1>; | ||||||
|  | 		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 = <0x1c>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	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 = <28>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	nss-macsec0 { | ||||||
|  | 		compatible = "qcom,nss-macsec"; | ||||||
|  | 		phy_addr = <0x1c>; | ||||||
|  | 		phy_access_mode = <0>; | ||||||
|  | 		mdiobus = <&mdio>; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	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 = <0xf>; /* mac mode for uniphy instance1*/ | ||||||
|  | 		switch_mac_mode2 = <0xff>; /* mac mode for uniphy instance2*/ | ||||||
|  | 		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>; | ||||||
|  | 			}; | ||||||
|  | 			port@4 { | ||||||
|  | 				port_id = <5>; | ||||||
|  | 				phy_address = <0x1c>; | ||||||
|  | 				port_mac_sel = "QGMAC_PORT"; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	gpio_keys { | ||||||
|  | 		compatible = "gpio-keys"; | ||||||
|  | 		pinctrl-0 = <&button_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		wps { | ||||||
|  | 			label = "wps"; | ||||||
|  | 			linux,code = <KEY_WPS_BUTTON>; | ||||||
|  | 			gpios = <&tlmm 9 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 		reset { | ||||||
|  | 			label = "reset"; | ||||||
|  | 			linux,code = <KEY_POWER>; | ||||||
|  | 			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@35 { | ||||||
|  | 			label = "led_5g"; | ||||||
|  | 			gpios = <&tlmm 35 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "led_5g"; | ||||||
|  | 			default-state = "off"; | ||||||
|  | 		}; | ||||||
|  | 		led@37 { | ||||||
|  | 			label = "led_2g"; | ||||||
|  | 			gpios = <&tlmm 37 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "led_2g"; | ||||||
|  | 			default-state = "off"; | ||||||
|  | 		}; | ||||||
|  | 		led@50 { | ||||||
|  | 			label = "led_usb0"; | ||||||
|  | 			gpios = <&tlmm 50 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "usb-host"; | ||||||
|  | 			default-state = "off"; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | i2c_4: i2c@78b9000 { | ||||||
|  | 	compatible = "qcom,i2c-qup-v2.2.1"; | ||||||
|  | 	#address-cells = <1>; | ||||||
|  | 	#size-cells = <0>; | ||||||
|  | 	reg = <0x78b9000 0x600>; | ||||||
|  | 	interrupts = <GIC_SPI 299 IRQ_TYPE_LEVEL_HIGH>; | ||||||
|  | 	clocks = <&gcc GCC_BLSP1_AHB_CLK>,<&gcc GCC_BLSP1_QUP5_I2C_APPS_CLK>; | ||||||
|  | 	clock-names = "iface", "core"; | ||||||
|  | 	clock-frequency  = <100000>; | ||||||
|  | 	dmas = <&blsp_dma 21>, <&blsp_dma 20>; | ||||||
|  | 	dma-names = "rx", "tx"; | ||||||
|  | 	status = "disabled"; | ||||||
|  | }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &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; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &blsp1_uart2 { | ||||||
|  | 	pinctrl-0 = <&hsuart_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &spi_1 { /* BLSP1 QUP1 */ | ||||||
|  | 	pinctrl-0 = <&spi_1_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	cs-select = <0>; | ||||||
|  | 	quartz-reset-gpio = <&tlmm 79 1>; | ||||||
|  | 	status = "disabled"; | ||||||
|  | 	spidev1: spi@1 { | ||||||
|  | 		compatible = "qca,spidev"; | ||||||
|  | 		reg = <0>; | ||||||
|  | 		spi-max-frequency = <24000000>; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | &qpic_bam { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nand { | ||||||
|  | 	pinctrl-0 = <&qpic_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "disable"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &ssphy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_1 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb2 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb3 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nss_crypto { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie_phy { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie0 { | ||||||
|  | #if defined(__CNSS2__) | ||||||
|  | 	status = "ok"; | ||||||
|  | #endif | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qpic_lcd { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qpic_lcd_panel { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
							
								
								
									
										120
									
								
								feeds/ipq807x/ipq807x/files/arch/arm64/boot/dts/qcom/qcom-ipq6018-cig-wf660a.dts
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										120
									
								
								feeds/ipq807x/ipq807x/files/arch/arm64/boot/dts/qcom/qcom-ipq6018-cig-wf660a.dts
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,120 @@ | |||||||
|  | /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-cig-wf660a-cp01.dtsi" | ||||||
|  | #include "qcom-ipq6018-rpm-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cpr-regulator.dtsi" | ||||||
|  | #include "qcom-ipq6018-cp-cpu.dtsi" | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "Cigtech WF-660a"; | ||||||
|  |  | ||||||
|  | 	/* | ||||||
|  | 	 * +=========+==============+========================+ | ||||||
|  | 	 * |        |              |                         | | ||||||
|  | 	 * | 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_0_pins: i2c_0_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio69", "gpio70"; | ||||||
|  | 			function = "blsp1_i2c"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | 	i2c_1_pins: i2c_1_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio42", "gpio43"; | ||||||
|  | 			function = "blsp2_i2c"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | 	i2c_4_pins: i2c_4_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio55", "gpio56"; | ||||||
|  | 			function = "blsp4_i2c"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	};	 | ||||||
|  | 	 | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &i2c_0 { | ||||||
|  | 	pinctrl-0 = <&i2c_0_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | &i2c_1 { | ||||||
|  | 	pinctrl-0 = <&i2c_1_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &i2c_4 { | ||||||
|  | 	pinctrl-0 = <&i2c_4_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &sdhc_1 { | ||||||
|  | 	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 | ||||||
| @@ -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,23 @@ | |||||||
|  | /dts-v1/; | ||||||
|  | /* | ||||||
|  |  * Copyright (c) 2022, 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-meshpp-s618.dtsi" | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "MeshPlusPlus, Inc. S618 CP01"; | ||||||
|  | 	compatible = "meshpp,s618-cp01", "qcom,ipq6018-cp01", "qcom,ipq6018"; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | /dts-v1/; | ||||||
|  | /* | ||||||
|  |  * Copyright (c) 2022, 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-meshpp-s618.dtsi" | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "MeshPlusPlus, Inc. S618 CP01"; | ||||||
|  | 	compatible = "meshpp,s618-cp03", "qcom,ipq6018-cp03", "qcom,ipq6018"; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,789 @@ | |||||||
|  | /* | ||||||
|  |  * Copyright (c) 2022, 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 <dt-bindings/input/input.h> | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	#address-cells = <0x2>; | ||||||
|  | 	#size-cells = <0x2>; | ||||||
|  | 	interrupt-parent = <&intc>; | ||||||
|  | 	qcom,msm-id = <0x1A5 0x0>; | ||||||
|  |  | ||||||
|  | 	aliases { | ||||||
|  | 		ethernet0 = "/soc/dp1"; | ||||||
|  | 		ethernet1 = "/soc/dp2"; | ||||||
|  | 		ethernet2 = "/soc/dp3"; | ||||||
|  | 		ethernet3 = "/soc/dp4"; | ||||||
|  | 		ethernet4 = "/soc/dp5"; | ||||||
|  |  | ||||||
|  | 		led-boot = &led_green; | ||||||
|  | 		led-running = &led_blue; | ||||||
|  | 		led-upgrade = &led_red; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	chosen { | ||||||
|  | 		bootargs = "console=ttyMSM0,115200,n8 rw init=/init"; | ||||||
|  |  | ||||||
|  | #ifdef __IPQ_MEM_PROFILE_256_MB__ | ||||||
|  |                 bootargs-append = " console=ttyMSM0,115200n8 panic=10 ubi.mtd=nand root=mtd:ubi_rootfs rootfstype=squashfs swiotlb=1 rootwait"; | ||||||
|  | #else | ||||||
|  |                 bootargs-append = " console=ttyMSM0,115200n8 panic=10 ubi.mtd=nand root=mtd:ubi_rootfs rootfstype=squashfs swiotlb=1 coherent_pool=2M rootwait"; | ||||||
|  | #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 */ | ||||||
|  | 	reserved-memory { | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
|  | 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x49B00000 0x0 0x00600000>; | ||||||
|  | 		}; | ||||||
|  | #endif | ||||||
|  | 		qcn9000_pcie0@50200000 { | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x50200000 0x0 0x03700000>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mhi_region0: dma_pool0@53900000 { | ||||||
|  | 			compatible = "shared-dma-pool"; | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x53900000 0x0 0x01800000>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &tlmm { | ||||||
|  | 	pinctrl-0 = <&sd_ldo_pins &generic_gpios &pcie_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 	uart_pins: uart_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio44", "gpio45"; | ||||||
|  | 			function = "blsp2_uart"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	sd_ldo_pins: sd_ldo_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio66"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-disable; | ||||||
|  | 			output-low; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	spi_0_pins: spi_0_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio38", "gpio39", "gpio40", "gpio41"; | ||||||
|  | 			function = "blsp0_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	spi_1_pins: spi_1_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio69", "gpio71", "gpio72"; | ||||||
|  | 			function = "blsp1_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		spi_cs { | ||||||
|  | 			pins = "gpio70"; | ||||||
|  | 			function = "blsp1_spi"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 		quartz_interrupt { | ||||||
|  | 			pins = "gpio78"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			input; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 		quartz_reset { | ||||||
|  | 			pins = "gpio79"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			output-low; | ||||||
|  | 			bias-disable; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	button_pins: button_pins { | ||||||
|  | 		switch_button { | ||||||
|  | 			pins = "gpio9"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 		reset_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; | ||||||
|  | 		}; | ||||||
|  | 		mux_3 { | ||||||
|  | 			pins = "gpio77"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds_pins: leds_pins { | ||||||
|  | 		led_5g { | ||||||
|  | 			pins = "gpio35"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		led_2g { | ||||||
|  | 			pins = "gpio37"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		m2_1_regulator { | ||||||
|  | 			pins = "gpio29"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		m2_1_pwr_en { | ||||||
|  | 			pins = "gpio49"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		m2_1_reset_n { | ||||||
|  | 			pins = "gpio32"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_red: red { | ||||||
|  | 			pins = "gpio50"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_green: green { | ||||||
|  | 			pins = "gpio54"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_blue: blue { | ||||||
|  | 			pins = "gpio57"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	sd_pins: sd_pins { | ||||||
|  | 		mux_1 { | ||||||
|  | 			pins = "gpio62"; | ||||||
|  | 			function = "sd_card"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-up; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mux_2 { | ||||||
|  | 			pins = "gpio23"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive_strength = <8>; | ||||||
|  | 			bias-disable; | ||||||
|  | 			output-high; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	extcon_usb_pins: extcon_usb_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio26"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <2>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	generic_gpios: generic_gpios { | ||||||
|  | 		gpio42 { | ||||||
|  | 			pins = "gpio42"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-disable; | ||||||
|  | 			output-high; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	pcie_pins: pcie_pins { | ||||||
|  | 		pcie0_enable { | ||||||
|  | 			pins = "gpio34"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-disable; | ||||||
|  | 			output-high; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  |         i2c_2_pins: i2c_2_pins { | ||||||
|  |                 mux { | ||||||
|  |                         pins = "gpio55", "gpio56"; | ||||||
|  |                         function = "gpio"; | ||||||
|  |                         drive-strength = <16>; | ||||||
|  |                         bias-pull-up; | ||||||
|  |                         input-enable; | ||||||
|  |                 }; | ||||||
|  |  | ||||||
|  |                 mux_2 { | ||||||
|  |                         pins = "gpio48"; | ||||||
|  |                         function = "gpio"; | ||||||
|  |                         drive_strength = <16>; | ||||||
|  |                         output-high; | ||||||
|  |                 }; | ||||||
|  |  | ||||||
|  |                 mux_3 { | ||||||
|  |                         pins = "gpio73"; | ||||||
|  |                         function = "gpio"; | ||||||
|  |                         drive-stength = <16>; | ||||||
|  |                         output-low; | ||||||
|  |                 }; | ||||||
|  |         }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &soc { | ||||||
|  | 	extcon_usb: extcon_usb { | ||||||
|  | 		pinctrl-0 = <&extcon_usb_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		id-gpio = <&tlmm 26 GPIO_ACTIVE_LOW>; | ||||||
|  | 		status = "ok"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	mdio0: mdio@90000 { | ||||||
|  | 		pinctrl-0 = <&mdio_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		phy-reset-gpio = <&tlmm 75 0 &tlmm 77 1>; | ||||||
|  | 		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>; | ||||||
|  |                 }; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	ess0: 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@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>; | ||||||
|  | 			}; | ||||||
|  | 			port@4 { | ||||||
|  | 				port_id = <5>; | ||||||
|  | 				phy_address = <4>; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	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@29 { | ||||||
|  | 			label = "m2_1_regulator"; | ||||||
|  | 			gpios = <&tlmm 29 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "none"; | ||||||
|  | 			default-state = "on"; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led@49 { | ||||||
|  | 			label = "m2_1_pwr_en"; | ||||||
|  | 			gpios = <&tlmm 49 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "none"; | ||||||
|  | 			default-state = "on"; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led@32 { | ||||||
|  | 			label = "m2_1_reset_n"; | ||||||
|  | 			gpios = <&tlmm 32 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,default-trigger = "none"; | ||||||
|  | 			default-state = "off"; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led@50 { | ||||||
|  | 			label = "red"; | ||||||
|  | 			gpios = <&tlmm 50 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "none"; | ||||||
|  | 			default-state = "on"; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led@54 { | ||||||
|  | 			label = "green"; | ||||||
|  | 			gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "none"; | ||||||
|  | 			default-state = "on"; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led@57 { | ||||||
|  | 			label = "blue"; | ||||||
|  | 			gpios = <&tlmm 57 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "none"; | ||||||
|  | 			default-state = "off"; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	gpio_keys { | ||||||
|  | 		compatible = "gpio-keys"; | ||||||
|  | 		pinctrl-0 = <&button_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		switch { | ||||||
|  | 			label = "switch"; | ||||||
|  | 			linux,code = <KEY_WPS_BUTTON>; | ||||||
|  | 			gpios = <&tlmm 9 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 		reset { | ||||||
|  | 			label = "reset"; | ||||||
|  | 			linux,code = <KEY_RESTART>; | ||||||
|  | 			gpios = <&tlmm 18 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	i2c_2: i2c@0 { /* i2c gpio */ | ||||||
|  | 		pinctrl-0 = <&i2c_2_pins>; | ||||||
|  | 	        pinctrl-names = "default"; | ||||||
|  | 		compatible = "i2c-gpio"; | ||||||
|  | 		gpios = <&tlmm 56 0>, <&tlmm 55 0>; | ||||||
|  | 		i2c-gpio,scl-open-drain; | ||||||
|  | 		i2c-gpio,delay-us = <7>; | ||||||
|  | 		#address-cells = <1>; | ||||||
|  | 		#size-cells = <0>; | ||||||
|  | 		status = "ok"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	wifi3: wifi3@f00000 { | ||||||
|  | 		qcom,wlan-ramdump-dynamic = <0x400000>; | ||||||
|  | 		mhi,max-channels = <30>; | ||||||
|  | 		mhi,timeout = <10000>; | ||||||
|  | 		#address-cells = <1>; | ||||||
|  | 		#size-cells = <0>; | ||||||
|  | 		qrtr_node_id = <0x20>; | ||||||
|  | 		qca,auto-restart; | ||||||
|  | #ifdef __IPQ_MEM_PROFILE_512_MB__ | ||||||
|  |  | ||||||
|  | 	      /* QCN9000 tgt-mem-mode=1 layout - 30MB | ||||||
|  | 	       * +=========+==============+=========+ | ||||||
|  | 	       * |  Region | Start Offset |   Size  | | ||||||
|  | 	       * +---------+--------------+---------+ | ||||||
|  | 	       * | BASE    |  0x4E400000  |   20MB  | | ||||||
|  | 	       * +---------+--------------+---------+ | ||||||
|  | 	       * | M3 Dump |  0x4F800000  |   1MB   | | ||||||
|  | 	       * +---------+--------------+---------+ | ||||||
|  | 	       * |  Caldb  |  0x4FA00000  |   8MB   | | ||||||
|  | 	       * +==================================+ | ||||||
|  | 	       */ | ||||||
|  |  | ||||||
|  | 		base-addr = <0x4E400000>; | ||||||
|  | 		m3-dump-addr = <0x4F800000>; | ||||||
|  | 		qcom,caldb-addr = <0x4FA00000>; | ||||||
|  | #else | ||||||
|  |  | ||||||
|  | 	      /* QCN9000 tgt-mem-mode=0 layout - 55MB | ||||||
|  | 	       * +=========+==============+=========+ | ||||||
|  | 	       * |  Region | Start Offset |   Size  | | ||||||
|  | 	       * +---------+--------------+---------+ | ||||||
|  | 	       * | BASE    |  0x50200000  |   45MB  | | ||||||
|  | 	       * +---------+--------------+---------+ | ||||||
|  | 	       * | M3 Dump |  0x52F00000  |   1MB   | | ||||||
|  | 	       * +---------+--------------+---------+ | ||||||
|  | 	       * |  Caldb  |  0x53100000  |   8MB   | | ||||||
|  | 	       * +==================================+ | ||||||
|  | 	       */ | ||||||
|  |  | ||||||
|  | 		base-addr = <0x50200000>; | ||||||
|  | 		m3-dump-addr = <0x52F00000>; | ||||||
|  | 		qcom,caldb-addr = <0x53100000>; | ||||||
|  | #endif | ||||||
|  | 		status = "ok"; | ||||||
|  |  | ||||||
|  | 		mhi_channels { | ||||||
|  | 			mhi_chan@0 { | ||||||
|  | 				reg = <0>; | ||||||
|  | 				label = "LOOPBACK"; | ||||||
|  | 				mhi,num-elements = <32>; | ||||||
|  | 				mhi,event-ring = <1>; | ||||||
|  | 				mhi,chan-dir = <1>; | ||||||
|  | 				mhi,data-type = <0>; | ||||||
|  | 				mhi,doorbell-mode = <2>; | ||||||
|  | 				mhi,ee = <0x14>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			mhi_chan@1 { | ||||||
|  | 				reg = <1>; | ||||||
|  | 				label = "LOOPBACK"; | ||||||
|  | 				mhi,num-elements = <32>; | ||||||
|  | 				mhi,event-ring = <1>; | ||||||
|  | 				mhi,chan-dir = <2>; | ||||||
|  | 				mhi,data-type = <0>; | ||||||
|  | 				mhi,doorbell-mode = <2>; | ||||||
|  | 				mhi,ee = <0x14>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			mhi_chan@4 { | ||||||
|  | 				reg = <4>; | ||||||
|  | 				label = "DIAG"; | ||||||
|  | 				mhi,num-elements = <32>; | ||||||
|  | 				mhi,event-ring = <1>; | ||||||
|  | 				mhi,chan-dir = <1>; | ||||||
|  | 				mhi,data-type = <0>; | ||||||
|  | 				mhi,doorbell-mode = <2>; | ||||||
|  | 				mhi,ee = <0x14>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			mhi_chan@5 { | ||||||
|  | 				reg = <5>; | ||||||
|  | 				label = "DIAG"; | ||||||
|  | 				mhi,num-elements = <32>; | ||||||
|  | 				mhi,event-ring = <1>; | ||||||
|  | 				mhi,chan-dir = <2>; | ||||||
|  | 				mhi,data-type = <0>; | ||||||
|  | 				mhi,doorbell-mode = <2>; | ||||||
|  | 				mhi,ee = <0x14>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			mhi_chan@20 { | ||||||
|  | 				reg = <20>; | ||||||
|  | 				label = "IPCR"; | ||||||
|  | 				mhi,num-elements = <32>; | ||||||
|  | 				mhi,event-ring = <1>; | ||||||
|  | 				mhi,chan-dir = <1>; | ||||||
|  | 				mhi,data-type = <1>; | ||||||
|  | 				mhi,doorbell-mode = <2>; | ||||||
|  | 				mhi,ee = <0x14>; | ||||||
|  | 				mhi,auto-start; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			mhi_chan@21 { | ||||||
|  | 				reg = <21>; | ||||||
|  | 				label = "IPCR"; | ||||||
|  | 				mhi,num-elements = <32>; | ||||||
|  | 				mhi,event-ring = <1>; | ||||||
|  | 				mhi,chan-dir = <2>; | ||||||
|  | 				mhi,data-type = <0>; | ||||||
|  | 				mhi,doorbell-mode = <2>; | ||||||
|  | 				mhi,ee = <0x14>; | ||||||
|  | 				mhi,auto-queue; | ||||||
|  | 				mhi,auto-start; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mhi_events { | ||||||
|  | 			mhi_event@0 { | ||||||
|  | 				mhi,num-elements = <32>; | ||||||
|  | 				mhi,intmod = <1>; | ||||||
|  | 				mhi,msi = <1>; | ||||||
|  | 				mhi,priority = <1>; | ||||||
|  | 				mhi,brstmode = <2>; | ||||||
|  | 				mhi,data-type = <1>; | ||||||
|  | 			}; | ||||||
|  |  | ||||||
|  | 			mhi_event@1 { | ||||||
|  | 				mhi,num-elements = <256>; | ||||||
|  | 				mhi,intmod = <1>; | ||||||
|  | 				mhi,msi = <2>; | ||||||
|  | 				mhi,priority = <1>; | ||||||
|  | 				mhi,brstmode = <2>; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mhi_devices { | ||||||
|  | 			mhi_qrtr { | ||||||
|  | 				mhi,chan = "IPCR"; | ||||||
|  | 				qcom,net-id = <0>; | ||||||
|  | 			}; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &blsp1_uart3 { | ||||||
|  | 	pinctrl-0 = <&uart_pins>; | ||||||
|  | 	pinctrl-names = "default"; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qpic_bam { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &ssphy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &qusb_phy_1 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb2 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &usb3 { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &nss_crypto { | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &CPU0 { | ||||||
|  | 	operating-points = < | ||||||
|  | 		/* kHz   uV (fixed) */ | ||||||
|  | 		864000   1100000 | ||||||
|  | 		1056000  1100000 | ||||||
|  | 		1200000  1100000 | ||||||
|  | 		1608000  1100000 | ||||||
|  | 	>; | ||||||
|  | 	clock-latency = <200000>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &CPU1 { | ||||||
|  | 	operating-points = < | ||||||
|  | 		/* kHz   uV (fixed) */ | ||||||
|  | 		864000   1100000 | ||||||
|  | 		1056000  1100000 | ||||||
|  | 		1200000  1100000 | ||||||
|  | 		1608000  1100000 | ||||||
|  | 	>; | ||||||
|  | 	clock-latency = <200000>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &CPU2 { | ||||||
|  | 	operating-points = < | ||||||
|  | 		/* kHz   uV (fixed) */ | ||||||
|  | 		864000   1100000 | ||||||
|  | 		1056000  1100000 | ||||||
|  | 		1200000  1100000 | ||||||
|  | 		1608000  1100000 | ||||||
|  | 	>; | ||||||
|  | 	clock-latency = <200000>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &CPU3 { | ||||||
|  | 	operating-points = < | ||||||
|  | 		/* kHz   uV (fixed) */ | ||||||
|  | 		864000   1100000 | ||||||
|  | 		1056000  1100000 | ||||||
|  | 		1200000  1100000 | ||||||
|  | 		1608000  1100000 | ||||||
|  | 	>; | ||||||
|  | 	clock-latency = <200000>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &wifi0 { | ||||||
|  |         qcom,board_id = <0x10>; | ||||||
|  |         status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie0 { | ||||||
|  | 	status = "ok"; | ||||||
|  |  | ||||||
|  | 	pcie0_rp { | ||||||
|  | 		reg = <0 0 0 0 0>; | ||||||
|  | 		status = "ok"; | ||||||
|  |  | ||||||
|  | 		mhi_0: qcom,mhi@0 { | ||||||
|  | 			reg = <0 0 0 0 0 >; | ||||||
|  | 			qrtr_instance_id = <0x20>; | ||||||
|  | 			qcom,board_id = <0xa4>; | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) | ||||||
|  | 			memory-region = <&mhi_region0>; | ||||||
|  | #endif | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie_phy { | ||||||
|  |         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; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | /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-pax1800.dtsi" | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "Plasma Cloud PAX1800 v1"; | ||||||
|  | 	compatible = "plasmacloud,pax1800-v1", "qcom,ipq6018-cp03", "qcom,ipq6018"; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | /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-pax1800.dtsi" | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	model = "Plasma Cloud PAX1800 v2"; | ||||||
|  | 	compatible = "plasmacloud,pax1800-v2", "qcom,ipq6018-cp03", "qcom,ipq6018"; | ||||||
|  | }; | ||||||
| @@ -0,0 +1,315 @@ | |||||||
|  | /* | ||||||
|  |  * 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> | ||||||
|  |  | ||||||
|  | / { | ||||||
|  | 	#address-cells = <0x2>; | ||||||
|  | 	#size-cells = <0x2>; | ||||||
|  |  | ||||||
|  | 	interrupt-parent = <&intc>; | ||||||
|  | 	qcom,msm-id = <0x1A5 0x0>; | ||||||
|  |  | ||||||
|  | 	chosen { | ||||||
|  | 		bootargs = "console=ttyMSM0,115200,n8 rw init=/init"; | ||||||
|  | 		bootargs-append = " swiotlb=1 coherent_pool=2M"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	aliases { | ||||||
|  | 		serial0 = &blsp1_uart3; | ||||||
|  | 		/* | ||||||
|  | 		 * Aliases as required by u-boot | ||||||
|  | 		 * to patch MAC addresses | ||||||
|  | 		 */ | ||||||
|  | 		ethernet0 = "/soc/dp1"; | ||||||
|  | 		ethernet1 = "/soc/dp2"; | ||||||
|  |  | ||||||
|  | 		led-boot = &led_status_green; | ||||||
|  | 		led-failsafe = &led_status_green; | ||||||
|  | 		led-running = &led_status_green; | ||||||
|  | 		led-upgrade = &led_status_green; | ||||||
|  | 		led-uplink = &led_status_blue; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	gpio_keys { | ||||||
|  | 		compatible = "gpio-keys"; | ||||||
|  | 		pinctrl-0 = <&button_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		reset { | ||||||
|  | 			label = "reset"; | ||||||
|  | 			linux,code = <KEY_RESTART>; | ||||||
|  | 			gpios = <&tlmm 24 GPIO_ACTIVE_LOW>; | ||||||
|  | 			linux,input-type = <1>; | ||||||
|  | 			debounce-interval = <60>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds { | ||||||
|  | 		compatible = "gpio-leds"; | ||||||
|  | 		pinctrl-0 = <&leds_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
|  | 		status_red { | ||||||
|  | 			label = "red:status"; | ||||||
|  | 			gpios = <&tlmm 25 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "default-off"; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_status_green: status_green { | ||||||
|  | 			label = "green:status"; | ||||||
|  | 			gpios = <&tlmm 35 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		led_status_blue: status_blue { | ||||||
|  | 			label = "blue:status"; | ||||||
|  | 			gpios = <&tlmm 37 GPIO_ACTIVE_HIGH>; | ||||||
|  | 			linux,default-trigger = "default-off"; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	watchdog { | ||||||
|  | 		compatible = "linux,wdt-gpio"; | ||||||
|  | 		pinctrl-0 = <&watchdog_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		gpios = <&tlmm 67 GPIO_ACTIVE_LOW>; | ||||||
|  | 		hw_algo = "toggle"; | ||||||
|  | 		hw_margin_ms = <2000>; | ||||||
|  | 		always-running; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	/* | ||||||
|  | 	 * +=========+==============+========================+ | ||||||
|  | 	 * |        |              |                         | | ||||||
|  | 	 * | 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; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	button_pins: button_pins { | ||||||
|  | 		reset_button { | ||||||
|  | 			pins = "gpio24"; | ||||||
|  | 			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; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	leds_pins: led_pinmux { | ||||||
|  | 		led_power_green { | ||||||
|  | 			pins = "gpio25"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		led_power_blue { | ||||||
|  | 			pins = "gpio35"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 		led_power_red { | ||||||
|  | 			pins = "gpio37"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	watchdog_pins: watchdog_pinmux { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio67"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			bias-none; | ||||||
|  | 			output-low; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &soc { | ||||||
|  | 	mdio@90000 { | ||||||
|  | 		pinctrl-0 = <&mdio_pins>; | ||||||
|  | 		pinctrl-names = "default"; | ||||||
|  | 		phy-reset-gpio = <&tlmm 75 0>; | ||||||
|  | 		status = "ok"; | ||||||
|  | 		phy0: ethernet-phy@0 { | ||||||
|  | 			reg = <3>; | ||||||
|  | 		}; | ||||||
|  | 		phy1: ethernet-phy@1 { | ||||||
|  | 			reg = <4>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	ess-switch@3a000000 { | ||||||
|  | 		switch_cpu_bmp = <0x1>;  /* cpu port bitmap */ | ||||||
|  | 		switch_lan_bmp = <0x08>; /* lan port bitmap */ | ||||||
|  | 		switch_wan_bmp = <0x10>; /* 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 = <3>; | ||||||
|  | 		reg = <0x3a001400 0x200>; | ||||||
|  | 		qcom,mactype = <0>; | ||||||
|  | 		local-mac-address = [000000000000]; | ||||||
|  | 		qcom,link-poll = <1>; | ||||||
|  | 		qcom,phy-mdio-addr = <4>; | ||||||
|  | 		phy-mode = "sgmii"; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	dp2 { | ||||||
|  | 		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"; | ||||||
|  | 	}; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &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"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &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 | ||||||
|  |  | ||||||
|  | &wifi0 { | ||||||
|  | 	status = "okay"; | ||||||
|  | 	qcom,ath11k-calibration-variant = "PlasmaCloud-PAX1800"; | ||||||
|  | }; | ||||||
| @@ -82,14 +82,24 @@ | |||||||
| 	 */ | 	 */ | ||||||
|  |  | ||||||
| /* TZAPP is enabled only in default memory profile */ | /* TZAPP is enabled only in default memory profile */ | ||||||
| #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) |  | ||||||
| 	reserved-memory { | 	reserved-memory { | ||||||
|  | #if !defined(__IPQ_MEM_PROFILE_256_MB__) && !defined(__IPQ_MEM_PROFILE_512_MB__) | ||||||
| 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | ||||||
| 			no-map; | 			no-map; | ||||||
| 			reg = <0x0 0x49B00000 0x0 0x00600000>; | 			reg = <0x0 0x49B00000 0x0 0x00600000>; | ||||||
| 		}; | 		}; | ||||||
| 	}; |  | ||||||
| #endif | #endif | ||||||
|  | 		qcn9000_pcie0@50200000 { | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x50200000 0x0 0x02D00000>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		mhi_region0: dma_pool0@52f00000 { | ||||||
|  | 			compatible = "shared-dma-pool"; | ||||||
|  | 			no-map; | ||||||
|  | 			reg = <0x0 0x52F00000 0x0 0x01800000>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| &tlmm { | &tlmm { | ||||||
| @@ -490,3 +500,49 @@ | |||||||
| 	//vqmmc-supply = <&ipq6018_l2_corner>; | 	//vqmmc-supply = <&ipq6018_l2_corner>; | ||||||
| 	status = "ok"; | 	status = "ok"; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | &wifi1 { | ||||||
|  | 	base-addr = <0x50200000>; | ||||||
|  | 	m3-dump-addr = <0x52500000>; | ||||||
|  | 	etr-addr = <0x52600000>; | ||||||
|  | 	caldb-addr = <0x52700000>; | ||||||
|  | 	hremote-size = <0x2300000>; | ||||||
|  | 	tgt-mem-mode = <0x0>; | ||||||
|  | 	board_id = <0xa4>; | ||||||
|  | 	caldb-size = <0x800000>; | ||||||
|  | 	status = "ok"; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie0 { | ||||||
|  | 	status = "ok"; | ||||||
|  | 	interrupts = <0 52 0>, <0 416 0>, <0 417 0>, | ||||||
|  |                      <0 418 0>, <0 419 0>, <0 420 0>, | ||||||
|  |                      <0 421 0>, <0 422 0>, <0 423 0>, | ||||||
|  |                      <0 424 0>, <0 425 0>, <0 426 0>, | ||||||
|  |                      <0 427 0>, <0 428 0>, <0 429 0>, | ||||||
|  |                      <0 430 0>, <0 431 0>; | ||||||
|  |  | ||||||
|  |         interrupt-names = "msi", "msi_0", "msi_1", | ||||||
|  |                           "msi_2", "msi_3", "msi_4", | ||||||
|  |                           "msi_5", "msi_6", "msi_7", | ||||||
|  |                           "msi_8", "msi_9", "msi_10", | ||||||
|  |                           "msi_11", "msi_12", "msi_13", | ||||||
|  |                           "msi_14", "msi_15"; | ||||||
|  |  | ||||||
|  |         qcom,msi-gicm-addr = <0x0B00A040>; | ||||||
|  |         qcom,msi-gicm-base = <0x1c0>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie0_rp { | ||||||
|  |         status = "ok"; | ||||||
|  |  | ||||||
|  |         mhi_0: qcom,mhi@0 { | ||||||
|  |                 reg = <0 0 0 0 0 >; | ||||||
|  |                 qrtr_instance_id = <0x20>; | ||||||
|  |                 memory-region = <&mhi_region0>; | ||||||
|  |         }; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | &pcie_phy { | ||||||
|  |         status = "ok"; | ||||||
|  | }; | ||||||
|   | |||||||
| @@ -35,12 +35,15 @@ | |||||||
| 		bootargs-append = " swiotlb=1 coherent_pool=2M"; | 		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 { | 	reserved-memory { | ||||||
| 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | 		tzapp:tzapp@49B00000 {	/* TZAPPS */ | ||||||
| 			no-map; | 			no-map; | ||||||
| 			reg = <0x0 0x49B00000 0x0 0x00600000>; | 			reg = <0x0 0x49B00000 0x0 0x00600000>; | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
|  | #endif | ||||||
| }; | }; | ||||||
|  |  | ||||||
| &tlmm { | &tlmm { | ||||||
| @@ -159,6 +162,16 @@ | |||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	modem_power_pins { | ||||||
|  | 		mux { | ||||||
|  | 			pins = "gpio27"; | ||||||
|  | 			function = "gpio"; | ||||||
|  | 			drive-strength = <8>; | ||||||
|  | 			bias-pull-down; | ||||||
|  | 			output-high; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	leds_pins: leds_pins { | 	leds_pins: leds_pins { | ||||||
| 		led_blue { | 		led_blue { | ||||||
| 			pins = "gpio35"; | 			pins = "gpio35"; | ||||||
| @@ -223,18 +236,6 @@ | |||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	dp1 { | 	dp1 { | ||||||
| 		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"; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	dp2 { |  | ||||||
| 		device_type = "network"; | 		device_type = "network"; | ||||||
| 		compatible = "qcom,nss-dp"; | 		compatible = "qcom,nss-dp"; | ||||||
| 		qcom,id = <0x04>; | 		qcom,id = <0x04>; | ||||||
| @@ -246,6 +247,18 @@ | |||||||
| 		phy-mode = "sgmii"; | 		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 { | 	gpio_keys { | ||||||
| 		compatible = "gpio-keys"; | 		compatible = "gpio-keys"; | ||||||
|  |  | ||||||
| @@ -268,17 +281,17 @@ | |||||||
| 		pinctrl-names = "default"; | 		pinctrl-names = "default"; | ||||||
|  |  | ||||||
| 		led_system: system { | 		led_system: system { | ||||||
| 			label = "ax860:green:system"; | 			label = "green:system"; | ||||||
| 			gpio = <&tlmm 37 GPIO_ACTIVE_HIGH>; | 			gpio = <&tlmm 37 GPIO_ACTIVE_HIGH>; | ||||||
| 		}; | 		}; | ||||||
|  |  | ||||||
| 		wlan2g { | 		wlan2g { | ||||||
| 			label = "ax860:blue:wlan2g"; | 			label = "blue:wlan2g"; | ||||||
| 			gpio = <&tlmm 35 GPIO_ACTIVE_HIGH>; | 			gpio = <&tlmm 35 GPIO_ACTIVE_HIGH>; | ||||||
| 		}; | 		}; | ||||||
|  |  | ||||||
| 		wlan5g { | 		wlan5g { | ||||||
| 			label = "ax860:red:wlan5g"; | 			label = "red:wlan5g"; | ||||||
| 			gpio = <&tlmm 32 GPIO_ACTIVE_HIGH>; | 			gpio = <&tlmm 32 GPIO_ACTIVE_HIGH>; | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
| @@ -336,8 +349,31 @@ | |||||||
| 	/delete-node/ opp06; | 	/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 { | &qseecom { | ||||||
| 	mem-start = <0x49B00000>; | 	mem-start = <0x49B00000>; | ||||||
| 	mem-size = <0x600000>; | 	mem-size = <0x600000>; | ||||||
| 	status = "ok"; | 	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 = "Yuncore FAP650"; | ||||||
|  | 	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/dp5"; | ||||||
|  | 		ethernet1 = "/soc/dp4"; | ||||||
|  | 		ethernet2 = "/soc/dp3"; | ||||||
|  | 		ethernet3 = "/soc/dp2"; | ||||||
|  | 		ethernet4 = "/soc/dp1"; | ||||||
|  |  | ||||||
|  | 		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,78 @@ | |||||||
| 			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 = <0>; | ||||||
|  | 			gpios = <&tlmm 54 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		usb-hub-enable { | ||||||
|  | 			gpio-export,name = "usb-hub-enable"; | ||||||
|  | 			gpio-export,output = <1>; | ||||||
|  | 			gpios = <&tlmm 55 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		usb-rear-power { | ||||||
|  | 			gpio-export,name = "usb-rear-power"; | ||||||
|  | 			gpio-export,output = <1>; | ||||||
|  | 			gpios = <&tlmm 29 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  |  | ||||||
|  | 		usb-side-power { | ||||||
|  | 			gpio-export,name = "usb-side-power"; | ||||||
|  | 			gpio-export,output = <1>; | ||||||
|  | 			gpios = <&tlmm 30 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| &tlmm { | &tlmm { | ||||||
| 	pinctrl-0 = <&btcoex_pins>; | 	pinctrl-0 = <&mcu_rst &mcu_rsv &usb_rear_pwr &usb_side_pwr &usb_hub_rst>; | ||||||
| 	pinctrl-names = "default"; | 	pinctrl-names = "default"; | ||||||
|  |  | ||||||
| 	btcoex_pins: btcoex_pins { | 	mcu_rst: mcu_rst_pins { | ||||||
| 		mux_0 { | 		pins = "gpio54"; | ||||||
| 			pins = "gpio64"; | 		function = "gpio"; | ||||||
| 			function = "pta1_1"; | 		drive-strength = <8>; | ||||||
| 			drive-strength = <6>; | 		bias-disable; | ||||||
| 			bias-pull-down; | 		output-low; | ||||||
| 	}; | 	}; | ||||||
| 		mux_1 { |  | ||||||
| 			pins = "gpio65"; | 	mcu_rsv: mcu_rsv_pins { | ||||||
| 			function = "pta1_2"; | 		pins = "gpio56"; | ||||||
| 			drive-strength = <6>; | 		function = "gpio"; | ||||||
| 			bias-pull-down; | 		drive-strength = <8>; | ||||||
|  | 		bias-disable; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	usb_rear_pwr: usb_rear_pwr_pins { | ||||||
|  | 		pins = "gpio29"; | ||||||
|  | 		function = "gpio"; | ||||||
|  | 		drive-strength = <8>; | ||||||
|  | 		bias-disable; | ||||||
|  | 		output-high; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	usb_side_pwr: usb_side_pwr_pins { | ||||||
|  | 		pins = "gpio30"; | ||||||
|  | 		function = "gpio"; | ||||||
|  | 		drive-strength = <8>; | ||||||
|  | 		bias-disable; | ||||||
|  | 		output-high; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	usb_hub_rst: usb_hub_rst_pins { | ||||||
|  | 		pins = "gpio55"; | ||||||
|  | 		function = "gpio"; | ||||||
|  | 		drive-strength = <8>; | ||||||
|  | 		bias-disable; | ||||||
|  | 		output-high; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	mdio_pins: mdio_pinmux { | 	mdio_pins: mdio_pinmux { | ||||||
| @@ -172,17 +225,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 +263,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 +751,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 +824,7 @@ | |||||||
| }; | }; | ||||||
|  |  | ||||||
| &pcie0 { | &pcie0 { | ||||||
| 	status = "ok"; | 	status = "disabled"; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| &pcie1 { | &pcie1 { | ||||||
|   | |||||||
| @@ -55,6 +55,17 @@ | |||||||
| 		#endif | 		#endif | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	gpio-export { | ||||||
|  | 		compatible = "gpio-export"; | ||||||
|  | 		#size-cells = <0>; | ||||||
|  |  | ||||||
|  | 		mcu-enable { | ||||||
|  | 			gpio-export,name = "mcu-enable"; | ||||||
|  | 			gpio-export,output = <0>; | ||||||
|  | 			gpios = <&tlmm 34 GPIO_ACTIVE_HIGH>; | ||||||
|  | 		}; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	reserved-memory { | 	reserved-memory { | ||||||
| /* No Pine attach in 256M profile */ | /* No Pine attach in 256M profile */ | ||||||
| #if !defined(__IPQ_MEM_PROFILE_256_MB__) | #if !defined(__IPQ_MEM_PROFILE_256_MB__) | ||||||
| @@ -155,28 +166,15 @@ | |||||||
| }; | }; | ||||||
|  |  | ||||||
| &tlmm { | &tlmm { | ||||||
| 	pinctrl-0 = <&btcoex_pins>; | 	pinctrl-0 = <&mcu_rst>; | ||||||
| 	pinctrl-names = "default"; | 	pinctrl-names = "default"; | ||||||
|  |  | ||||||
| 	btcoex_pins: btcoex_pins { | 	mcu_rst: mcu_rst_pins { | ||||||
| 		mux_0 { | 		pins = "gpio34"; | ||||||
| 			pins = "gpio64"; | 		function = "gpio"; | ||||||
| 			function = "pta1_1"; | 		drive-strength = <8>; | ||||||
| 			drive-strength = <6>; | 		bias-disable; | ||||||
| 			bias-pull-down; | 		output-low; | ||||||
| 		}; |  | ||||||
| 		mux_1 { |  | ||||||
| 			pins = "gpio65"; |  | ||||||
| 			function = "pta1_2"; |  | ||||||
| 			drive-strength = <6>; |  | ||||||
| 			bias-pull-down; |  | ||||||
| 		}; |  | ||||||
| 		mux_2 { |  | ||||||
| 			pins = "gpio66"; |  | ||||||
| 			function = "pta1_0"; |  | ||||||
| 			drive-strength = <6>; |  | ||||||
| 			bias-pull-down; |  | ||||||
| 		}; |  | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	mdio_pins: mdio_pinmux { | 	mdio_pins: mdio_pinmux { | ||||||
| @@ -207,6 +205,7 @@ | |||||||
| 			bias-disable; | 			bias-disable; | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	i2c_5_pins: i2c_5_pinmux { | 	i2c_5_pins: i2c_5_pinmux { | ||||||
| 		mux { | 		mux { | ||||||
| 			pins = "gpio0", "gpio2"; | 			pins = "gpio0", "gpio2"; | ||||||
| @@ -225,33 +224,6 @@ | |||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	spi_3_pins: spi_3_pins { |  | ||||||
| 		mux { |  | ||||||
| 			pins = "gpio50", "gpio52", "gpio53"; |  | ||||||
| 			function = "blsp3_spi"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-disable; |  | ||||||
| 		}; |  | ||||||
| 		spi_cs { |  | ||||||
| 			pins = "gpio22"; |  | ||||||
| 			function = "blsp3_spi2"; |  | ||||||
| 			drive-strength = <8>; |  | ||||||
| 			bias-disable; |  | ||||||
| 		}; |  | ||||||
| 		quartz_interrupt { |  | ||||||
| 			pins = "gpio47"; |  | ||||||
| 			function = "gpio"; |  | ||||||
| 			input; |  | ||||||
| 			bias-disable; |  | ||||||
| 		}; |  | ||||||
| 		quartz_reset { |  | ||||||
| 			pins = "gpio21"; |  | ||||||
| 			function = "gpio"; |  | ||||||
| 			output-low; |  | ||||||
| 			bias-disable; |  | ||||||
| 		}; |  | ||||||
| 	}; |  | ||||||
|  |  | ||||||
| 	qpic_pins: qpic_pins { | 	qpic_pins: qpic_pins { | ||||||
| 		data_0 { | 		data_0 { | ||||||
| 			pins = "gpio15"; | 			pins = "gpio15"; | ||||||
| @@ -312,7 +284,7 @@ | |||||||
|  |  | ||||||
| 	hsuart_pins: hsuart_pins { | 	hsuart_pins: hsuart_pins { | ||||||
| 		mux { | 		mux { | ||||||
| 			pins = "gpio46", "gpio47", "gpio48", "gpio49"; | 			pins = "gpio48", "gpio49"; | ||||||
| 			function = "blsp2_uart"; | 			function = "blsp2_uart"; | ||||||
| 			drive-strength = <8>; | 			drive-strength = <8>; | ||||||
| 			bias-disable; | 			bias-disable; | ||||||
| @@ -320,7 +292,6 @@ | |||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	button_pins: button_pins { | 	button_pins: button_pins { | ||||||
|  |  | ||||||
| 		wps_button { | 		wps_button { | ||||||
| 			pins = "gpio67"; | 			pins = "gpio67"; | ||||||
| 			function = "gpio"; | 			function = "gpio"; | ||||||
| @@ -366,6 +337,7 @@ | |||||||
| 			bias-pull-down; | 			bias-pull-down; | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	pwm_pins: pwm_pinmux { | 	pwm_pins: pwm_pinmux { | ||||||
| 		mux_1 { | 		mux_1 { | ||||||
| 			pins = "gpio25"; | 			pins = "gpio25"; | ||||||
| @@ -383,7 +355,6 @@ | |||||||
| 			drive-strength = <8>; | 			drive-strength = <8>; | ||||||
| 		}; | 		}; | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| &soc { | &soc { | ||||||
|   | |||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -1,5 +1,18 @@ | |||||||
| KERNEL_LOADADDR := 0x41008000 | KERNEL_LOADADDR := 0x41008000 | ||||||
|  |  | ||||||
|  | DEVICE_VARS += CE_TYPE | ||||||
|  |  | ||||||
|  | define Device/cig_wf660a | ||||||
|  |   DEVICE_TITLE := Cigtech WF-660a | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-cig-wf660a | ||||||
|  |   SUPPORTED_DEVICES := cig,wf660a | ||||||
|  |   DEVICE_DTS_CONFIG := config@cp01-c1 | ||||||
|  |   DEVICE_PACKAGES := ath11k-wifi-cig-wf660a uboot-env uboot-envtools | ||||||
|  |   IMAGES := sysupgrade.tar mmc-factory.bin | ||||||
|  |   IMAGE/mmc-factory.bin := append-ubi | qsdk-ipq-factory-mmc | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += cig_wf660a | ||||||
|  |  | ||||||
| define Device/cig_wf188n | define Device/cig_wf188n | ||||||
|   DEVICE_TITLE := Cigtech WF-188n |   DEVICE_TITLE := Cigtech WF-188n | ||||||
|   DEVICE_DTS := qcom-ipq6018-cig-wf188n |   DEVICE_DTS := qcom-ipq6018-cig-wf188n | ||||||
| @@ -18,12 +31,30 @@ 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 | ||||||
|   DEVICE_DTS_CONFIG := config@cp01-c1 |   DEVICE_DTS_CONFIG := config@cp01-c1 | ||||||
|   SUPPORTED_DEVICES := hfcl,ion4xi |   SUPPORTED_DEVICES := hfcl,ion4xi | ||||||
|   DEVICE_PACKAGES := ath11k-wifi-qcom-ipq6018 uboot-envtools |   DEVICE_PACKAGES := ath11k-wifi-hfcl-ion4xi uboot-envtools | ||||||
| endef | endef | ||||||
| TARGET_DEVICES += hfcl_ion4xi | TARGET_DEVICES += hfcl_ion4xi | ||||||
|  |  | ||||||
| @@ -36,6 +67,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 | ||||||
| @@ -50,7 +108,7 @@ define Device/wallys_dr6018_v4 | |||||||
|   DEVICE_DTS := qcom-ipq6018-wallys-dr6018-v4 |   DEVICE_DTS := qcom-ipq6018-wallys-dr6018-v4 | ||||||
|   DEVICE_DTS_CONFIG := config@cp01-c4 |   DEVICE_DTS_CONFIG := config@cp01-c4 | ||||||
|   SUPPORTED_DEVICES := wallys,dr6018-v4 |   SUPPORTED_DEVICES := wallys,dr6018-v4 | ||||||
|   DEVICE_PACKAGES := ath11k-wifi-wallys-dr6018-v4 uboot-envtools |   DEVICE_PACKAGES := ath11k-wifi-wallys-dr6018-v4 uboot-envtools ath11k-firmware-qcn9000 | ||||||
| endef | endef | ||||||
| TARGET_DEVICES += wallys_dr6018_v4 | TARGET_DEVICES += wallys_dr6018_v4 | ||||||
|  |  | ||||||
| @@ -88,3 +146,63 @@ define Device/yuncore_ax840 | |||||||
|   DEVICE_PACKAGES := ath11k-wifi-yuncore-ax840 uboot-env |   DEVICE_PACKAGES := ath11k-wifi-yuncore-ax840 uboot-env | ||||||
| endef | endef | ||||||
| TARGET_DEVICES += yuncore_ax840 | TARGET_DEVICES += yuncore_ax840 | ||||||
|  |  | ||||||
|  | define Device/plasmacloud_common_64k | ||||||
|  |   DEVICE_PACKAGES := uboot-envtools | ||||||
|  |   CE_TYPE := | ||||||
|  |   BLOCKSIZE := 64k | ||||||
|  |   IMAGES := sysupgrade.tar factory.bin | ||||||
|  |   IMAGE/factory.bin := append-rootfs | pad-rootfs | openmesh-image ce_type=$$$$(CE_TYPE) | ||||||
|  |   IMAGE/sysupgrade.tar := append-rootfs | pad-rootfs | sysupgrade-tar rootfs=$$$$@ | append-metadata | ||||||
|  |   KERNEL += | pad-to $$(BLOCKSIZE) | ||||||
|  | endef | ||||||
|  |  | ||||||
|  | define Device/plasmacloud_pax1800-v1 | ||||||
|  |   $(Device/plasmacloud_common_64k) | ||||||
|  |   DEVICE_TITLE := Plasma Cloud PAX1800 v1 | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-pax1800-v1 | ||||||
|  |   SUPPORTED_DEVICES := plasmacloud,pax1800-v1 | ||||||
|  |   DEVICE_DTS_CONFIG := config@cp03-c1 | ||||||
|  |   CE_TYPE := PAX1800 | ||||||
|  |   DEVICE_PACKAGES += ath11k-wifi-plasmacloud-pax1800 | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += plasmacloud_pax1800-v1 | ||||||
|  |  | ||||||
|  | define Device/plasmacloud_pax1800-v2 | ||||||
|  |   $(Device/plasmacloud_common_64k) | ||||||
|  |   DEVICE_TITLE := Plasma Cloud PAX1800 v2 | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-pax1800-v2 | ||||||
|  |   SUPPORTED_DEVICES := plasmacloud,pax1800-v2 | ||||||
|  |   DEVICE_DTS_CONFIG := config@plasmacloud.pax1800v2 | ||||||
|  |   CE_TYPE := PAX1800v2 | ||||||
|  |   DEVICE_PACKAGES += ath11k-wifi-plasmacloud-pax1800 | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += plasmacloud_pax1800-v2 | ||||||
|  |  | ||||||
|  | define Device/meshpp_s618_cp03 | ||||||
|  |   DEVICE_TITLE := S618 cp03 | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-meshpp-s618-cp03 | ||||||
|  |   SUPPORTED_DEVICES := meshpp,s618-cp03 | ||||||
|  |   DEVICE_DTS_CONFIG := config@cp03-c1 | ||||||
|  |   DEVICE_PACKAGES := ath11k-wifi-meshpp-s618 -kmod-usb-dwc3-of-simple kmod-usb-dwc3-qcom kmod-usb3 | ||||||
|  | endef | ||||||
|  | TARGET_DEVICES += meshpp_s618_cp03 | ||||||
|  |  | ||||||
|  | define Device/meshpp_s618_cp01 | ||||||
|  |   DEVICE_TITLE := S618 cp01 | ||||||
|  |   DEVICE_DTS := qcom-ipq6018-meshpp-s618-cp01 | ||||||
|  |   SUPPORTED_DEVICES := meshpp,s618-cp01 | ||||||
|  |   DEVICE_DTS_CONFIG := config@cp01-c1 | ||||||
|  |   DEVICE_PACKAGES := ath11k-wifi-meshpp-s618 -kmod-usb-dwc3-of-simple kmod-usb-dwc3-qcom kmod-usb3 | ||||||
|  | endef | ||||||
|  | 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 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -32856,7 +32856,7 @@ | |||||||
| +
 | +
 | ||||||
| +	new_range = dst_reg->off;
 | +	new_range = dst_reg->off;
 | ||||||
| +	if (range_right_open)
 | +	if (range_right_open)
 | ||||||
| +		new_range--;
 | +		new_range++;
 | ||||||
| +
 | +
 | ||||||
| +	/* Examples for register markings:
 | +	/* Examples for register markings:
 | ||||||
| +	 *
 | +	 *
 | ||||||
|   | |||||||
| @@ -0,0 +1,30 @@ | |||||||
|  | From a0d398a7373b395a2cbdc865815560671d1e8a08 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Venkat Chimata <venkata@shasta.cloud> | ||||||
|  | Date: Fri, 12 Aug 2022 15:42:40 +0530 | ||||||
|  | Subject: [PATCH] sk_buff's cb should be cleared in the entry point for both | ||||||
|  |  incoming and outgoing packets at each layer. At bridge, it is already handled | ||||||
|  |  in the outgoing path, but not in the incoming path. We have seen cases where | ||||||
|  |  proxyarp_replied was 1 on sk_buffs coming from the WLAN driver and they were | ||||||
|  |  getting dropped in forwarding path. | ||||||
|  |  | ||||||
|  | Signed-off-by: Venkat Chimata <venkata@shasta.cloud> | ||||||
|  | --- | ||||||
|  |  net/bridge/br_input.c | 2 ++ | ||||||
|  |  1 file changed, 2 insertions(+) | ||||||
|  |  | ||||||
|  | diff --git a/net/bridge/br_input.c b/net/bridge/br_input.c | ||||||
|  | index e6b745b7..09cd5b72 100644 | ||||||
|  | --- a/net/bridge/br_input.c | ||||||
|  | +++ b/net/bridge/br_input.c | ||||||
|  | @@ -282,6 +282,8 @@ rx_handler_result_t br_handle_frame(struct sk_buff **pskb) | ||||||
|  |  	if (!skb) | ||||||
|  |  		return RX_HANDLER_CONSUMED; | ||||||
|  |   | ||||||
|  | +	memset(skb->cb, 0, sizeof(struct br_input_skb_cb)); | ||||||
|  | + | ||||||
|  |  	p = br_port_get_rcu(skb->dev); | ||||||
|  |   | ||||||
|  |  	if (unlikely(is_link_local_ether_addr(dest))) { | ||||||
|  | --  | ||||||
|  | 2.34.1 | ||||||
|  |  | ||||||
| @@ -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,72 @@ | |||||||
|  | From: Stefano Brivio <sbrivio@redhat.com> | ||||||
|  | Date: Tue, 4 Aug 2020 07:53:42 +0200 | ||||||
|  | Subject: [PATCH] ipv4: route: Ignore output interface in FIB lookup for PMTU | ||||||
|  |  route | ||||||
|  |  | ||||||
|  | Currently, processes sending traffic to a local bridge with an | ||||||
|  | encapsulation device as a port don't get ICMP errors if they exceed | ||||||
|  | the PMTU of the encapsulated link. | ||||||
|  |  | ||||||
|  | David Ahern suggested this as a hack, but it actually looks like | ||||||
|  | the correct solution: when we update the PMTU for a given destination | ||||||
|  | by means of updating or creating a route exception, the encapsulation | ||||||
|  | might trigger this because of PMTU discovery happening either on the | ||||||
|  | encapsulation device itself, or its lower layer. This happens on | ||||||
|  | bridged encapsulations only. | ||||||
|  |  | ||||||
|  | The output interface shouldn't matter, because we already have a | ||||||
|  | valid destination. Drop the output interface restriction from the | ||||||
|  | associated route lookup. | ||||||
|  |  | ||||||
|  | For UDP tunnels, we will now have a route exception created for the | ||||||
|  | encapsulation itself, with a MTU value reflecting its headroom, which | ||||||
|  | allows a bridge forwarding IP packets originated locally to deliver | ||||||
|  | errors back to the sending socket. | ||||||
|  |  | ||||||
|  | The behaviour is now consistent with IPv6 and verified with selftests | ||||||
|  | pmtu_ipv{4,6}_br_{geneve,vxlan}{4,6}_exception introduced later in | ||||||
|  | this series. | ||||||
|  |  | ||||||
|  | v2: | ||||||
|  | - reset output interface only for bridge ports (David Ahern) | ||||||
|  | - add and use netif_is_any_bridge_port() helper (David Ahern) | ||||||
|  |  | ||||||
|  | Suggested-by: David Ahern <dsahern@gmail.com> | ||||||
|  | Signed-off-by: Stefano Brivio <sbrivio@redhat.com> | ||||||
|  | Reviewed-by: David Ahern <dsahern@gmail.com> | ||||||
|  | Signed-off-by: David S. Miller <davem@davemloft.net> | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | --- a/include/linux/netdevice.h | ||||||
|  | +++ b/include/linux/netdevice.h | ||||||
|  | @@ -4015,6 +4015,16 @@ static inline bool netif_is_ovs_master(c | ||||||
|  |  	return dev->priv_flags & IFF_OPENVSWITCH; | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +static inline bool netif_is_ovs_port(const struct net_device *dev) | ||||||
|  | +{ | ||||||
|  | +	return dev->priv_flags & IFF_OVS_DATAPATH; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +static inline bool netif_is_any_bridge_port(const struct net_device *dev) | ||||||
|  | +{ | ||||||
|  | +	return netif_is_bridge_port(dev) || netif_is_ovs_port(dev); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  static inline bool netif_is_ifb_dev(const struct net_device *dev) | ||||||
|  |  { | ||||||
|  |  	return dev->priv_flags_ext & IFF_EXT_IFB; | ||||||
|  | --- a/net/ipv4/route.c | ||||||
|  | +++ b/net/ipv4/route.c | ||||||
|  | @@ -1004,6 +1004,11 @@ static void ip_rt_update_pmtu(struct dst | ||||||
|  |  	struct flowi4 fl4; | ||||||
|  |   | ||||||
|  |  	ip_rt_build_flow_key(&fl4, sk, skb); | ||||||
|  | + | ||||||
|  | +	/* Don't make lookup fail for bridged encapsulations */ | ||||||
|  | +	if (skb && netif_is_any_bridge_port(skb->dev)) | ||||||
|  | +		fl4.flowi4_oif = 0; | ||||||
|  | + | ||||||
|  |  	__ip_rt_update_pmtu(rt, &fl4, mtu); | ||||||
|  |  } | ||||||
|  |   | ||||||
| @@ -0,0 +1,57 @@ | |||||||
|  | From: Matteo Croce <mcroce@redhat.com> | ||||||
|  | Date: Sat, 2 Nov 2019 01:12:03 +0100 | ||||||
|  | Subject: [PATCH] icmp: add helpers to recognize ICMP error packets | ||||||
|  |  | ||||||
|  | Add two helper functions, one for IPv4 and one for IPv6, to recognize | ||||||
|  | the ICMP packets which are error responses. | ||||||
|  | This packets are special because they have as payload the original | ||||||
|  | header of the packet which generated it (RFC 792 says at least 8 bytes, | ||||||
|  | but Linux actually includes much more than that). | ||||||
|  |  | ||||||
|  | Signed-off-by: Matteo Croce <mcroce@redhat.com> | ||||||
|  | Signed-off-by: David S. Miller <davem@davemloft.net> | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | --- a/include/linux/icmp.h | ||||||
|  | +++ b/include/linux/icmp.h | ||||||
|  | @@ -24,4 +24,19 @@ static inline struct icmphdr *icmp_hdr(c | ||||||
|  |  { | ||||||
|  |  	return (struct icmphdr *)skb_transport_header(skb); | ||||||
|  |  } | ||||||
|  | + | ||||||
|  | +static inline bool icmp_is_err(int type) | ||||||
|  | +{ | ||||||
|  | +	switch (type) { | ||||||
|  | +	case ICMP_DEST_UNREACH: | ||||||
|  | +	case ICMP_SOURCE_QUENCH: | ||||||
|  | +	case ICMP_REDIRECT: | ||||||
|  | +	case ICMP_TIME_EXCEEDED: | ||||||
|  | +	case ICMP_PARAMETERPROB: | ||||||
|  | +		return true; | ||||||
|  | +	} | ||||||
|  | + | ||||||
|  | +	return false; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  #endif	/* _LINUX_ICMP_H */ | ||||||
|  | --- a/include/linux/icmpv6.h | ||||||
|  | +++ b/include/linux/icmpv6.h | ||||||
|  | @@ -42,4 +42,18 @@ extern void				icmpv6_flow_init(struct s | ||||||
|  |  							 const struct in6_addr *saddr, | ||||||
|  |  							 const struct in6_addr *daddr, | ||||||
|  |  							 int oif); | ||||||
|  | + | ||||||
|  | +static inline bool icmpv6_is_err(int type) | ||||||
|  | +{ | ||||||
|  | +	switch (type) { | ||||||
|  | +	case ICMPV6_DEST_UNREACH: | ||||||
|  | +	case ICMPV6_PKT_TOOBIG: | ||||||
|  | +	case ICMPV6_TIME_EXCEED: | ||||||
|  | +	case ICMPV6_PARAMPROB: | ||||||
|  | +		return true; | ||||||
|  | +	} | ||||||
|  | + | ||||||
|  | +	return false; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  #endif | ||||||
| @@ -0,0 +1,360 @@ | |||||||
|  | From: Stefano Brivio <sbrivio@redhat.com> | ||||||
|  | Date: Tue, 4 Aug 2020 07:53:43 +0200 | ||||||
|  | Subject: [PATCH] tunnels: PMTU discovery support for directly bridged IP | ||||||
|  |  packets | ||||||
|  |  | ||||||
|  | It's currently possible to bridge Ethernet tunnels carrying IP | ||||||
|  | packets directly to external interfaces without assigning them | ||||||
|  | addresses and routes on the bridged network itself: this is the case | ||||||
|  | for UDP tunnels bridged with a standard bridge or by Open vSwitch. | ||||||
|  |  | ||||||
|  | PMTU discovery is currently broken with those configurations, because | ||||||
|  | the encapsulation effectively decreases the MTU of the link, and | ||||||
|  | while we are able to account for this using PMTU discovery on the | ||||||
|  | lower layer, we don't have a way to relay ICMP or ICMPv6 messages | ||||||
|  | needed by the sender, because we don't have valid routes to it. | ||||||
|  |  | ||||||
|  | On the other hand, as a tunnel endpoint, we can't fragment packets | ||||||
|  | as a general approach: this is for instance clearly forbidden for | ||||||
|  | VXLAN by RFC 7348, section 4.3: | ||||||
|  |  | ||||||
|  |    VTEPs MUST NOT fragment VXLAN packets.  Intermediate routers may | ||||||
|  |    fragment encapsulated VXLAN packets due to the larger frame size. | ||||||
|  |    The destination VTEP MAY silently discard such VXLAN fragments. | ||||||
|  |  | ||||||
|  | The same paragraph recommends that the MTU over the physical network | ||||||
|  | accomodates for encapsulations, but this isn't a practical option for | ||||||
|  | complex topologies, especially for typical Open vSwitch use cases. | ||||||
|  |  | ||||||
|  | Further, it states that: | ||||||
|  |  | ||||||
|  |    Other techniques like Path MTU discovery (see [RFC1191] and | ||||||
|  |    [RFC1981]) MAY be used to address this requirement as well. | ||||||
|  |  | ||||||
|  | Now, PMTU discovery already works for routed interfaces, we get | ||||||
|  | route exceptions created by the encapsulation device as they receive | ||||||
|  | ICMP Fragmentation Needed and ICMPv6 Packet Too Big messages, and | ||||||
|  | we already rebuild those messages with the appropriate MTU and route | ||||||
|  | them back to the sender. | ||||||
|  |  | ||||||
|  | Add the missing bits for bridged cases: | ||||||
|  |  | ||||||
|  | - checks in skb_tunnel_check_pmtu() to understand if it's appropriate | ||||||
|  |   to trigger a reply according to RFC 1122 section 3.2.2 for ICMP and | ||||||
|  |   RFC 4443 section 2.4 for ICMPv6. This function is already called by | ||||||
|  |   UDP tunnels | ||||||
|  |  | ||||||
|  | - a new function generating those ICMP or ICMPv6 replies. We can't | ||||||
|  |   reuse icmp_send() and icmp6_send() as we don't see the sender as a | ||||||
|  |   valid destination. This doesn't need to be generic, as we don't | ||||||
|  |   cover any other type of ICMP errors given that we only provide an | ||||||
|  |   encapsulation function to the sender | ||||||
|  |  | ||||||
|  | While at it, make the MTU check in skb_tunnel_check_pmtu() accurate: | ||||||
|  | we might receive GSO buffers here, and the passed headroom already | ||||||
|  | includes the inner MAC length, so we don't have to account for it | ||||||
|  | a second time (that would imply three MAC headers on the wire, but | ||||||
|  | there are just two). | ||||||
|  |  | ||||||
|  | This issue became visible while bridging IPv6 packets with 4500 bytes | ||||||
|  | of payload over GENEVE using IPv4 with a PMTU of 4000. Given the 50 | ||||||
|  | bytes of encapsulation headroom, we would advertise MTU as 3950, and | ||||||
|  | we would reject fragmented IPv6 datagrams of 3958 bytes size on the | ||||||
|  | wire. We're exclusively dealing with network MTU here, though, so we | ||||||
|  | could get Ethernet frames up to 3964 octets in that case. | ||||||
|  |  | ||||||
|  | v2: | ||||||
|  | - moved skb_tunnel_check_pmtu() to ip_tunnel_core.c (David Ahern) | ||||||
|  | - split IPv4/IPv6 functions (David Ahern) | ||||||
|  |  | ||||||
|  | Signed-off-by: Stefano Brivio <sbrivio@redhat.com> | ||||||
|  | Reviewed-by: David Ahern <dsahern@gmail.com> | ||||||
|  | Signed-off-by: David S. Miller <davem@davemloft.net> | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | --- a/include/net/ip_tunnels.h | ||||||
|  | +++ b/include/net/ip_tunnels.h | ||||||
|  | @@ -279,6 +279,8 @@ int iptunnel_xmit(struct sock *sk, struc | ||||||
|  |  		  u8 tos, u8 ttl, __be16 df, bool xnet); | ||||||
|  |  struct metadata_dst *iptunnel_metadata_reply(struct metadata_dst *md, | ||||||
|  |  					     gfp_t flags); | ||||||
|  | +int skb_tunnel_check_pmtu(struct sk_buff *skb, struct dst_entry *encap_dst, | ||||||
|  | +			  int headroom, bool reply); | ||||||
|  |   | ||||||
|  |  struct sk_buff *iptunnel_handle_offloads(struct sk_buff *skb, bool gre_csum, | ||||||
|  |  					 int gso_type_mask); | ||||||
|  | --- a/net/ipv4/ip_tunnel_core.c | ||||||
|  | +++ b/net/ipv4/ip_tunnel_core.c | ||||||
|  | @@ -204,6 +204,252 @@ error: | ||||||
|  |  } | ||||||
|  |  EXPORT_SYMBOL_GPL(iptunnel_handle_offloads); | ||||||
|  |   | ||||||
|  | +/** | ||||||
|  | + * iptunnel_pmtud_build_icmp() - Build ICMP error message for PMTUD | ||||||
|  | + * @skb:	Original packet with L2 header | ||||||
|  | + * @mtu:	MTU value for ICMP error | ||||||
|  | + * | ||||||
|  | + * Return: length on success, negative error code if message couldn't be built. | ||||||
|  | + */ | ||||||
|  | +static int iptunnel_pmtud_build_icmp(struct sk_buff *skb, int mtu) | ||||||
|  | +{ | ||||||
|  | +	const struct iphdr *iph = ip_hdr(skb); | ||||||
|  | +	struct icmphdr *icmph; | ||||||
|  | +	struct iphdr *niph; | ||||||
|  | +	struct ethhdr eh; | ||||||
|  | +	int len, err; | ||||||
|  | + | ||||||
|  | +	if (!pskb_may_pull(skb, ETH_HLEN + sizeof(struct iphdr))) | ||||||
|  | +		return -EINVAL; | ||||||
|  | + | ||||||
|  | +	skb_copy_bits(skb, skb_mac_header(skb) - skb->data, &eh, ETH_HLEN); | ||||||
|  | +	pskb_pull(skb, ETH_HLEN); | ||||||
|  | +	skb_reset_network_header(skb); | ||||||
|  | + | ||||||
|  | +	err = pskb_trim(skb, 576 - sizeof(*niph) - sizeof(*icmph)); | ||||||
|  | +	if (err) | ||||||
|  | +		return err; | ||||||
|  | + | ||||||
|  | +	len = skb->len + sizeof(*icmph); | ||||||
|  | +	err = skb_cow(skb, sizeof(*niph) + sizeof(*icmph) + ETH_HLEN); | ||||||
|  | +	if (err) | ||||||
|  | +		return err; | ||||||
|  | + | ||||||
|  | +	icmph = (struct icmphdr *)skb_push(skb, sizeof(*icmph)); | ||||||
|  | +	*icmph = (struct icmphdr) { | ||||||
|  | +		.type			= ICMP_DEST_UNREACH, | ||||||
|  | +		.code			= ICMP_FRAG_NEEDED, | ||||||
|  | +		.checksum		= 0, | ||||||
|  | +		.un.frag.__unused	= 0, | ||||||
|  | +		.un.frag.mtu		= ntohs(mtu), | ||||||
|  | +	}; | ||||||
|  | +	icmph->checksum = ip_compute_csum(icmph, len); | ||||||
|  | +	skb_reset_transport_header(skb); | ||||||
|  | + | ||||||
|  | +	niph = (struct iphdr *)skb_push(skb, sizeof(*niph)); | ||||||
|  | +	*niph = (struct iphdr) { | ||||||
|  | +		.ihl			= sizeof(*niph) / 4u, | ||||||
|  | +		.version 		= 4, | ||||||
|  | +		.tos 			= 0, | ||||||
|  | +		.tot_len		= htons(len + sizeof(*niph)), | ||||||
|  | +		.id			= 0, | ||||||
|  | +		.frag_off		= htons(IP_DF), | ||||||
|  | +		.ttl			= iph->ttl, | ||||||
|  | +		.protocol		= IPPROTO_ICMP, | ||||||
|  | +		.saddr			= iph->daddr, | ||||||
|  | +		.daddr			= iph->saddr, | ||||||
|  | +	}; | ||||||
|  | +	ip_send_check(niph); | ||||||
|  | +	skb_reset_network_header(skb); | ||||||
|  | + | ||||||
|  | +	skb->ip_summed = CHECKSUM_NONE; | ||||||
|  | + | ||||||
|  | +	eth_header(skb, skb->dev, htons(eh.h_proto), eh.h_source, eh.h_dest, 0); | ||||||
|  | +	skb_reset_mac_header(skb); | ||||||
|  | + | ||||||
|  | +	return skb->len; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +/** | ||||||
|  | + * iptunnel_pmtud_check_icmp() - Trigger ICMP reply if needed and allowed | ||||||
|  | + * @skb:	Buffer being sent by encapsulation, L2 headers expected | ||||||
|  | + * @mtu:	Network MTU for path | ||||||
|  | + * | ||||||
|  | + * Return: 0 for no ICMP reply, length if built, negative value on error. | ||||||
|  | + */ | ||||||
|  | +static int iptunnel_pmtud_check_icmp(struct sk_buff *skb, int mtu) | ||||||
|  | +{ | ||||||
|  | +	const struct icmphdr *icmph = icmp_hdr(skb); | ||||||
|  | +	const struct iphdr *iph = ip_hdr(skb); | ||||||
|  | + | ||||||
|  | +	if (mtu <= 576 || iph->frag_off != htons(IP_DF)) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	if (ipv4_is_lbcast(iph->daddr)  || ipv4_is_multicast(iph->daddr) || | ||||||
|  | +	    ipv4_is_zeronet(iph->saddr) || ipv4_is_loopback(iph->saddr)  || | ||||||
|  | +	    ipv4_is_lbcast(iph->saddr)  || ipv4_is_multicast(iph->saddr)) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	if (iph->protocol == IPPROTO_ICMP && icmp_is_err(icmph->type)) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	return iptunnel_pmtud_build_icmp(skb, mtu); | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +#if IS_ENABLED(CONFIG_IPV6) | ||||||
|  | +/** | ||||||
|  | + * iptunnel_pmtud_build_icmpv6() - Build ICMPv6 error message for PMTUD | ||||||
|  | + * @skb:	Original packet with L2 header | ||||||
|  | + * @mtu:	MTU value for ICMPv6 error | ||||||
|  | + * | ||||||
|  | + * Return: length on success, negative error code if message couldn't be built. | ||||||
|  | + */ | ||||||
|  | +static int iptunnel_pmtud_build_icmpv6(struct sk_buff *skb, int mtu) | ||||||
|  | +{ | ||||||
|  | +	const struct ipv6hdr *ip6h = ipv6_hdr(skb); | ||||||
|  | +	struct icmp6hdr *icmp6h; | ||||||
|  | +	struct ipv6hdr *nip6h; | ||||||
|  | +	struct ethhdr eh; | ||||||
|  | +	int len, err; | ||||||
|  | +	__wsum csum; | ||||||
|  | + | ||||||
|  | +	if (!pskb_may_pull(skb, ETH_HLEN + sizeof(struct ipv6hdr))) | ||||||
|  | +		return -EINVAL; | ||||||
|  | + | ||||||
|  | +	skb_copy_bits(skb, skb_mac_header(skb) - skb->data, &eh, ETH_HLEN); | ||||||
|  | +	pskb_pull(skb, ETH_HLEN); | ||||||
|  | +	skb_reset_network_header(skb); | ||||||
|  | + | ||||||
|  | +	err = pskb_trim(skb, IPV6_MIN_MTU - sizeof(*nip6h) - sizeof(*icmp6h)); | ||||||
|  | +	if (err) | ||||||
|  | +		return err; | ||||||
|  | + | ||||||
|  | +	len = skb->len + sizeof(*icmp6h); | ||||||
|  | +	err = skb_cow(skb, sizeof(*nip6h) + sizeof(*icmp6h) + ETH_HLEN); | ||||||
|  | +	if (err) | ||||||
|  | +		return err; | ||||||
|  | + | ||||||
|  | +	icmp6h = (struct icmp6hdr *)skb_push(skb, sizeof(*icmp6h)); | ||||||
|  | +	*icmp6h = (struct icmp6hdr) { | ||||||
|  | +		.icmp6_type		= ICMPV6_PKT_TOOBIG, | ||||||
|  | +		.icmp6_code		= 0, | ||||||
|  | +		.icmp6_cksum		= 0, | ||||||
|  | +		.icmp6_mtu		= htonl(mtu), | ||||||
|  | +	}; | ||||||
|  | +	skb_reset_transport_header(skb); | ||||||
|  | + | ||||||
|  | +	nip6h = (struct ipv6hdr *)skb_push(skb, sizeof(*nip6h)); | ||||||
|  | +	*nip6h = (struct ipv6hdr) { | ||||||
|  | +		.priority		= 0, | ||||||
|  | +		.version		= 6, | ||||||
|  | +		.flow_lbl		= { 0 }, | ||||||
|  | +		.payload_len		= htons(len), | ||||||
|  | +		.nexthdr		= IPPROTO_ICMPV6, | ||||||
|  | +		.hop_limit		= ip6h->hop_limit, | ||||||
|  | +		.saddr			= ip6h->daddr, | ||||||
|  | +		.daddr			= ip6h->saddr, | ||||||
|  | +	}; | ||||||
|  | +	skb_reset_network_header(skb); | ||||||
|  | + | ||||||
|  | +	csum = csum_partial(icmp6h, len, 0); | ||||||
|  | +	icmp6h->icmp6_cksum = csum_ipv6_magic(&nip6h->saddr, &nip6h->daddr, len, | ||||||
|  | +					      IPPROTO_ICMPV6, csum); | ||||||
|  | + | ||||||
|  | +	skb->ip_summed = CHECKSUM_NONE; | ||||||
|  | + | ||||||
|  | +	eth_header(skb, skb->dev, htons(eh.h_proto), eh.h_source, eh.h_dest, 0); | ||||||
|  | +	skb_reset_mac_header(skb); | ||||||
|  | + | ||||||
|  | +	return skb->len; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +/** | ||||||
|  | + * iptunnel_pmtud_check_icmpv6() - Trigger ICMPv6 reply if needed and allowed | ||||||
|  | + * @skb:	Buffer being sent by encapsulation, L2 headers expected | ||||||
|  | + * @mtu:	Network MTU for path | ||||||
|  | + * | ||||||
|  | + * Return: 0 for no ICMPv6 reply, length if built, negative value on error. | ||||||
|  | + */ | ||||||
|  | +static int iptunnel_pmtud_check_icmpv6(struct sk_buff *skb, int mtu) | ||||||
|  | +{ | ||||||
|  | +	const struct ipv6hdr *ip6h = ipv6_hdr(skb); | ||||||
|  | +	int stype = ipv6_addr_type(&ip6h->saddr); | ||||||
|  | +	u8 proto = ip6h->nexthdr; | ||||||
|  | +	__be16 frag_off; | ||||||
|  | +	int offset; | ||||||
|  | + | ||||||
|  | +	if (mtu <= IPV6_MIN_MTU) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	if (stype == IPV6_ADDR_ANY || stype == IPV6_ADDR_MULTICAST || | ||||||
|  | +	    stype == IPV6_ADDR_LOOPBACK) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	offset = ipv6_skip_exthdr(skb, sizeof(struct ipv6hdr), &proto, | ||||||
|  | +				  &frag_off); | ||||||
|  | +	if (offset < 0 || (frag_off & htons(~0x7))) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	if (proto == IPPROTO_ICMPV6) { | ||||||
|  | +		struct icmp6hdr *icmp6h; | ||||||
|  | + | ||||||
|  | +		if (!pskb_may_pull(skb, skb_network_header(skb) + | ||||||
|  | +					offset + 1 - skb->data)) | ||||||
|  | +			return 0; | ||||||
|  | + | ||||||
|  | +		icmp6h = (struct icmp6hdr *)(skb_network_header(skb) + offset); | ||||||
|  | +		if (icmpv6_is_err(icmp6h->icmp6_type) || | ||||||
|  | +		    icmp6h->icmp6_type == NDISC_REDIRECT) | ||||||
|  | +			return 0; | ||||||
|  | +	} | ||||||
|  | + | ||||||
|  | +	return iptunnel_pmtud_build_icmpv6(skb, mtu); | ||||||
|  | +} | ||||||
|  | +#endif /* IS_ENABLED(CONFIG_IPV6) */ | ||||||
|  | + | ||||||
|  | +/** | ||||||
|  | + * skb_tunnel_check_pmtu() - Check, update PMTU and trigger ICMP reply as needed | ||||||
|  | + * @skb:	Buffer being sent by encapsulation, L2 headers expected | ||||||
|  | + * @encap_dst:	Destination for tunnel encapsulation (outer IP) | ||||||
|  | + * @headroom:	Encapsulation header size, bytes | ||||||
|  | + * @reply:	Build matching ICMP or ICMPv6 message as a result | ||||||
|  | + * | ||||||
|  | + * L2 tunnel implementations that can carry IP and can be directly bridged | ||||||
|  | + * (currently UDP tunnels) can't always rely on IP forwarding paths to handle | ||||||
|  | + * PMTU discovery. In the bridged case, ICMP or ICMPv6 messages need to be built | ||||||
|  | + * based on payload and sent back by the encapsulation itself. | ||||||
|  | + * | ||||||
|  | + * For routable interfaces, we just need to update the PMTU for the destination. | ||||||
|  | + * | ||||||
|  | + * Return: 0 if ICMP error not needed, length if built, negative value on error | ||||||
|  | + */ | ||||||
|  | +int skb_tunnel_check_pmtu(struct sk_buff *skb, struct dst_entry *encap_dst, | ||||||
|  | +			  int headroom, bool reply) | ||||||
|  | +{ | ||||||
|  | +	struct dst_entry *dst = skb_dst(skb); | ||||||
|  | +	u32 mtu = dst_mtu(encap_dst) - headroom; | ||||||
|  | + | ||||||
|  | +	if ((skb_is_gso(skb) && skb_gso_network_seglen(skb) <= mtu) || | ||||||
|  | +	    (!skb_is_gso(skb) && (skb->len - skb_mac_header_len(skb)) <= mtu)) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	if (dst && dst->ops->update_pmtu) | ||||||
|  | +		dst->ops->update_pmtu(dst, NULL, skb, mtu); | ||||||
|  | + | ||||||
|  | +	if (!reply || skb->pkt_type == PACKET_HOST) | ||||||
|  | +		return 0; | ||||||
|  | + | ||||||
|  | +	if (skb->protocol == htons(ETH_P_IP)) | ||||||
|  | +		return iptunnel_pmtud_check_icmp(skb, mtu); | ||||||
|  | + | ||||||
|  | +#if IS_ENABLED(CONFIG_IPV6) | ||||||
|  | +	if (skb->protocol == htons(ETH_P_IPV6)) | ||||||
|  | +		return iptunnel_pmtud_check_icmpv6(skb, mtu); | ||||||
|  | +#endif | ||||||
|  | +	return 0; | ||||||
|  | +} | ||||||
|  | +EXPORT_SYMBOL(skb_tunnel_check_pmtu); | ||||||
|  | + | ||||||
|  |  /* Often modified stats are per cpu, other are shared (netdev->stats) */ | ||||||
|  |  struct rtnl_link_stats64 *ip_tunnel_get_stats64(struct net_device *dev, | ||||||
|  |  						struct rtnl_link_stats64 *tot) | ||||||
|  | --- a/drivers/net/vxlan.c | ||||||
|  | +++ b/drivers/net/vxlan.c | ||||||
|  | @@ -2076,6 +2076,8 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  		/* Reset the skb_iif to Tunnels interface index */ | ||||||
|  |  		skb->skb_iif = dev->ifindex; | ||||||
|  |   | ||||||
|  | +		skb_tunnel_check_pmtu(skb, &rt->dst, VXLAN_HEADROOM, false); | ||||||
|  | + | ||||||
|  |  		tos = ip_tunnel_ecn_encap(tos, old_iph, skb); | ||||||
|  |  		ttl = ttl ? : ip4_dst_hoplimit(&rt->dst); | ||||||
|  |  		err = vxlan_xmit_skb(rt, sk, skb, fl4.saddr, | ||||||
|  | @@ -2141,6 +2143,8 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  				flags |= VXLAN_F_UDP_ZERO_CSUM6_TX; | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  | +		skb_tunnel_check_pmtu(skb, ndst, VXLAN6_HEADROOM, false); | ||||||
|  | + | ||||||
|  |  		ttl = ttl ? : ip6_dst_hoplimit(ndst); | ||||||
|  |  		err = vxlan6_xmit_skb(ndst, sk, skb, dev, &saddr, &dst->sin6.sin6_addr, | ||||||
|  |  				      0, ttl, src_port, dst_port, htonl(vni << 8), md, | ||||||
| @@ -0,0 +1,114 @@ | |||||||
|  | From: pravin shelar <pshelar@ovn.org> | ||||||
|  | Date: Sun, 13 Nov 2016 20:43:56 -0800 | ||||||
|  | Subject: [PATCH] vxlan: simplify RTF_LOCAL handling. | ||||||
|  |  | ||||||
|  | Avoid code duplicate code for handling RTF_LOCAL routes. | ||||||
|  |  | ||||||
|  | Signed-off-by: Pravin B Shelar <pshelar@ovn.org> | ||||||
|  | Acked-by: Jiri Benc <jbenc@redhat.com> | ||||||
|  | Signed-off-by: David S. Miller <davem@davemloft.net> | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | --- a/drivers/net/vxlan.c | ||||||
|  | +++ b/drivers/net/vxlan.c | ||||||
|  | @@ -1946,6 +1946,40 @@ static void vxlan_encap_bypass(struct sk | ||||||
|  |  	} | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +static int encap_bypass_if_local(struct sk_buff *skb, struct net_device *dev, | ||||||
|  | +				 struct vxlan_dev *vxlan, union vxlan_addr *daddr, | ||||||
|  | +				 __be32 dst_port, __be32 vni, struct dst_entry *dst, | ||||||
|  | +				 u32 rt_flags) | ||||||
|  | +{ | ||||||
|  | +#if IS_ENABLED(CONFIG_IPV6) | ||||||
|  | +	/* IPv6 rt-flags are checked against RTF_LOCAL, but the value of | ||||||
|  | +	 * RTF_LOCAL is equal to RTCF_LOCAL. So to keep code simple | ||||||
|  | +	 * we can use RTCF_LOCAL which works for ipv4 and ipv6 route entry. | ||||||
|  | +	 */ | ||||||
|  | +	BUILD_BUG_ON(RTCF_LOCAL != RTF_LOCAL); | ||||||
|  | +#endif | ||||||
|  | +	/* Bypass encapsulation if the destination is local */ | ||||||
|  | +	if (rt_flags & RTCF_LOCAL && | ||||||
|  | +	    !(rt_flags & (RTCF_BROADCAST | RTCF_MULTICAST))) { | ||||||
|  | +		struct vxlan_dev *dst_vxlan; | ||||||
|  | + | ||||||
|  | +		dst_release(dst); | ||||||
|  | +		dst_vxlan = vxlan_find_vni(vxlan->net, vni, | ||||||
|  | +					   daddr->sa.sa_family, dst_port, | ||||||
|  | +					   vxlan->flags); | ||||||
|  | +		if (!dst_vxlan) { | ||||||
|  | +			dev->stats.tx_errors++; | ||||||
|  | +			kfree_skb(skb); | ||||||
|  | + | ||||||
|  | +			return -ENOENT; | ||||||
|  | +		} | ||||||
|  | +		vxlan_encap_bypass(skb, vxlan, dst_vxlan); | ||||||
|  | +		return 1; | ||||||
|  | +	} | ||||||
|  | + | ||||||
|  | +	return 0; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  static void vxlan_xmit_one(struct sk_buff *skb, struct net_device *dev, | ||||||
|  |  			   struct vxlan_rdst *rdst, bool did_rsc) | ||||||
|  |  { | ||||||
|  | @@ -2059,18 +2093,12 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  |  		/* Bypass encapsulation if the destination is local */ | ||||||
|  | -		if (rt->rt_flags & RTCF_LOCAL && | ||||||
|  | -		    !(rt->rt_flags & (RTCF_BROADCAST | RTCF_MULTICAST))) { | ||||||
|  | -			struct vxlan_dev *dst_vxlan; | ||||||
|  | - | ||||||
|  | -			ip_rt_put(rt); | ||||||
|  | -			dst_vxlan = vxlan_find_vni(vxlan->net, vni, | ||||||
|  | -						   dst->sa.sa_family, dst_port, | ||||||
|  | -						   vxlan->flags); | ||||||
|  | -			if (!dst_vxlan) | ||||||
|  | -				goto tx_error; | ||||||
|  | -			vxlan_encap_bypass(skb, vxlan, dst_vxlan); | ||||||
|  | -			return; | ||||||
|  | +		if (!info) { | ||||||
|  | +			err = encap_bypass_if_local(skb, dev, vxlan, dst, | ||||||
|  | +						    dst_port, vni, &rt->dst, | ||||||
|  | +						    rt->rt_flags); | ||||||
|  | +			if (err) | ||||||
|  | +				return; | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  |  		/* Reset the skb_iif to Tunnels interface index */ | ||||||
|  | @@ -2096,7 +2124,6 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  	} else { | ||||||
|  |  		struct dst_entry *ndst; | ||||||
|  |  		struct in6_addr saddr; | ||||||
|  | -		u32 rt6i_flags; | ||||||
|  |   | ||||||
|  |  		if (!vxlan->vn6_sock) | ||||||
|  |  			goto drop; | ||||||
|  | @@ -2121,19 +2148,14 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  |  		/* Bypass encapsulation if the destination is local */ | ||||||
|  | -		rt6i_flags = ((struct rt6_info *)ndst)->rt6i_flags; | ||||||
|  | -		if (rt6i_flags & RTF_LOCAL && | ||||||
|  | -		    !(rt6i_flags & (RTCF_BROADCAST | RTCF_MULTICAST))) { | ||||||
|  | -			struct vxlan_dev *dst_vxlan; | ||||||
|  | +		if (!info) { | ||||||
|  | +			u32 rt6i_flags = ((struct rt6_info *)ndst)->rt6i_flags; | ||||||
|  |   | ||||||
|  | -			dst_release(ndst); | ||||||
|  | -			dst_vxlan = vxlan_find_vni(vxlan->net, vni, | ||||||
|  | -						   dst->sa.sa_family, dst_port, | ||||||
|  | -						   vxlan->flags); | ||||||
|  | -			if (!dst_vxlan) | ||||||
|  | -				goto tx_error; | ||||||
|  | -			vxlan_encap_bypass(skb, vxlan, dst_vxlan); | ||||||
|  | -			return; | ||||||
|  | +			err = encap_bypass_if_local(skb, dev, vxlan, dst, | ||||||
|  | +						    dst_port, vni, ndst, | ||||||
|  | +						    rt6i_flags); | ||||||
|  | +			if (err) | ||||||
|  | +				return; | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  |  		if (info) { | ||||||
| @@ -0,0 +1,140 @@ | |||||||
|  | From: Stefano Brivio <sbrivio@redhat.com> | ||||||
|  | Date: Tue, 4 Aug 2020 07:53:44 +0200 | ||||||
|  | Subject: [PATCH] vxlan: Support for PMTU discovery on directly bridged links | ||||||
|  |  | ||||||
|  | If the interface is a bridge or Open vSwitch port, and we can't | ||||||
|  | forward a packet because it exceeds the local PMTU estimate, | ||||||
|  | trigger an ICMP or ICMPv6 reply to the sender, using the same | ||||||
|  | interface to forward it back. | ||||||
|  |  | ||||||
|  | If metadata collection is enabled, reverse destination and source | ||||||
|  | addresses, so that Open vSwitch is able to match this packet against | ||||||
|  | the existing, reverse flow. | ||||||
|  |  | ||||||
|  | v2: Use netif_is_any_bridge_port() (David Ahern) | ||||||
|  |  | ||||||
|  | Signed-off-by: Stefano Brivio <sbrivio@redhat.com> | ||||||
|  | Signed-off-by: David S. Miller <davem@davemloft.net> | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | --- a/drivers/net/vxlan.c | ||||||
|  | +++ b/drivers/net/vxlan.c | ||||||
|  | @@ -1903,7 +1903,7 @@ static struct dst_entry *vxlan6_get_rout | ||||||
|  |   | ||||||
|  |  /* Bypass encapsulation if the destination is local */ | ||||||
|  |  static void vxlan_encap_bypass(struct sk_buff *skb, struct vxlan_dev *src_vxlan, | ||||||
|  | -			       struct vxlan_dev *dst_vxlan) | ||||||
|  | +			       struct vxlan_dev *dst_vxlan, bool snoop) | ||||||
|  |  { | ||||||
|  |  	struct pcpu_sw_netstats *tx_stats, *rx_stats; | ||||||
|  |  	union vxlan_addr loopback; | ||||||
|  | @@ -1928,7 +1928,7 @@ static void vxlan_encap_bypass(struct sk | ||||||
|  |  #endif | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -	if (dst_vxlan->flags & VXLAN_F_LEARN) | ||||||
|  | +	if ((dst_vxlan->flags & VXLAN_F_LEARN) && snoop) | ||||||
|  |  		vxlan_snoop(skb->dev, &loopback, eth_hdr(skb)->h_source); | ||||||
|  |   | ||||||
|  |  	u64_stats_update_begin(&tx_stats->syncp); | ||||||
|  | @@ -1973,7 +1973,7 @@ static int encap_bypass_if_local(struct | ||||||
|  |   | ||||||
|  |  			return -ENOENT; | ||||||
|  |  		} | ||||||
|  | -		vxlan_encap_bypass(skb, vxlan, dst_vxlan); | ||||||
|  | +		vxlan_encap_bypass(skb, vxlan, dst_vxlan, true); | ||||||
|  |  		return 1; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | @@ -1990,7 +1990,7 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  	const struct iphdr *old_iph; | ||||||
|  |  	struct flowi4 fl4; | ||||||
|  |  	union vxlan_addr *dst; | ||||||
|  | -	union vxlan_addr remote_ip; | ||||||
|  | +	union vxlan_addr remote_ip, local_ip; | ||||||
|  |  	struct vxlan_metadata _md; | ||||||
|  |  	struct vxlan_metadata *md = &_md; | ||||||
|  |  	__be16 src_port = 0, dst_port; | ||||||
|  | @@ -2006,6 +2006,7 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  		dst_port = rdst->remote_port ? rdst->remote_port : vxlan->cfg.dst_port; | ||||||
|  |  		vni = rdst->remote_vni; | ||||||
|  |  		dst = &rdst->remote_ip; | ||||||
|  | +		local_ip = vxlan->cfg.saddr; | ||||||
|  |  	} else { | ||||||
|  |  		if (!info) { | ||||||
|  |  			WARN_ONCE(1, "%s: Missing encapsulation instructions\n", | ||||||
|  | @@ -2015,17 +2016,20 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  		dst_port = info->key.tp_dst ? : vxlan->cfg.dst_port; | ||||||
|  |  		vni = be64_to_cpu(info->key.tun_id); | ||||||
|  |  		remote_ip.sa.sa_family = ip_tunnel_info_af(info); | ||||||
|  | -		if (remote_ip.sa.sa_family == AF_INET) | ||||||
|  | +		if (remote_ip.sa.sa_family == AF_INET) { | ||||||
|  |  			remote_ip.sin.sin_addr.s_addr = info->key.u.ipv4.dst; | ||||||
|  | -		else | ||||||
|  | +			local_ip.sin.sin_addr.s_addr = info->key.u.ipv4.src; | ||||||
|  | +		} else { | ||||||
|  |  			remote_ip.sin6.sin6_addr = info->key.u.ipv6.dst; | ||||||
|  | +			local_ip.sin6.sin6_addr = info->key.u.ipv6.src; | ||||||
|  | +		} | ||||||
|  |  		dst = &remote_ip; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	if (vxlan_addr_any(dst)) { | ||||||
|  |  		if (did_rsc) { | ||||||
|  |  			/* short-circuited back to local bridge */ | ||||||
|  | -			vxlan_encap_bypass(skb, vxlan, vxlan); | ||||||
|  | +			vxlan_encap_bypass(skb, vxlan, vxlan, true); | ||||||
|  |  			return; | ||||||
|  |  		} | ||||||
|  |  		goto drop; | ||||||
|  | @@ -2104,7 +2108,23 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  		/* Reset the skb_iif to Tunnels interface index */ | ||||||
|  |  		skb->skb_iif = dev->ifindex; | ||||||
|  |   | ||||||
|  | -		skb_tunnel_check_pmtu(skb, &rt->dst, VXLAN_HEADROOM, false); | ||||||
|  | +		err = skb_tunnel_check_pmtu(skb, &rt->dst, VXLAN_HEADROOM, | ||||||
|  | +					    netif_is_any_bridge_port(dev)); | ||||||
|  | +		if (err < 0) { | ||||||
|  | +			goto tx_error; | ||||||
|  | +		} else if (err) { | ||||||
|  | +			if (info) { | ||||||
|  | +				struct in_addr src, dst; | ||||||
|  | + | ||||||
|  | +				src = remote_ip.sin.sin_addr; | ||||||
|  | +				dst = local_ip.sin.sin_addr; | ||||||
|  | +				info->key.u.ipv4.src = src.s_addr; | ||||||
|  | +				info->key.u.ipv4.dst = dst.s_addr; | ||||||
|  | +			} | ||||||
|  | +			vxlan_encap_bypass(skb, vxlan, vxlan, false); | ||||||
|  | +			ip_rt_put(rt); | ||||||
|  | +			return; | ||||||
|  | +		} | ||||||
|  |   | ||||||
|  |  		tos = ip_tunnel_ecn_encap(tos, old_iph, skb); | ||||||
|  |  		ttl = ttl ? : ip4_dst_hoplimit(&rt->dst); | ||||||
|  | @@ -2165,7 +2185,24 @@ static void vxlan_xmit_one(struct sk_buf | ||||||
|  |  				flags |= VXLAN_F_UDP_ZERO_CSUM6_TX; | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  | -		skb_tunnel_check_pmtu(skb, ndst, VXLAN6_HEADROOM, false); | ||||||
|  | +		err = skb_tunnel_check_pmtu(skb, ndst, VXLAN6_HEADROOM, | ||||||
|  | +					    netif_is_any_bridge_port(dev)); | ||||||
|  | +		if (err < 0) { | ||||||
|  | +			goto tx_error; | ||||||
|  | +		} else if (err) { | ||||||
|  | +			if (info) { | ||||||
|  | +				struct in6_addr src, dst; | ||||||
|  | + | ||||||
|  | +				src = remote_ip.sin6.sin6_addr; | ||||||
|  | +				dst = local_ip.sin6.sin6_addr; | ||||||
|  | +				info->key.u.ipv6.src = src; | ||||||
|  | +				info->key.u.ipv6.dst = dst; | ||||||
|  | +			} | ||||||
|  | + | ||||||
|  | +			vxlan_encap_bypass(skb, vxlan, vxlan, false); | ||||||
|  | +			ip_rt_put(rt); | ||||||
|  | +			return; | ||||||
|  | +		} | ||||||
|  |   | ||||||
|  |  		ttl = ttl ? : ip6_dst_hoplimit(ndst); | ||||||
|  |  		err = vxlan6_xmit_skb(ndst, sk, skb, dev, &saddr, &dst->sin6.sin6_addr, | ||||||
| @@ -0,0 +1,234 @@ | |||||||
|  | From: Sven Eckelmann <sven@open-mesh.com> | ||||||
|  | Date: Wed, 2 Sep 2015 19:47:43 +0200 | ||||||
|  | Subject: generic: Fix per interface nf_call_iptables setting | ||||||
|  |  | ||||||
|  | commit r30917 ("kernel: bypass all netfilter hooks if the sysctls for that | ||||||
|  | functionality have been disabled - eliminates the overhead of enabling | ||||||
|  | CONFIG_BRIDGE_NETFILTER in the kernel config") introduced an optimization | ||||||
|  | which should reduce/eliminate the overhead for traffic send over bridges on | ||||||
|  | kernels compiled with CONFIG_BRIDGE_NETFILTER=y. But this optimization | ||||||
|  | breaks the nf_call_iptables per bridge setting which is more fine grained | ||||||
|  | than the global sysctl net.bridge.bridge-nf-call-iptables setting. | ||||||
|  |  | ||||||
|  | A test reflecting a real world setup was created to identify if this really | ||||||
|  | eliminates the overhead and if per-bridge nf_call_iptables could be used in | ||||||
|  | some setups to increase the throughput. A Qualcomm Atheros QCA9558 based | ||||||
|  | system with one ethernet and an ath9k wifi 3x3 in HT40 mode was used. | ||||||
|  | Cables from the AP to the wifi station were used to reduce interference | ||||||
|  | problems during the tests. | ||||||
|  |  | ||||||
|  | The wlan interface was put in one bridge interface called br-wlan. This | ||||||
|  | bridge usually contains some more wlan interfaces. The eth0 was put in a | ||||||
|  | second bridge called br-lan. This usually contains some other privileged | ||||||
|  | wlan or mesh interfaces. Routing was added between br-lan and br-wlan. | ||||||
|  |  | ||||||
|  | Three kernels were tested: | ||||||
|  |  | ||||||
|  |  * (default) OpenWrt kernel for this device | ||||||
|  |  * (brfilter-global) OpenWrt kernel with CONFIG_BRIDGE_NETFILTER=y | ||||||
|  |  * (brfilter-local)  OpenWrt kernel with CONFIG_BRIDGE_NETFILTER=y and | ||||||
|  |     without 644-bridge_optimize_netfilter_hooks.patch | ||||||
|  |  | ||||||
|  | The changes to the the netfilter settings of the bridge were done via: | ||||||
|  |  | ||||||
|  |  * (brfilter-global) /sbin/sysctl -w net.bridge.bridge-nf-call-iptables=1 | ||||||
|  |  * (brfilter-lobal) echo 1 > /sys/class/net/br-lan/bridge/nf_call_iptables | ||||||
|  |    and/or echo 1 > /sys/class/net/br-wan/bridge/nf_call_iptables | ||||||
|  |  | ||||||
|  | A station connected to the wlan0 (AP) interface was used to send traffic to | ||||||
|  | a PC connected via ethernet. iperf with 3 concurrent transmissions was used | ||||||
|  | to generate the traffic. | ||||||
|  |  | ||||||
|  | | kernel          | br-nf-* global | nf-call* iface | download | upload   | | ||||||
|  | |-----------------|----------------|----------------|----------|----------| | ||||||
|  | | default         | 0              | -              |      209 |      268 | | ||||||
|  | | brfilter-global | 0              | -              |      185 |      243 | | ||||||
|  | | brfilter-local  | 0              | -              |      187 |      243 | | ||||||
|  | | brfilter-local  | 0              | br-lan         |      157 |      226 | | ||||||
|  | | brfilter-local  | 0              | br-lan br-wlan |      139 |      161 | | ||||||
|  | | brfilter-global | 1              | -              |      136 |      162 | | ||||||
|  |  | ||||||
|  | Download/upload results in Mibit/s | ||||||
|  |  | ||||||
|  | It can be seen that the patch doesn't eliminate the overhead. It can also | ||||||
|  | be seen that the throughput of brfilter-global and brfilter-local with | ||||||
|  | disabled filtering is the roughly the same. Also the throughput for | ||||||
|  | brfilter-global and brfilter-local for enabled filtering on all bridges is | ||||||
|  | roughly the same. | ||||||
|  |  | ||||||
|  | But also the brfilter-local throughput is higher when only br-lan requires | ||||||
|  | the filtering. This setting would not be possible with | ||||||
|  | 644-bridge_optimize_netfilter_hooks.patch applied and thus can only be | ||||||
|  | compared with brfilter-global and filtering enabled for all interfaces. | ||||||
|  |  | ||||||
|  | Signed-off-by: Sven Eckelmann <sven@open-mesh.com> | ||||||
|  |  | ||||||
|  | Forwarded: https://patchwork.ozlabs.org/patch/513592/ | ||||||
|  | Applied-Upstream: https://dev.openwrt.org/changeset/46835 | ||||||
|  |  | ||||||
|  | --- a/net/bridge/br_forward.c | ||||||
|  | +++ b/net/bridge/br_forward.c | ||||||
|  | @@ -69,7 +69,7 @@ EXPORT_SYMBOL_GPL(br_dev_queue_push_xmit | ||||||
|  |   | ||||||
|  |  int br_forward_finish(struct net *net, struct sock *sk, struct sk_buff *skb) | ||||||
|  |  { | ||||||
|  | -	return BR_HOOK(NFPROTO_BRIDGE, NF_BR_POST_ROUTING, | ||||||
|  | +	return NF_HOOK(NFPROTO_BRIDGE, NF_BR_POST_ROUTING, | ||||||
|  |  		       net, sk, skb, NULL, skb->dev, | ||||||
|  |  		       br_dev_queue_push_xmit); | ||||||
|  |   | ||||||
|  | @@ -97,7 +97,7 @@ static void __br_deliver(const struct ne | ||||||
|  |  		return; | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  | -	BR_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, | ||||||
|  | +	NF_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, | ||||||
|  |  		dev_net(skb->dev), NULL, skb,NULL, skb->dev, | ||||||
|  |  		br_forward_finish); | ||||||
|  |  } | ||||||
|  | @@ -121,7 +121,7 @@ static void __br_forward(const struct ne | ||||||
|  |  	skb->dev = to->dev; | ||||||
|  |  	skb_forward_csum(skb); | ||||||
|  |   | ||||||
|  | -	BR_HOOK(NFPROTO_BRIDGE, NF_BR_FORWARD, | ||||||
|  | +	NF_HOOK(NFPROTO_BRIDGE, NF_BR_FORWARD, | ||||||
|  |  		dev_net(indev), NULL, skb, indev, skb->dev, | ||||||
|  |  		br_forward_finish); | ||||||
|  |  } | ||||||
|  | --- a/net/bridge/br_input.c | ||||||
|  | +++ b/net/bridge/br_input.c | ||||||
|  | @@ -70,7 +70,7 @@ int br_pass_frame_up(struct sk_buff *skb | ||||||
|  |  	if (!skb) | ||||||
|  |  		return NET_RX_DROP; | ||||||
|  |   | ||||||
|  | -	return BR_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_IN, | ||||||
|  | +	return NF_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_IN, | ||||||
|  |  		       dev_net(indev), NULL, skb, indev, NULL, | ||||||
|  |  		       br_netif_receive_skb); | ||||||
|  |  } | ||||||
|  | @@ -320,7 +320,7 @@ rx_handler_result_t br_handle_frame(stru | ||||||
|  |  		} | ||||||
|  |   | ||||||
|  |  		/* Deliver packet to local host only */ | ||||||
|  | -		if (BR_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_IN, | ||||||
|  | +		if (NF_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_IN, | ||||||
|  |  			    dev_net(skb->dev), NULL, skb, skb->dev, NULL, | ||||||
|  |  			    br_handle_local_finish)) { | ||||||
|  |  			return RX_HANDLER_CONSUMED; /* consumed by filter */ | ||||||
|  | @@ -337,7 +337,7 @@ forward: | ||||||
|  |  			if (ether_addr_equal(p->br->dev->dev_addr, dest)) | ||||||
|  |  				skb->pkt_type = PACKET_HOST; | ||||||
|  |   | ||||||
|  | -			if (BR_HOOK(NFPROTO_BRIDGE, NF_BR_PRE_ROUTING, dev_net(skb->dev), NULL, | ||||||
|  | +			if (NF_HOOK(NFPROTO_BRIDGE, NF_BR_PRE_ROUTING, dev_net(skb->dev), NULL, | ||||||
|  |  				skb, skb->dev, NULL, br_handle_local_finish)) | ||||||
|  |  				break; | ||||||
|  |   | ||||||
|  | @@ -361,7 +361,7 @@ forward: | ||||||
|  |  		if (ether_addr_equal(p->br->dev->dev_addr, dest)) | ||||||
|  |  			skb->pkt_type = PACKET_HOST; | ||||||
|  |   | ||||||
|  | -		BR_HOOK(NFPROTO_BRIDGE, NF_BR_PRE_ROUTING, | ||||||
|  | +		NF_HOOK(NFPROTO_BRIDGE, NF_BR_PRE_ROUTING, | ||||||
|  |  			dev_net(skb->dev), NULL, skb, skb->dev, NULL, | ||||||
|  |  			br_handle_frame_finish); | ||||||
|  |  		break; | ||||||
|  | --- a/net/bridge/br_multicast.c | ||||||
|  | +++ b/net/bridge/br_multicast.c | ||||||
|  | @@ -856,7 +856,7 @@ static void __br_multicast_send_query(st | ||||||
|  |   | ||||||
|  |  	if (port) { | ||||||
|  |  		skb->dev = port->dev; | ||||||
|  | -		BR_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, | ||||||
|  | +		NF_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, | ||||||
|  |  			dev_net(port->dev), NULL, skb, NULL, skb->dev, | ||||||
|  |  			br_dev_queue_push_xmit); | ||||||
|  |  	} else { | ||||||
|  | --- a/net/bridge/br_netfilter_hooks.c | ||||||
|  | +++ b/net/bridge/br_netfilter_hooks.c | ||||||
|  | @@ -72,15 +72,6 @@ static int brnf_pass_vlan_indev __read_m | ||||||
|  |  #define IS_ARP(skb) \ | ||||||
|  |  	(!skb_vlan_tag_present(skb) && skb->protocol == htons(ETH_P_ARP)) | ||||||
|  |   | ||||||
|  | -int brnf_call_ebtables __read_mostly; | ||||||
|  | -EXPORT_SYMBOL_GPL(brnf_call_ebtables); | ||||||
|  | - | ||||||
|  | -bool br_netfilter_run_hooks(void) | ||||||
|  | -{ | ||||||
|  | -	return brnf_call_iptables | brnf_call_ip6tables | brnf_call_arptables | | ||||||
|  | -		brnf_call_ebtables | brnf_call_custom; | ||||||
|  | -} | ||||||
|  | - | ||||||
|  |  static inline __be16 vlan_proto(const struct sk_buff *skb) | ||||||
|  |  { | ||||||
|  |  	if (skb_vlan_tag_present(skb)) | ||||||
|  | --- a/net/bridge/br_private.h | ||||||
|  | +++ b/net/bridge/br_private.h | ||||||
|  | @@ -909,29 +909,15 @@ extern const struct nf_br_ops __rcu *nf_ | ||||||
|  |   | ||||||
|  |  /* br_netfilter.c */ | ||||||
|  |  #if IS_ENABLED(CONFIG_BRIDGE_NETFILTER) | ||||||
|  | -extern int brnf_call_ebtables; | ||||||
|  |  int br_nf_core_init(void); | ||||||
|  |  void br_nf_core_fini(void); | ||||||
|  |  void br_netfilter_rtable_init(struct net_bridge *); | ||||||
|  | -bool br_netfilter_run_hooks(void); | ||||||
|  |  #else | ||||||
|  |  static inline int br_nf_core_init(void) { return 0; } | ||||||
|  |  static inline void br_nf_core_fini(void) {} | ||||||
|  |  #define br_netfilter_rtable_init(x) | ||||||
|  | -#define br_netfilter_run_hooks()	false | ||||||
|  |  #endif | ||||||
|  |   | ||||||
|  | -static inline int | ||||||
|  | -BR_HOOK(uint8_t pf, unsigned int hook, struct net *net, struct sock *sk, | ||||||
|  | -	struct sk_buff *skb, struct net_device *in, struct net_device *out, | ||||||
|  | -	int (*okfn)(struct net *, struct sock *, struct sk_buff *)) | ||||||
|  | -{ | ||||||
|  | -	if (!br_netfilter_run_hooks()) | ||||||
|  | -		return okfn(net, sk, skb); | ||||||
|  | - | ||||||
|  | -	return NF_HOOK(pf, hook, net, sk, skb, in, out, okfn); | ||||||
|  | -} | ||||||
|  | - | ||||||
|  |  /* br_stp.c */ | ||||||
|  |  void br_log_state(const struct net_bridge_port *p); | ||||||
|  |  void br_set_state(struct net_bridge_port *p, unsigned int state); | ||||||
|  | --- a/net/bridge/br_stp_bpdu.c | ||||||
|  | +++ b/net/bridge/br_stp_bpdu.c | ||||||
|  | @@ -60,7 +60,7 @@ static void br_send_bpdu(struct net_brid | ||||||
|  |   | ||||||
|  |  	skb_reset_mac_header(skb); | ||||||
|  |   | ||||||
|  | -	BR_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, | ||||||
|  | +	NF_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, | ||||||
|  |  		dev_net(p->dev), NULL, skb, NULL, skb->dev, | ||||||
|  |  		br_send_bpdu_finish); | ||||||
|  |  } | ||||||
|  | --- a/net/bridge/netfilter/ebtables.c | ||||||
|  | +++ b/net/bridge/netfilter/ebtables.c | ||||||
|  | @@ -2416,13 +2416,11 @@ static int __init ebtables_init(void) | ||||||
|  |  	} | ||||||
|  |   | ||||||
|  |  	printk(KERN_INFO "Ebtables v2.0 registered\n"); | ||||||
|  | -	brnf_call_ebtables = 1; | ||||||
|  |  	return 0; | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  static void __exit ebtables_fini(void) | ||||||
|  |  { | ||||||
|  | -	brnf_call_ebtables = 0; | ||||||
|  |  	nf_unregister_sockopt(&ebt_sockopts); | ||||||
|  |  	xt_unregister_target(&ebt_standard_target); | ||||||
|  |  	printk(KERN_INFO "Ebtables v2.0 unregistered\n"); | ||||||
|  | --- a/net/ipv4/netfilter/nf_nat_l3proto_ipv4.c | ||||||
|  | +++ b/net/ipv4/netfilter/nf_nat_l3proto_ipv4.c | ||||||
|  | @@ -310,7 +310,7 @@ nf_nat_ipv4_fn(void *priv, struct sk_buf | ||||||
|  |  		 * nf_bridge will be set and nf_bridge->physoutdev is not null, | ||||||
|  |  		 * We can assume that it is not expecting NAT operation. | ||||||
|  |  		 * | ||||||
|  | -		 * when BR_HOOK is enabled, multicast packets will reach | ||||||
|  | +		 * when NF_HOOK is enabled, multicast packets will reach | ||||||
|  |  		 * postrouting twice,the first time is when it is forwarded | ||||||
|  |  		 * between ports of a bridge, the second time is that it is | ||||||
|  |  		 * forwarded to upstream port. | ||||||
| @@ -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) | ||||||
							
								
								
									
										97
									
								
								feeds/ipq807x/qca-ssdk/patches/300-fdb.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										97
									
								
								feeds/ipq807x/qca-ssdk/patches/300-fdb.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,97 @@ | |||||||
|  | Index: qca-ssdk/src/init/ssdk_init.c | ||||||
|  | =================================================================== | ||||||
|  | --- qca-ssdk.orig/src/init/ssdk_init.c | ||||||
|  | +++ qca-ssdk/src/init/ssdk_init.c | ||||||
|  | @@ -137,6 +137,10 @@ | ||||||
|  |  #include "ssdk_scomphy.h" | ||||||
|  |  #endif | ||||||
|  |   | ||||||
|  | +#include <linux/debugfs.h> | ||||||
|  | +#include "fal/fal_fdb.h" | ||||||
|  | +#include "ref/ref_vsi.h" | ||||||
|  | + | ||||||
|  |  #ifdef IN_RFS | ||||||
|  |  struct rfs_device rfs_dev; | ||||||
|  |  struct notifier_block ssdk_inet_notifier; | ||||||
|  | @@ -2005,10 +2009,81 @@ void ssdk_ess_reset(void) | ||||||
|  |   | ||||||
|  |  char ssdk_driver_name[] = "ess_ssdk"; | ||||||
|  |   | ||||||
|  | +static ssize_t ssdk_flush_mac_write(struct file *f, const char *buffer, | ||||||
|  | +				    size_t len, loff_t *offset) | ||||||
|  | +{ | ||||||
|  | +        fal_fdb_entry_t entry; | ||||||
|  | +	char data[18]; | ||||||
|  | +	ssize_t ret; | ||||||
|  | +	char mac[6]; | ||||||
|  | + | ||||||
|  | +	ret = simple_write_to_buffer(data, sizeof(data), offset, buffer, len); | ||||||
|  | + | ||||||
|  | +	if (ret < 0) | ||||||
|  | +		return ret; | ||||||
|  | +	data[17] = 0; | ||||||
|  | + | ||||||
|  | +	if (sscanf(data, "%2hhx:%2hhx:%2hhx:%2hhx:%2hhx:%2hhx", | ||||||
|  | +                                &mac[0], &mac[1], &mac[2], &mac[3], | ||||||
|  | +                                &mac[4], &mac[5]) != 6) { | ||||||
|  | +		printk("failed to parse mac\n"); | ||||||
|  | +		return -1; | ||||||
|  | +	} | ||||||
|  | + | ||||||
|  | +	{ | ||||||
|  | +		fal_fdb_op_t	fdb_op; | ||||||
|  | +		fal_fdb_entry_t	fdb_entry; | ||||||
|  | +		sw_error_t	ret; | ||||||
|  | + | ||||||
|  | +		memset(&fdb_op, 0, sizeof(fdb_op)); | ||||||
|  | +		memset(&fdb_entry, 0, sizeof(fdb_entry)); | ||||||
|  | + | ||||||
|  | +		ret = fal_fdb_entry_extend_getfirst(0, &fdb_op, &fdb_entry); | ||||||
|  | +		while (ret == SW_OK) { | ||||||
|  | +			/*printk("%s:%s[%d]%d %2x:%2x:%2x:%2x:%2x:%2x | %2x:%2x:%2x:%2x:%2x:%2x\n", __FILE__, __func__, __LINE__, | ||||||
|  | +				fdb_entry.fid, fdb_entry.addr.uc[0], fdb_entry.addr.uc[1], fdb_entry.addr.uc[2], fdb_entry.addr.uc[3], fdb_entry.addr.uc[4], fdb_entry.addr.uc[5], | ||||||
|  | +				mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);*/ | ||||||
|  | +			if (!memcmp(mac, &fdb_entry.addr, 6)) { | ||||||
|  | +				memset(&entry, 0, sizeof(entry)); | ||||||
|  | +				memcpy(&entry.addr, mac, ETH_ALEN); | ||||||
|  | +				entry.fid = fdb_entry.fid; | ||||||
|  | + | ||||||
|  | +				if (SW_OK != fal_fdb_entry_del_bymac(0, &entry))  | ||||||
|  | +					printk("failed to delete FDB entry\n"); | ||||||
|  | +				else | ||||||
|  | +					printk("deleted %s/%d\n", data, entry.fid); | ||||||
|  | +			} | ||||||
|  | + | ||||||
|  | +			ret = fal_fdb_entry_extend_getnext(0, &fdb_op, &fdb_entry); | ||||||
|  | +		} | ||||||
|  | + | ||||||
|  | +	} | ||||||
|  | +	return len; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  | +const struct file_operations ssdk_flush_mac_fops = { | ||||||
|  | +	.owner = THIS_MODULE, | ||||||
|  | +	.write = ssdk_flush_mac_write, | ||||||
|  | +}; | ||||||
|  | + | ||||||
|  | +static int debugfs_fdb_init(void) | ||||||
|  | +{ | ||||||
|  | +	void *ret; | ||||||
|  | + | ||||||
|  | +	ret = debugfs_create_file("ssdk_flush_mac", 0644, NULL, NULL, | ||||||
|  | +				&ssdk_flush_mac_fops); | ||||||
|  | +	if (!ret) | ||||||
|  | +		pr_warn("Failed to create ssdk_flush_mac in debugfs"); | ||||||
|  | + | ||||||
|  | +	return 0; | ||||||
|  | +} | ||||||
|  | + | ||||||
|  |  static int ssdk_probe(struct platform_device *pdev) | ||||||
|  |  { | ||||||
|  |  	struct device_node *np; | ||||||
|  |   | ||||||
|  | +	debugfs_fdb_init(); | ||||||
|  | + | ||||||
|  |  	np = of_node_get(pdev->dev.of_node); | ||||||
|  |  	if (of_device_is_compatible(np, "qcom,ess-instance")) | ||||||
|  |  		return of_platform_populate(np, NULL, NULL, &pdev->dev); | ||||||
							
								
								
									
										179
									
								
								feeds/ipq807x/xtables-addons/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										179
									
								
								feeds/ipq807x/xtables-addons/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,179 @@ | |||||||
|  | # | ||||||
|  | # Copyright (C) 2009-2013 OpenWrt.org | ||||||
|  | # | ||||||
|  | # This is free software, licensed under the GNU General Public License v2. | ||||||
|  | # See /LICENSE for more information. | ||||||
|  | # | ||||||
|  |  | ||||||
|  | include $(TOPDIR)/rules.mk | ||||||
|  | include $(INCLUDE_DIR)/kernel.mk | ||||||
|  |  | ||||||
|  | PKG_NAME:=xtables-addons | ||||||
|  | PKG_VERSION:=2.14 | ||||||
|  | PKG_RELEASE:=8 | ||||||
|  | PKG_HASH:=d215a9a8b8e66aae04b982fa2e1228e8a71e7dfe42320df99e34e5000cbdf152 | ||||||
|  |  | ||||||
|  | PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.xz | ||||||
|  | PKG_SOURCE_URL:=@SF/xtables-addons | ||||||
|  | PKG_BUILD_DEPENDS:=iptables | ||||||
|  | PKG_INSTALL:=1 | ||||||
|  | PKG_BUILD_PARALLEL:=1 | ||||||
|  | PKG_CHECK_FORMAT_SECURITY:=0 | ||||||
|  |  | ||||||
|  | PKG_MAINTAINER:=Jo-Philipp Wich <jo@mein.io> | ||||||
|  | PKG_LICENSE:=GPL-2.0 | ||||||
|  |  | ||||||
|  | PKG_FIXUP:=autoreconf | ||||||
|  |  | ||||||
|  | include $(INCLUDE_DIR)/package.mk | ||||||
|  |  | ||||||
|  | define Package/xtables-addons | ||||||
|  |   SECTION:=net | ||||||
|  |   CATEGORY:=Network | ||||||
|  |   SUBMENU:=Firewall | ||||||
|  |   TITLE:=Extensions not distributed in the main Xtables | ||||||
|  |   URL:=http://xtables-addons.sourceforge.net/ | ||||||
|  | endef | ||||||
|  |  | ||||||
|  | # uses GNU configure | ||||||
|  |  | ||||||
|  | CONFIGURE_ARGS+= \ | ||||||
|  | 	--with-kbuild="$(LINUX_DIR)" \ | ||||||
|  | 	--with-xtlibdir="/usr/lib/iptables" | ||||||
|  |  | ||||||
|  | ifdef CONFIG_EXTERNAL_TOOLCHAIN | ||||||
|  | MAKE_FLAGS:= \ | ||||||
|  | 	$(patsubst ARCH=%,ARCH=$(LINUX_KARCH),$(MAKE_FLAGS)) \ | ||||||
|  | 	DEPMOD="/bin/true" | ||||||
|  |  | ||||||
|  | MAKE_INSTALL_FLAGS:= \ | ||||||
|  | 	$(patsubst ARCH=%,ARCH=$(LINUX_KARCH),$(MAKE_FLAGS)) \ | ||||||
|  | 	DEPMOD="/bin/true" | ||||||
|  | else | ||||||
|  | define Build/Compile | ||||||
|  | 	+$(MAKE) $(PKG_JOBS) -C $(PKG_BUILD_DIR) \ | ||||||
|  | 		$(KERNEL_MAKE_FLAGS) \ | ||||||
|  | 		DESTDIR="$(PKG_INSTALL_DIR)" \ | ||||||
|  | 		DEPMOD="/bin/true" \ | ||||||
|  | 		all | ||||||
|  | endef | ||||||
|  |  | ||||||
|  | define Build/Install | ||||||
|  | 	$(MAKE) -C $(PKG_BUILD_DIR) \ | ||||||
|  | 		$(KERNEL_MAKE_FLAGS) \ | ||||||
|  | 		DESTDIR="$(PKG_INSTALL_DIR)" \ | ||||||
|  | 		DEPMOD="/bin/true" \ | ||||||
|  | 		install | ||||||
|  | endef | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | # 1: extension/module suffix used in package name | ||||||
|  | # 2: extension/module display name used in package title/description | ||||||
|  | # 3: list of extensions to package | ||||||
|  | # 4: list of modules to package | ||||||
|  | # 5: module load priority | ||||||
|  | # 6: module depends | ||||||
|  | define BuildTemplate | ||||||
|  |  | ||||||
|  |  ifneq ($(3),) | ||||||
|  |   define Package/iptables-mod-$(1) | ||||||
|  |     $$(call Package/xtables-addons) | ||||||
|  |     CATEGORY:=Network | ||||||
|  |     TITLE:=$(2) iptables extension | ||||||
|  |     DEPENDS:=iptables $(if $(4),+kmod-ipt-$(1)) | ||||||
|  |   endef | ||||||
|  |  | ||||||
|  |   define Package/iptables-mod-$(1)/install | ||||||
|  | 	$(INSTALL_DIR) $$(1)/usr/lib/iptables | ||||||
|  | 	for m in $(3); do \ | ||||||
|  | 		$(CP) \ | ||||||
|  | 			$(PKG_INSTALL_DIR)/usr/lib/iptables/lib$$$$$$$${m}.so \ | ||||||
|  | 			$$(1)/usr/lib/iptables/ ; \ | ||||||
|  | 	done | ||||||
|  |   endef | ||||||
|  |  | ||||||
|  |   $$(eval $$(call BuildPackage,iptables-mod-$(1))) | ||||||
|  |  endif | ||||||
|  |  | ||||||
|  |  ifneq ($(4),) | ||||||
|  |   define KernelPackage/ipt-$(1) | ||||||
|  |     SUBMENU:=Netfilter Extensions | ||||||
|  |     TITLE:=$(2) netfilter module | ||||||
|  |     DEPENDS:=+kmod-ipt-core $(5) | ||||||
|  |     FILES:=$(foreach mod,$(4),$(PKG_BUILD_DIR)/extensions/$(mod).$(LINUX_KMOD_SUFFIX)) | ||||||
|  |     AUTOLOAD:=$(call AutoProbe,$(notdir $(4))) | ||||||
|  |   endef | ||||||
|  |  | ||||||
|  |   $$(eval $$(call KernelPackage,ipt-$(1))) | ||||||
|  |  endif | ||||||
|  |  | ||||||
|  | endef | ||||||
|  |  | ||||||
|  |  | ||||||
|  | define Package/iptaccount | ||||||
|  |   $(call Package/xtables-addons) | ||||||
|  |   CATEGORY:=Network | ||||||
|  |   TITLE:=iptables-mod-account control utility | ||||||
|  |   DEPENDS:=iptables +iptables-mod-account | ||||||
|  | endef | ||||||
|  |  | ||||||
|  | define Package/iptaccount/install | ||||||
|  | 	$(INSTALL_DIR) $(1)/usr/lib | ||||||
|  | 	$(INSTALL_DIR) $(1)/usr/sbin | ||||||
|  | 	$(CP) \ | ||||||
|  | 		$(PKG_INSTALL_DIR)/usr/lib/libxt_ACCOUNT_cl.so* \ | ||||||
|  | 		$(1)/usr/lib/ | ||||||
|  | 	$(CP) \ | ||||||
|  | 		$(PKG_INSTALL_DIR)/usr/sbin/iptaccount \ | ||||||
|  | 		$(1)/usr/sbin/ | ||||||
|  | endef | ||||||
|  |  | ||||||
|  |  | ||||||
|  | define Package/iptgeoip | ||||||
|  |   $(call Package/xtables-addons) | ||||||
|  |   CATEGORY:=Network | ||||||
|  |   TITLE:=iptables-mod-geoip support scripts for MaxMind GeoIP databases | ||||||
|  |   # we could also use wget-nossl but that's more complicated than our | ||||||
|  |   # syntax of dependencies permits... | ||||||
|  |   DEPENDS:=iptables +iptables-mod-geoip \ | ||||||
|  | 		+perl +perlbase-getopt +perlbase-io +perl-text-csv_xs \ | ||||||
|  | 		+!BUSYBOX_CONFIG_WGET:wget +!BUSYBOX_CONFIG_GZIP:gzip +!BUSYBOX_CONFIG_UNZIP:unzip | ||||||
|  | endef | ||||||
|  |  | ||||||
|  | define Package/iptgeoip/install | ||||||
|  | 	$(INSTALL_DIR) $(1)/usr/lib/xtables-addons | ||||||
|  | 	$(CP) \ | ||||||
|  | 		$(PKG_INSTALL_DIR)/usr/lib/xtables-addons/xt_geoip_{build,dl} \ | ||||||
|  | 		$(1)/usr/lib/xtables-addons/ | ||||||
|  | 	$(INSTALL_DIR) $(1)/usr/share/xt_geoip | ||||||
|  | endef | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #$(eval $(call BuildTemplate,SUFFIX,DESCRIPTION,EXTENSION,MODULE,PRIORITY,DEPENDS)) | ||||||
|  |  | ||||||
|  | $(eval $(call BuildTemplate,compat-xtables,API compatibilty layer,,compat_xtables,+IPV6:kmod-ip6tables)) | ||||||
|  | $(eval $(call BuildTemplate,nathelper-rtsp,RTSP Conntrack and NAT,,rtsp/nf_conntrack_rtsp rtsp/nf_nat_rtsp,+kmod-ipt-conntrack-extra +kmod-ipt-nat)) | ||||||
|  |  | ||||||
|  | $(eval $(call BuildTemplate,account,ACCOUNT,xt_ACCOUNT,ACCOUNT/xt_ACCOUNT,+kmod-ipt-compat-xtables)) | ||||||
|  | $(eval $(call BuildTemplate,chaos,CHAOS,xt_CHAOS,xt_CHAOS,+kmod-ipt-compat-xtables +kmod-ipt-delude +kmod-ipt-tarpit)) | ||||||
|  | $(eval $(call BuildTemplate,condition,Condition,xt_condition,xt_condition,)) | ||||||
|  | $(eval $(call BuildTemplate,delude,DELUDE,xt_DELUDE,xt_DELUDE,+kmod-ipt-compat-xtables)) | ||||||
|  | $(eval $(call BuildTemplate,dhcpmac,DHCPMAC,xt_DHCPMAC,xt_DHCPMAC,+kmod-ipt-compat-xtables)) | ||||||
|  | $(eval $(call BuildTemplate,dnetmap,DNETMAP,xt_DNETMAP,xt_DNETMAP,+kmod-ipt-compat-xtables +kmod-ipt-nat)) | ||||||
|  | $(eval $(call BuildTemplate,fuzzy,fuzzy,xt_fuzzy,xt_fuzzy,)) | ||||||
|  | $(eval $(call BuildTemplate,geoip,geoip,xt_geoip,xt_geoip,)) | ||||||
|  | $(eval $(call BuildTemplate,iface,iface,xt_iface,xt_iface,)) | ||||||
|  | $(eval $(call BuildTemplate,ipmark,IPMARK,xt_IPMARK,xt_IPMARK,+kmod-ipt-compat-xtables)) | ||||||
|  | $(eval $(call BuildTemplate,ipp2p,IPP2P,xt_ipp2p,xt_ipp2p,+kmod-ipt-compat-xtables)) | ||||||
|  | $(eval $(call BuildTemplate,ipv4options,ipv4options,xt_ipv4options,xt_ipv4options,)) | ||||||
|  | $(eval $(call BuildTemplate,length2,length2,xt_length2,xt_length2,+kmod-ipt-compat-xtables)) | ||||||
|  | $(eval $(call BuildTemplate,logmark,LOGMARK,xt_LOGMARK,xt_LOGMARK,+kmod-ipt-compat-xtables)) | ||||||
|  | $(eval $(call BuildTemplate,lscan,lscan,xt_lscan,xt_lscan,)) | ||||||
|  | $(eval $(call BuildTemplate,lua,Lua PacketScript,xt_LUA,LUA/xt_LUA,+kmod-ipt-conntrack-extra)) | ||||||
|  | $(eval $(call BuildTemplate,psd,psd,xt_psd,xt_psd,)) | ||||||
|  | $(eval $(call BuildTemplate,quota2,quota2,xt_quota2,xt_quota2,)) | ||||||
|  | $(eval $(call BuildTemplate,sysrq,SYSRQ,xt_SYSRQ,xt_SYSRQ,+kmod-ipt-compat-xtables +kmod-crypto-hash)) | ||||||
|  | $(eval $(call BuildTemplate,tarpit,TARPIT,xt_TARPIT,xt_TARPIT,+kmod-ipt-compat-xtables)) | ||||||
|  |  | ||||||
|  | $(eval $(call BuildPackage,iptaccount)) | ||||||
|  | $(eval $(call BuildPackage,iptgeoip)) | ||||||
| @@ -0,0 +1,11 @@ | |||||||
|  | --- a/configure.ac | ||||||
|  | +++ b/configure.ac | ||||||
|  | @@ -44,7 +44,7 @@ regular_CFLAGS="-Wall -Waggregate-return | ||||||
|  |   | ||||||
|  |  if test -n "$kbuilddir"; then | ||||||
|  |  	AC_MSG_CHECKING([kernel version that we will build against]) | ||||||
|  | -	krel="$(make -sC "$kbuilddir" M=$PWD kernelrelease | $AWK -v 'FS=[[^0-9.]]' '{print $1; exit}')" | ||||||
|  | +	krel="$(make -sC "$kbuilddir" M=$PWD kernelversion | $AWK -v 'FS=[[^0-9.]]' '{print $1; exit}')" | ||||||
|  |  	save_IFS="$IFS" | ||||||
|  |  	IFS='.' | ||||||
|  |  	set x $krel | ||||||
| @@ -0,0 +1,50 @@ | |||||||
|  | From 2b76b68c65c97fc11409088c3c30993324df8500 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Marcelo Henrique Cerri <marcelo.cerri@canonical.com> | ||||||
|  | Date: Thu, 4 Jan 2018 18:50:50 +0100 | ||||||
|  | Subject: [PATCH] build: support for Linux 4.15 | ||||||
|  |  | ||||||
|  | Signed-off-by: Marcelo Henrique Cerri <marcelo.cerri@canonical.com> | ||||||
|  | --- | ||||||
|  |  extensions/pknock/xt_pknock.c | 16 +++++++++++++++- | ||||||
|  |  1 file changed, 15 insertions(+), 1 deletion(-) | ||||||
|  |  | ||||||
|  | diff --git a/extensions/pknock/xt_pknock.c b/extensions/pknock/xt_pknock.c | ||||||
|  | index 6fbdea4..31d4bc8 100644 | ||||||
|  | --- a/extensions/pknock/xt_pknock.c | ||||||
|  | +++ b/extensions/pknock/xt_pknock.c | ||||||
|  | @@ -358,10 +358,20 @@ has_logged_during_this_minute(const struct peer *peer) | ||||||
|  |   * @r: rule | ||||||
|  |   */ | ||||||
|  |  static void | ||||||
|  | -peer_gc(unsigned long r) | ||||||
|  | +peer_gc( | ||||||
|  | +#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 15, 0) | ||||||
|  | +	struct timer_list *tl | ||||||
|  | +#else | ||||||
|  | +	unsigned long r | ||||||
|  | +#endif | ||||||
|  | +) | ||||||
|  |  { | ||||||
|  |  	unsigned int i; | ||||||
|  | +#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 15, 0) | ||||||
|  | +	struct xt_pknock_rule *rule = from_timer(rule, tl, timer); | ||||||
|  | +#else | ||||||
|  |  	struct xt_pknock_rule *rule = (struct xt_pknock_rule *)r; | ||||||
|  | +#endif | ||||||
|  |  	struct peer *peer; | ||||||
|  |  	struct list_head *pos, *n; | ||||||
|  |   | ||||||
|  | @@ -469,9 +479,13 @@ add_rule(struct xt_pknock_mtinfo *info) | ||||||
|  |  	if (rule->peer_head == NULL) | ||||||
|  |  		goto out; | ||||||
|  |   | ||||||
|  | +#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 15, 0) | ||||||
|  | +	timer_setup(&rule->timer, peer_gc, 0); | ||||||
|  | +#else | ||||||
|  |  	init_timer(&rule->timer); | ||||||
|  |  	rule->timer.function	= peer_gc; | ||||||
|  |  	rule->timer.data	= (unsigned long)rule; | ||||||
|  | +#endif | ||||||
|  |   | ||||||
|  |  	rule->status_proc = proc_create_data(info->rule_name, 0, pde, | ||||||
|  |  	                    &pknock_proc_ops, rule); | ||||||
| @@ -0,0 +1,25 @@ | |||||||
|  | From 3ea761a1ed338241fbc79bef8e433307e108b6cd Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Jan Engelhardt <jengelh@inai.de> | ||||||
|  | Date: Tue, 14 Aug 2018 14:29:30 +0200 | ||||||
|  | Subject: [PATCH] build: add support for Linux 4.18 | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  extensions/xt_DNETMAP.c | 4 ++++ | ||||||
|  |  1 file changed, 4 insertions(+) | ||||||
|  |  | ||||||
|  | diff --git a/extensions/xt_DNETMAP.c b/extensions/xt_DNETMAP.c | ||||||
|  | index 1b415c3..de7d4ec 100644 | ||||||
|  | --- a/extensions/xt_DNETMAP.c | ||||||
|  | +++ b/extensions/xt_DNETMAP.c | ||||||
|  | @@ -367,7 +367,11 @@ dnetmap_tg(struct sk_buff *skb, const struct xt_action_param *par) | ||||||
|  |  	__be32 prenat_ip, postnat_ip, prenat_ip_prev; | ||||||
|  |  	const struct xt_DNETMAP_tginfo *tginfo = par->targinfo; | ||||||
|  |  	const struct nf_nat_range *mr = &tginfo->prefix; | ||||||
|  | +#if LINUX_VERSION_CODE >= KERNEL_VERSION(4, 18, 0) | ||||||
|  | +	struct nf_nat_range2 newrange; | ||||||
|  | +#else | ||||||
|  |  	struct nf_nat_range newrange; | ||||||
|  | +#endif | ||||||
|  |  	struct dnetmap_entry *e; | ||||||
|  |  	struct dnetmap_prefix *p; | ||||||
|  |  	__s32 jttl; | ||||||
							
								
								
									
										1732
									
								
								feeds/ipq807x/xtables-addons/patches/100-add-rtsp-conntrack.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1732
									
								
								feeds/ipq807x/xtables-addons/patches/100-add-rtsp-conntrack.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										18158
									
								
								feeds/ipq807x/xtables-addons/patches/200-add-lua-packetscript.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18158
									
								
								feeds/ipq807x/xtables-addons/patches/200-add-lua-packetscript.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -0,0 +1,127 @@ | |||||||
|  | --- a/extensions/LUA/xt_LUA_target.c | ||||||
|  | +++ b/extensions/LUA/xt_LUA_target.c | ||||||
|  | @@ -19,7 +19,7 @@ | ||||||
|  |  #include <linux/kernel.h> | ||||||
|  |  #include <linux/slab.h> | ||||||
|  |  #include <linux/module.h> | ||||||
|  | -#include <asm/uaccess.h> | ||||||
|  | +#include <linux/uaccess.h> | ||||||
|  |  #include <net/ip.h> | ||||||
|  |  #include <linux/netfilter/x_tables.h> | ||||||
|  |  #include "xt_LUA.h" | ||||||
|  | @@ -64,10 +64,10 @@ uint32_t  lua_state_refs[LUA_STATE_ARRAY | ||||||
|  |   * XT_CONTINUE inside the *register_lua_packet_lib* function. | ||||||
|  |   */ | ||||||
|  |   | ||||||
|  | -spinlock_t lock = SPIN_LOCK_UNLOCKED; | ||||||
|  | +DEFINE_SPINLOCK(lock); | ||||||
|  |   | ||||||
|  |  static uint32_t  | ||||||
|  | -lua_tg(struct sk_buff *pskb, const struct xt_target_param *par) | ||||||
|  | +lua_tg(struct sk_buff *pskb, const struct xt_action_param *par) | ||||||
|  |  { | ||||||
|  |  	uint32_t  verdict; | ||||||
|  |  	lua_packet_segment *p; | ||||||
|  | @@ -88,11 +88,11 @@ lua_tg(struct sk_buff *pskb, const struc | ||||||
|  |  	/* push the lua_packet_segment as a parameter */ | ||||||
|  |  	p = (lua_packet_segment *)lua_newuserdata(L, sizeof(lua_packet_segment)); | ||||||
|  |  	if (pskb->mac_header) | ||||||
|  | -		p->start = pskb->mac_header; | ||||||
|  | +		p->start = skb_mac_header(pskb); | ||||||
|  |  	else if (pskb->network_header) | ||||||
|  | -		p->start = pskb->network_header; | ||||||
|  | +		p->start = skb_network_header(pskb); | ||||||
|  |  	else if (pskb->transport_header) | ||||||
|  | -		p->start = pskb->transport_header; | ||||||
|  | +		p->start = skb_transport_header(pskb); | ||||||
|  |  	p->offset = 0; | ||||||
|  |  	p->length = (unsigned long)pskb->tail - (unsigned long)p->start; | ||||||
|  |  	p->changes = NULL; | ||||||
|  | @@ -208,16 +208,16 @@ static bool load_script_into_state(uint3 | ||||||
|  |   * some workqueue initialization. So far this is done each time this function | ||||||
|  |   * is called, subject to change. | ||||||
|  |   */ | ||||||
|  | -static bool | ||||||
|  | +static int | ||||||
|  |  lua_tg_checkentry(const struct xt_tgchk_param *par) | ||||||
|  |  { | ||||||
|  |  	const struct xt_lua_tginfo *info = par->targinfo; | ||||||
|  |   | ||||||
|  |  	if (load_script_into_state(info->state_id, info->script_size, (char *)info->buf)) { | ||||||
|  |  		lua_state_refs[info->state_id]++; | ||||||
|  | -		return true; | ||||||
|  | +		return 0; | ||||||
|  |  	} | ||||||
|  | -	return false; | ||||||
|  | +	return -EINVAL; | ||||||
|  |  } | ||||||
|  |   | ||||||
|  |  /*::* | ||||||
|  | --- a/extensions/LUA/lua/llimits.h | ||||||
|  | +++ b/extensions/LUA/lua/llimits.h | ||||||
|  | @@ -8,7 +8,6 @@ | ||||||
|  |  #define llimits_h | ||||||
|  |   | ||||||
|  |  #include <stddef.h> | ||||||
|  | -#include <limits.h> | ||||||
|  |   | ||||||
|  |  #include "lua.h" | ||||||
|  |   | ||||||
|  | --- a/extensions/LUA/lua/lapi.c | ||||||
|  | +++ b/extensions/LUA/lua/lapi.c | ||||||
|  | @@ -4,9 +4,6 @@ | ||||||
|  |  ** See Copyright Notice in lua.h | ||||||
|  |  */ | ||||||
|  |   | ||||||
|  | -#include <stdarg.h> | ||||||
|  | -#include <math.h> | ||||||
|  | -#include <assert.h> | ||||||
|  |  #include <string.h> | ||||||
|  |   | ||||||
|  |  #define lapi_c | ||||||
|  | --- a/extensions/LUA/lua/ltable.c | ||||||
|  | +++ b/extensions/LUA/lua/ltable.c | ||||||
|  | @@ -18,7 +18,6 @@ | ||||||
|  |  ** Hence even when the load factor reaches 100%, performance remains good. | ||||||
|  |  */ | ||||||
|  |   | ||||||
|  | -#include <math.h> | ||||||
|  |  #include <string.h> | ||||||
|  |   | ||||||
|  |  #define ltable_c | ||||||
|  | --- a/extensions/LUA/lua/luaconf.h | ||||||
|  | +++ b/extensions/LUA/lua/luaconf.h | ||||||
|  | @@ -13,8 +13,12 @@ | ||||||
|  |  #if !defined(__KERNEL__) | ||||||
|  |  #include <limits.h> | ||||||
|  |  #else | ||||||
|  | +#include <linux/kernel.h> | ||||||
|  | + | ||||||
|  | +#undef UCHAR_MAX | ||||||
|  | +#undef BUFSIZ | ||||||
|  | +#undef NO_FPU | ||||||
|  |  #define UCHAR_MAX	255 | ||||||
|  | -#define SHRT_MAX        32767 | ||||||
|  |  #define BUFSIZ 		8192 | ||||||
|  |  #define NO_FPU | ||||||
|  |  #endif | ||||||
|  | @@ -637,6 +641,8 @@ union luai_Cast { double l_d; long l_l; | ||||||
|  |  */ | ||||||
|  |  #if defined(__KERNEL__) | ||||||
|  |  #undef LUA_USE_ULONGJMP | ||||||
|  | +#define setjmp __builtin_setjmp | ||||||
|  | +#define longjmp __builtin_longjmp | ||||||
|  |  #endif | ||||||
|  |   | ||||||
|  |  #if defined(__cplusplus) | ||||||
|  | --- a/extensions/LUA/lua/llex.h | ||||||
|  | +++ b/extensions/LUA/lua/llex.h | ||||||
|  | @@ -10,6 +10,8 @@ | ||||||
|  |  #include "lobject.h" | ||||||
|  |  #include "lzio.h" | ||||||
|  |   | ||||||
|  | +/* prevent conflict with definition from asm/current.h */ | ||||||
|  | +#undef current | ||||||
|  |   | ||||||
|  |  #define FIRST_RESERVED	257 | ||||||
|  |   | ||||||
| @@ -0,0 +1,18 @@ | |||||||
|  | --- a/extensions/libxt_geoip.c | ||||||
|  | +++ b/extensions/libxt_geoip.c | ||||||
|  | @@ -59,13 +59,13 @@ geoip_get_subnets(const char *code, uint | ||||||
|  |   | ||||||
|  |  	/* Use simple integer vector files */ | ||||||
|  |  	if (nfproto == NFPROTO_IPV6) { | ||||||
|  | -#if __BYTE_ORDER == _BIG_ENDIAN | ||||||
|  | +#if BYTE_ORDER == BIG_ENDIAN | ||||||
|  |  		snprintf(buf, sizeof(buf), GEOIP_DB_DIR "/BE/%s.iv6", code); | ||||||
|  |  #else | ||||||
|  |  		snprintf(buf, sizeof(buf), GEOIP_DB_DIR "/LE/%s.iv6", code); | ||||||
|  |  #endif | ||||||
|  |  	} else { | ||||||
|  | -#if __BYTE_ORDER == _BIG_ENDIAN | ||||||
|  | +#if BYTE_ORDER == BIG_ENDIAN | ||||||
|  |  		snprintf(buf, sizeof(buf), GEOIP_DB_DIR "/BE/%s.iv4", code); | ||||||
|  |  #else | ||||||
|  |  		snprintf(buf, sizeof(buf), GEOIP_DB_DIR "/LE/%s.iv4", code); | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| menu "Configuration" |  | ||||||
| 	depends on PACKAGE_openvswitch |  | ||||||
|  |  | ||||||
| 	config	OPENVSWITCH_WITH_LIBUNBOUND |  | ||||||
| 		bool |  | ||||||
| 		default y |  | ||||||
| 		prompt "Build with libunbound library." |  | ||||||
| endmenu |  | ||||||
| @@ -1,282 +0,0 @@ | |||||||
| # |  | ||||||
| # Copyright (C) 2013 Julius Schulz-Zander <julius@net.t-labs.tu-berlin.de> |  | ||||||
| # Copyright (C) 2014-2017 OpenWrt.org |  | ||||||
| # Copyright (C) 2018-2020 Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| # |  | ||||||
| # This is free software, licensed under the GNU General Public License v2. |  | ||||||
| # See /LICENSE for more information. |  | ||||||
| # |  | ||||||
| include $(TOPDIR)/rules.mk |  | ||||||
| include $(INCLUDE_DIR)/kernel.mk |  | ||||||
| include ./openvswitch.mk |  | ||||||
|  |  | ||||||
| # Checklist on version bump |  | ||||||
| # |  | ||||||
| #  - Check acinclude.m4 for range of supported kernel versions: "but version newer than .* is not supported" |  | ||||||
| #  - Check and update kmod dependencies when necessary (runtime module load check in the least) |  | ||||||
| # |  | ||||||
| PKG_NAME:=openvswitch |  | ||||||
| PKG_VERSION:=$(ovs_version) |  | ||||||
| PKG_RELEASE:=10 |  | ||||||
| PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz |  | ||||||
| PKG_SOURCE_URL:=https://www.openvswitch.org/releases/ |  | ||||||
| PKG_HASH:=5c7baed537364d43af36c15dde298c95d35cb2cb3204b4d3fe9b0fc73c97f16d |  | ||||||
|  |  | ||||||
| PKG_LICENSE:=Apache-2.0 |  | ||||||
| PKG_LICENSE_FILES:=LICENSE |  | ||||||
| PKG_CPE_ID:=cpe:/a:openvswitch:openvswitch |  | ||||||
|  |  | ||||||
| PKG_BUILD_DIR:=$(ovs_builddir) |  | ||||||
| PKG_BUILD_DEPENDS+=python3/host python-six/host |  | ||||||
| PKG_USE_MIPS16:=0 |  | ||||||
| PKG_BUILD_PARALLEL:=1 |  | ||||||
| PKG_FIXUP:=autoreconf |  | ||||||
| PKG_INSTALL:=1 |  | ||||||
| PYTHON3_PKG_BUILD:=0 |  | ||||||
|  |  | ||||||
| PKG_MAINTAINER:=Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
|  |  | ||||||
| include $(INCLUDE_DIR)/package.mk |  | ||||||
| include $(TOPDIR)/feeds/packages/lang/python/python3-host.mk |  | ||||||
| include $(TOPDIR)/feeds/packages/lang/python/python3-package.mk |  | ||||||
|  |  | ||||||
| define Package/openvswitch/config |  | ||||||
| source "$(SOURCE)/Config.in" |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| ovs_kmod_packages:= |  | ||||||
| ovs_kmod_intree_kernel_patchver_min:=3.10 |  | ||||||
| ovs_kmod_intree_kernel_patchver_max:=5.5 |  | ||||||
| ovs_kmod_intree_not_supported:=$(strip $(call kernel_patchver_lt,$(ovs_kmod_intree_kernel_patchver_min))$(call kernel_patchver_gt,$(ovs_kmod_intree_kernel_patchver_max))) |  | ||||||
| ovs_kmod_intree_dir:=$(PKG_BUILD_DIR)/datapath/linux |  | ||||||
| ovs_kmod_upstream_dir:=$(LINUX_DIR)/net/openvswitch |  | ||||||
| ovs_kmod_package_name=$(if $(filter openvswitch,$(1)),openvswitch,$(1)) |  | ||||||
| ovs_kmod_is_intree=$(filter %-intree,$(1)) |  | ||||||
| ovs_kmod_upstream_name=kmod-$(call ovs_kmod_package_name,$(patsubst %-intree,%,$(1))) |  | ||||||
| ovs_kmod_package_provides=$(call ovs_kmod_upstream_name,$(1)) |  | ||||||
| define OvsKmodPackageTemplate |  | ||||||
| ifeq ($(if $(call ovs_kmod_is_intree,$(1)),$(ovs_kmod_intree_not_supported)),) |  | ||||||
|   define KernelPackage/$(call ovs_kmod_package_name,$(1)) |  | ||||||
|      SECTION:=kernel |  | ||||||
|      CATEGORY:=Kernel modules |  | ||||||
|      SUBMENU:=Network Support |  | ||||||
|      TITLE:=$(ovs_kmod_$(1)_title) |  | ||||||
|      DEPENDS:=$(ovs_kmod_$(1)_depends) $(if $(call ovs_kmod_is_intree,$(1)),@IPV6 @DEVEL) |  | ||||||
|      PROVIDES:=$(call ovs_kmod_package_provides,$(1)) |  | ||||||
|      KCONFIG:=$(ovs_kmod_$(1)_kconfig) |  | ||||||
|      FILES:=$(ovs_kmod_$(1)_files) |  | ||||||
|      AUTOLOAD:=$(call AutoProbe,$(foreach m,$(ovs_kmod_$(1)_files),$(notdir $(patsubst %.ko,%,$(basename $(m)))))) |  | ||||||
|   endef |  | ||||||
|  |  | ||||||
|   ovs_kmod_packages+=$(call ovs_kmod_package_name,$(1)) |  | ||||||
| endif |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch_title:=Open vSwitch kernel datapath (upstream) |  | ||||||
| ovs_kmod_openvswitch_kconfig:=CONFIG_OPENVSWITCH |  | ||||||
| ovs_kmod_openvswitch_depends:=\ |  | ||||||
| 	  +kmod-lib-crc32c \ |  | ||||||
| 	  +kmod-nf-nat \ |  | ||||||
| 	  +IPV6:kmod-nf-nat6 \ |  | ||||||
| 	  +kmod-nf-conntrack \ |  | ||||||
| 	  +IPV6:kmod-nf-conntrack6 \ |  | ||||||
| 	  +kmod-nsh \ |  | ||||||
| 	  +kmod-ipt-conntrack-extra \ |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch_files:=$(ovs_kmod_upstream_dir)/openvswitch.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-gre_title:=Open vSwitch GRE tunneling support (upstream) |  | ||||||
| ovs_kmod_openvswitch-gre_kconfig:= CONFIG_OPENVSWITCH_GRE |  | ||||||
| ovs_kmod_openvswitch-gre_depends:= +kmod-openvswitch +kmod-gre |  | ||||||
| ovs_kmod_openvswitch-gre_files:= $(ovs_kmod_upstream_dir)/vport-gre.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-gre)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-vxlan_title:=Open vSwitch VXLAN tunneling support (upstream) |  | ||||||
| ovs_kmod_openvswitch-vxlan_kconfig:= CONFIG_OPENVSWITCH_VXLAN |  | ||||||
| ovs_kmod_openvswitch-vxlan_depends:= +kmod-openvswitch +kmod-vxlan |  | ||||||
| ovs_kmod_openvswitch-vxlan_files:= $(ovs_kmod_upstream_dir)/vport-vxlan.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-vxlan)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-geneve_title:=Open vSwitch Geneve tunneling support (upstream) |  | ||||||
| ovs_kmod_openvswitch-geneve_kconfig:= CONFIG_OPENVSWITCH_GENEVE |  | ||||||
| ovs_kmod_openvswitch-geneve_depends:= +kmod-openvswitch +kmod-geneve |  | ||||||
| ovs_kmod_openvswitch-geneve_files:= $(ovs_kmod_upstream_dir)/vport-geneve.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-geneve)) |  | ||||||
|  |  | ||||||
| # NOTE depends |  | ||||||
| # |  | ||||||
| #  - kmod-ipt-conntrack-extra: required for nf_conncount.ko |  | ||||||
| # |  | ||||||
| ovs_kmod_openvswitch-intree_title:=Open vSwitch kernel datapath (in tree) |  | ||||||
| ovs_kmod_openvswitch-intree_depends:=\ |  | ||||||
| 	  +kmod-lib-crc32c \ |  | ||||||
| 	  +kmod-nf-nat \ |  | ||||||
| 	  +IPV6:kmod-nf-nat6 \ |  | ||||||
| 	  +kmod-nf-conntrack \ |  | ||||||
| 	  +kmod-udptunnel4 \ |  | ||||||
| 	  +kmod-ipt-conntrack-extra \ |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-intree_files:= $(ovs_kmod_intree_dir)/openvswitch.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-intree)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-gre-intree_title:=Open vSwitch GRE tunneling support (in tree) |  | ||||||
| ovs_kmod_openvswitch-gre-intree_depends:= +kmod-openvswitch-intree +kmod-gre |  | ||||||
| ovs_kmod_openvswitch-gre-intree_files:= $(ovs_kmod_intree_dir)/vport-gre.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-gre-intree)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-vxlan-intree_title:=Open vSwitch VXLAN tunneling support (in tree) |  | ||||||
| ovs_kmod_openvswitch-vxlan-intree_depends:= +kmod-openvswitch-intree +kmod-vxlan |  | ||||||
| ovs_kmod_openvswitch-vxlan-intree_files:= $(ovs_kmod_intree_dir)/vport-vxlan.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-vxlan-intree)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-geneve-intree_title:=Open vSwitch Geneve tunneling support (in tree) |  | ||||||
| ovs_kmod_openvswitch-geneve-intree_depends:= +kmod-openvswitch-intree +kmod-geneve |  | ||||||
| ovs_kmod_openvswitch-geneve-intree_files:= $(ovs_kmod_intree_dir)/vport-geneve.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-geneve-intree)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-stt-intree_title:=Open vSwitch STT tunneling support (in tree) |  | ||||||
| ovs_kmod_openvswitch-stt-intree_depends:= +kmod-openvswitch-intree |  | ||||||
| ovs_kmod_openvswitch-stt-intree_files:= $(ovs_kmod_intree_dir)/vport-stt.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-stt-intree)) |  | ||||||
|  |  | ||||||
| ovs_kmod_openvswitch-lisp-intree_title:=Open vSwitch LISP tunneling support (in tree) |  | ||||||
| ovs_kmod_openvswitch-lisp-intree_depends:= +kmod-openvswitch-intree |  | ||||||
| ovs_kmod_openvswitch-lisp-intree_files:= $(ovs_kmod_intree_dir)/vport-lisp.ko |  | ||||||
| $(eval $(call OvsKmodPackageTemplate,openvswitch-lisp-intree)) |  | ||||||
|  |  | ||||||
| # Dependency review |  | ||||||
| # |  | ||||||
| #	for f in sbin/*;   do echo $f; readelf -d $f | grep -i shared; done |  | ||||||
| #	for f in bin/*;    do echo $f; readelf -d $f | grep -i shared; done |  | ||||||
| #	for f in lib/*.so; do echo $f; readelf -d $f | grep -i shared; done |  | ||||||
| # |  | ||||||
| ovs_libopenvswitch_title:=Open vSwitch (libopenvswitch.so) |  | ||||||
| ovs_libopenvswitch_hidden:=1 |  | ||||||
| ovs_libopenvswitch_depends:=+libopenssl +!(arc||arceb):libunwind |  | ||||||
| ovs_libopenvswitch_depends+=+libatomic |  | ||||||
| ifeq ($(CONFIG_OPENVSWITCH_WITH_LIBUNBOUND),y) |  | ||||||
| ovs_libopenvswitch_depends+=+libunbound |  | ||||||
| endif |  | ||||||
| ovs_libopenvswitch_files:=usr/lib/libopenvswitch*.so* |  | ||||||
| $(eval $(call OvsPackageTemplate,libopenvswitch)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ovs_libofproto_title:=Open vSwitch (libofproto.so libsflow.so) |  | ||||||
| ovs_libofproto_hidden:=1 |  | ||||||
| ovs_libofproto_depends+=+libatomic |  | ||||||
| ovs_libofproto_files:=usr/lib/libofproto*.so* usr/lib/libsflow*.so* |  | ||||||
| $(eval $(call OvsPackageTemplate,libofproto)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ovs_libovsdb_title:=Open vSwitch (libovsdb.so) |  | ||||||
| ovs_libovsdb_hidden:=1 |  | ||||||
| ovs_libovsdb_depends+=+libatomic |  | ||||||
| ovs_libovsdb_files:=usr/lib/libovsdb*.so* |  | ||||||
| $(eval $(call OvsPackageTemplate,libovsdb)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ovs_vswitchd_title:=Open vSwitch (ovs-vswitchd) |  | ||||||
| ovs_vswitchd_hidden:=1 |  | ||||||
| ovs_vswitchd_depends:=+openvswitch-libopenvswitch +openvswitch-libofproto |  | ||||||
| ovs_vswitchd_depends+=+libatomic |  | ||||||
| ovs_vswitchd_files:=usr/sbin/ovs-vswitchd |  | ||||||
| $(eval $(call OvsPackageTemplate,vswitchd)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ovs_ovsdb_title:=Open vSwitch (ovsdb-server) |  | ||||||
| ovs_ovsdb_hidden:=1 |  | ||||||
| ovs_ovsdb_depends:=+openvswitch-libopenvswitch +openvswitch-libovsdb |  | ||||||
| ovs_ovsdb_depends+=+libatomic |  | ||||||
| ovs_ovsdb_files:=usr/sbin/ovsdb-server |  | ||||||
| $(eval $(call OvsPackageTemplate,ovsdb)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ovs_common_title:=Open vSwitch (common files) |  | ||||||
| ovs_common_hidden:=1 |  | ||||||
| ovs_common_depends:=+openvswitch-libopenvswitch +openvswitch-libofproto +openvswitch-libovsdb |  | ||||||
| ovs_common_depends+=+libatomic |  | ||||||
| ovs_common_files:= \ |  | ||||||
| 	usr/share/openvswitch/scripts/ovs-lib \ |  | ||||||
| 	usr/share/openvswitch/scripts/ovs-ctl \ |  | ||||||
| 	usr/share/openvswitch/scripts/ovs-kmod-ctl \ |  | ||||||
| 	usr/share/openvswitch/scripts/ovs-save \ |  | ||||||
| 	$(foreach b,ovs-appctl ovs-dpctl ovs-ofctl ovs-vsctl ovsdb-client ovsdb-tool,usr/bin/$(b)) |  | ||||||
| define ovs_common_install |  | ||||||
| 	$$(INSTALL_DIR) $$(1)/etc/openvswitch |  | ||||||
| 	$$(INSTALL_DIR) $$(1)/etc/init.d |  | ||||||
| 	$$(INSTALL_BIN) ./files/openvswitch.init $$(1)/etc/init.d/openvswitch |  | ||||||
| 	$$(INSTALL_DIR) $$(1)/etc/config |  | ||||||
| 	$$(INSTALL_DATA) ./files/openvswitch.config $$(1)/etc/config/openvswitch |  | ||||||
| 	$$(INSTALL_DIR) $$(1)/usr/share/openvswitch/scripts |  | ||||||
| 	$$(INSTALL_BIN) ./files/ovs-ctl-wrapper $$(1)/usr/share/openvswitch/scripts/ |  | ||||||
| 	$$(LN) /usr/share/openvswitch/scripts/ovs-ctl-wrapper $$(1)/usr/bin/ovs-ctl |  | ||||||
| 	$$(LN) /usr/share/openvswitch/scripts/ovs-ctl-wrapper $$(1)/usr/bin/ovs-kmod-ctl |  | ||||||
| endef |  | ||||||
| define Package/openvswitch-common/conffiles |  | ||||||
| /etc/config/openvswitch |  | ||||||
| /etc/openvswitch |  | ||||||
| endef |  | ||||||
| $(eval $(call OvsPackageTemplate,common)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # coreutils-sleep is required by ovs-lib for sleeping a fraction of second |  | ||||||
| # |  | ||||||
| # uuidgen is required for generating system-id |  | ||||||
| ovs_openvswitch_title:=Open vSwitch |  | ||||||
| ovs_openvswitch_hidden:= |  | ||||||
| ovs_openvswitch_depends:=+coreutils +coreutils-sleep +uuidgen \ |  | ||||||
| 	+openvswitch-common +openvswitch-vswitchd +openvswitch-ovsdb +kmod-openvswitch |  | ||||||
| ovs_openvswitch_depends+=+libatomic |  | ||||||
| ovs_openvswitch_files:= usr/share/openvswitch/vswitch.ovsschema |  | ||||||
| $(eval $(call OvsPackageTemplate,openvswitch)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ovs_python3_title:=Open vSwitch (Python3 library) |  | ||||||
| ovs_python3_hidden:= |  | ||||||
| ovs_python3_depends:=+PACKAGE_openvswitch-python3:python3 +PACKAGE_openvswitch-python3:python3-six |  | ||||||
| define ovs_python3_install |  | ||||||
| 	$$(INSTALL_DIR) $$(1)$$(PYTHON3_PKG_DIR) |  | ||||||
| 	$$(CP) $$(PKG_INSTALL_DIR)/usr/share/openvswitch/python/ovs $$(1)$$(PYTHON3_PKG_DIR) |  | ||||||
| endef |  | ||||||
| $(eval $(call OvsPackageTemplate,python3)) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| CONFIGURE_ARGS+= \ |  | ||||||
| 	--enable-ndebug \ |  | ||||||
| 	--enable-shared \ |  | ||||||
| 	--disable-libcapng \ |  | ||||||
| 	--disable-silent-rules \ |  | ||||||
|  |  | ||||||
| CONFIGURE_VARS += \ |  | ||||||
| 	$(if $(CONFIG_OPENVSWITCH_WITH_LIBUNBOUND),,ac_cv_lib_unbound_ub_ctx_create=no) \ |  | ||||||
| 	ovs_cv_flake8=no \ |  | ||||||
| 	ovs_cv_python3=$(PYTHON3) \ |  | ||||||
| 	ovs_cv_python3_host=$(HOST_PYTHON3_BIN) \ |  | ||||||
| 	SPHINXBUILD=none \ |  | ||||||
| 	KARCH=$(LINUX_KARCH) \ |  | ||||||
|  |  | ||||||
| ovs_intree_kmod_configs:=CONFIG_PACKAGE_kmod-openvswitch-intree |  | ||||||
| ovs_intree_kmod_enabled:=$(strip $(foreach c,$(ovs_intree_kmod_configs),$($(c)))) |  | ||||||
| PKG_CONFIG_DEPENDS+=$(ovs_intree_kmod_configs) |  | ||||||
| ifneq ($(ovs_intree_kmod_enabled),) |  | ||||||
|   ifeq ($(ovs_kmod_intree_not_supported),) |  | ||||||
|     CONFIGURE_ARGS += --with-linux=$(LINUX_DIR) |  | ||||||
|   else |  | ||||||
|     $(warning XXX: openvswitch: intree kmods selected but not supported) |  | ||||||
|   endif |  | ||||||
| endif |  | ||||||
|  |  | ||||||
| TARGET_CFLAGS += -flto -std=gnu99 |  | ||||||
| MAKE_VARS += PYTHONPATH="$(HOST_PYTHON3PATH)" |  | ||||||
|  |  | ||||||
| export OVS_KERNEL_MAKE_FLAGS=$(KERNEL_MAKE_FLAGS) |  | ||||||
|  |  | ||||||
| override CONFIG_AUTOREMOVE= |  | ||||||
|  |  | ||||||
| $(foreach p,$(ovs_kmod_packages),\ |  | ||||||
|   $(eval $(call KernelPackage,$(p)))\ |  | ||||||
| ) |  | ||||||
| $(foreach p,$(ovs_packages),\ |  | ||||||
|   $(eval $(call BuildPackage,$(p)))\ |  | ||||||
| ) |  | ||||||
| @@ -1,106 +0,0 @@ | |||||||
| # Which packages to install |  | ||||||
|  |  | ||||||
| Install `openvswitch` if you need OpenFlow virtual switch function.  It |  | ||||||
| contains ovs-vswitchd, ovsdb-server and helper utilities such as ovs-vsctl, |  | ||||||
| ovs-ofctl, ovs-ctl etc. |  | ||||||
|  |  | ||||||
| Linux kernel datapath module openvswitch.ko will also be installed along with |  | ||||||
| package `openvswitch`.  Tunnel encap support for gre, geneve, vxlan can be |  | ||||||
| included by installing `kmod-openvswitch-{gre,geneve,vxlan}` respectively |  | ||||||
|  |  | ||||||
| For OVN deployment |  | ||||||
|  |  | ||||||
| - Install `openvswitch-ovn-north` for ovs-northd, ovsdb-server, ovn helper utitlies |  | ||||||
| - Install `openvswitch-ovn-host` for ovn-controller and `openvswitch` |  | ||||||
|  |  | ||||||
| # How to use them |  | ||||||
|  |  | ||||||
| Open vSwitch provides a few very useful helper script in |  | ||||||
| `/usr/share/openvswitch/scripts/`.  A simple initscript is provided.  It's |  | ||||||
| mainly a wrapper around `ovs-ctl` and `ovn-ctl` with simple knobs from |  | ||||||
| `/etc/config/openvswitch`.  Procd is not used here. |  | ||||||
|  |  | ||||||
| 	/etc/init.d/openvswitch start |  | ||||||
| 	/etc/init.d/openvswitch stop |  | ||||||
| 	/etc/init.d/openvswitch stop north |  | ||||||
| 	/etc/init.d/openvswitch restart ovs |  | ||||||
| 	/etc/init.d/openvswitch status |  | ||||||
|  |  | ||||||
| Use `ovs-ctl` and `ovn-ctl` directly for more functionalities |  | ||||||
|  |  | ||||||
| # Open vSwitch in-tree Linux datapath modules |  | ||||||
|  |  | ||||||
| The Open vSwitch build system uses regexp and conditional-compilation |  | ||||||
| heuristics to support building the shipped kernel module source code against a |  | ||||||
| wide range of kernels, as of openvswitch-2.10, the list is supposed to include |  | ||||||
| vanilla linux 3.10 to 4.15, plus a few distro kernels. |  | ||||||
|  |  | ||||||
| It may NOT work |  | ||||||
|  |  | ||||||
|  - Sometimes the code does not compile |  | ||||||
|  - Sometimes the code compiles but insmod will fail |  | ||||||
|  - Sometimes modules are loaded okay but actually does not function right |  | ||||||
|  |  | ||||||
| For these reasons, the in-tree datapath modules are NOT visible/enabled by |  | ||||||
| default. |  | ||||||
|  |  | ||||||
| Building and using in-tree datapath modules requires some level of devel |  | ||||||
| abilities to proceed.  You are expected to configure build options and build |  | ||||||
| the code on your own |  | ||||||
|  |  | ||||||
| E.g. pair openvswitch userspace with in-tree datapath module |  | ||||||
|  |  | ||||||
| 	CONFIG_DEVEL=y |  | ||||||
| 	CONFIG_PACKAGE_openvswitch=y |  | ||||||
| 	# CONFIG_PACKAGE_kmod-openvswitch is not set |  | ||||||
| 	CONFIG_PACKAGE_kmod-openvswitch-intree=y |  | ||||||
|  |  | ||||||
| E.g. replace in-tree datapath module with upstream version |  | ||||||
|  |  | ||||||
| 	opkg remove --force-depends kmod-openvswitch-intree |  | ||||||
| 	opkg install kmod-openvswitch |  | ||||||
| 	ovs-ctl force-reload-kmod |  | ||||||
|  |  | ||||||
| # UCI configuration options |  | ||||||
|  |  | ||||||
| There are 5 config section types in package openvswitch: |  | ||||||
| ovs ovn_northd, ovn_controller & ovs_bridge. |  | ||||||
|  |  | ||||||
| Each of these supports a disabled option, which should be  |  | ||||||
| set to 0 to launch the respective daemons. |  | ||||||
|  |  | ||||||
| The ovs section section also supports the options below, to configure a set of |  | ||||||
| SSL CA, certificate and private key. After adding these to Open vSwitch, you |  | ||||||
| may specify ssl: connection methods for e.g. the OpenFlow controller. Note that |  | ||||||
| Open vSwitch only reads these files during startup, so it needs to be restarted |  | ||||||
| after adding or changing these options. |  | ||||||
|  |  | ||||||
| | Name     | Type    | Required | Default | Description                       | |  | ||||||
| |----------|---------|----------|---------|-----------------------------------| |  | ||||||
| | disabled | boolean | no       | 0       | If set to 1, do not configure SSL | |  | ||||||
| | ca       | string  | no       | (none)  | Path to CA certificate            | |  | ||||||
| | cert     | string  | no       | (none)  | Path to certificate               | |  | ||||||
| | key      | string  | no       | (none)  | Path to private key               | |  | ||||||
|  |  | ||||||
| The ovs_bridge section also supports the options below, |  | ||||||
| for initialising a virtual bridge with an OpenFlow controller. |  | ||||||
|  |  | ||||||
| | Name          | Type    | Required | Default                        | Description                                                | |  | ||||||
| |---------------|---------|----------|--------------------------------|------------------------------------------------------------| |  | ||||||
| | disabled      | boolean | no       | 0                              | If set to true, disable initialisation of the named bridge | |  | ||||||
| | name          | string  | no       | Inherits UCI config block name | The name of the switch in the OVS daemon                   | |  | ||||||
| | controller    | string  | no       | (none)                         | The endpoint of an OpenFlow controller for this bridge     | |  | ||||||
| | datapath_id   | string  | no       | (none)                         | The OpenFlow datapath ID for this bridge                   | |  | ||||||
| | datapath_desc | string  | no       | (none)                         | The OpenFlow datapath description for this bridge          | |  | ||||||
| | fail_mode     | string  | no       | standalone                     | The bridge failure mode                                    | |  | ||||||
|  |  | ||||||
| The ovs_port section can be used to add ports to a bridge. It supports the options below. |  | ||||||
|  |  | ||||||
| | Name     | Type    | Required | Default | Description |  | ||||||
| | ---------|---------|----------|---------|------------------------------------------------| |  | ||||||
| | disabled | boolean | no       | 0       | If set to 1, do not add the port to the bridge | |  | ||||||
| | bridge   | string  | yes      | (none)  | Name of the bridge to add the port to          | |  | ||||||
| | port     | string  | yes      | (none)  | Name of the port to add to the bridge          | |  | ||||||
| | ofport   | integer | no       | (none)  | OpenFlow port number to be used by the port    | |  | ||||||
| | tag      | integer | no       | (none)  | 802.1Q VLAN tag to set on the port             | |  | ||||||
| | type     | string  | no       | (none)  | Port type, e.g. internal, erspan, type, ...    | |  | ||||||
| @@ -1,27 +0,0 @@ | |||||||
| config ovs ovs |  | ||||||
| 	option disabled 1 |  | ||||||
| 	option ca '/etc/openvswitch/example_ca.crt' |  | ||||||
| 	option cert '/etc/openvswitch/example_cert.crt' |  | ||||||
| 	option key '/etc/openvswitch/example_key.crt' |  | ||||||
|  |  | ||||||
| config ovn_northd north |  | ||||||
| 	option disabled 1 |  | ||||||
|  |  | ||||||
| config ovn_controller controller |  | ||||||
| 	option disabled 1 |  | ||||||
|  |  | ||||||
| config ovs_bridge |  | ||||||
| 	option disabled 1 |  | ||||||
| 	option name 'my-bridge' |  | ||||||
| 	option controller 'tcp:192.168.0.1' |  | ||||||
| 	option datapath_desc '' |  | ||||||
| 	option datapath_id '' |  | ||||||
| 	option fail_mode 'standalone' |  | ||||||
|  |  | ||||||
| config ovs_port |  | ||||||
| 	option disabled 1 |  | ||||||
| 	option bridge 'my-bridge' |  | ||||||
| 	option port 'ovs-port1' |  | ||||||
| 	option ofport '1' |  | ||||||
| 	option tag '123' |  | ||||||
| 	option type 'internal' |  | ||||||
| @@ -1,281 +0,0 @@ | |||||||
| #!/bin/sh /etc/rc.common |  | ||||||
| # Copyright (C) 2013 Julius Schulz-Zander <julius@net.t-labs.tu-berlin.de> |  | ||||||
| # Copyright (C) 2014-2017 OpenWrt.org |  | ||||||
| # Copyright (C) 2018 Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| # Copyright (C) 2021 Felix Fietkau <nbd@nbd.name> |  | ||||||
|  |  | ||||||
| . /lib/functions/procd.sh |  | ||||||
| START=15 |  | ||||||
|  |  | ||||||
| basescript=$(readlink "$initscript") |  | ||||||
|  |  | ||||||
| ovs_ctl="/usr/share/openvswitch/scripts/ovs-ctl"; [ -x "$ovs_ctl" ] || ovs_ctl=: |  | ||||||
| ovn_ctl="/usr/share/ovn/scripts/ovn-ctl"; [ -x "$ovn_ctl" ] || ovn_ctl=: |  | ||||||
|  |  | ||||||
| extra_command "status" "Get status information" |  | ||||||
|  |  | ||||||
| service_triggers() { |  | ||||||
| 	procd_add_reload_trigger openvswitch |  | ||||||
| } |  | ||||||
|  |  | ||||||
| init_triggers() { |  | ||||||
| 	procd_open_service "$(basename ${basescript:-$initscript})" "$initscript" |  | ||||||
| 	procd_close_service set |  | ||||||
| } |  | ||||||
|  |  | ||||||
| start() { |  | ||||||
| 	init_triggers |  | ||||||
| 	ovs_action start "$@" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| reload() { |  | ||||||
| 	start |  | ||||||
| } |  | ||||||
|  |  | ||||||
| running() { |  | ||||||
| 	return 0 |  | ||||||
| } |  | ||||||
|  |  | ||||||
| stop() { |  | ||||||
| 	procd_kill "$(basename ${basescript:-$initscript})" |  | ||||||
| 	ovs_action stop "$@" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| restart() { |  | ||||||
| 	init_triggers |  | ||||||
| 	ovs_action restart "$@" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| status() { |  | ||||||
| 	ovs_action status "$@" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_action_cfgs= |  | ||||||
| ovs_action() { |  | ||||||
| 	local action="$1"; shift |  | ||||||
| 	local cfgtype |  | ||||||
|  |  | ||||||
| 	ovs_action_cfgs="$*" |  | ||||||
| 	config_load openvswitch |  | ||||||
| 	for cfgtype in ovs ovn_northd ovn_controller; do |  | ||||||
| 		config_foreach "ovs_xx" "$cfgtype" "$action" "$cfgtype" |  | ||||||
| 	done |  | ||||||
|  |  | ||||||
| 	case "$action" in |  | ||||||
| 		restart|start) |  | ||||||
| 			config_foreach ovs_bridge_init "ovs_bridge" |  | ||||||
| 			;; |  | ||||||
| 	esac |  | ||||||
|  |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_xx() { |  | ||||||
| 	local cfg="$1" |  | ||||||
| 	local action="$2" |  | ||||||
| 	local cfgtype="$3" |  | ||||||
| 	local disabled |  | ||||||
|  |  | ||||||
| 	if [ -n "$ovs_action_cfgs" ] && ! list_contains "ovs_action_cfgs" "$cfg"; then |  | ||||||
| 		return |  | ||||||
| 	fi |  | ||||||
| 	case "$action" in |  | ||||||
| 		status|stop) ;; |  | ||||||
| 		*) |  | ||||||
| 			config_get_bool disabled "$cfg" disabled 0 |  | ||||||
| 			[ "$disabled" == "0" ] || return |  | ||||||
| 			;; |  | ||||||
| 	esac |  | ||||||
|  |  | ||||||
| 	case "$cfgtype" in |  | ||||||
| 		ovs) |  | ||||||
| 			"$ovs_ctl" "$action" \ |  | ||||||
| 				--system-id=random 1000>&- |  | ||||||
| 			ovs_set_ssl |  | ||||||
| 			;; |  | ||||||
| 		ovn_*) |  | ||||||
| 			"$ovn_ctl" "${action}_${cfgtype#ovn_}" |  | ||||||
| 			;; |  | ||||||
| 	esac |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_parse_port() { |  | ||||||
| 	case "$1" in |  | ||||||
| 		*:*) |  | ||||||
| 			port="${1%%:*}" |  | ||||||
| 			type="${1#*:}" |  | ||||||
| 		;; |  | ||||||
| 		*) |  | ||||||
| 			port="$1" |  | ||||||
| 			type="" |  | ||||||
| 		;; |  | ||||||
| 	esac |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_port_add() { |  | ||||||
| 	[ -n "$1" ] || return |  | ||||||
|  |  | ||||||
| 	ovs_bridge_parse_port "$1" |  | ||||||
| 	cur_type="$(ovs-vsctl get interface "$port" type 2>/dev/null)" |  | ||||||
| 	[ "$?" = 0 ] && { |  | ||||||
| 		[ "$type" = "$cur_type" ] || ovs-vsctl del-port "$port" |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	ovs-vsctl --may-exist add-port "$name" "$port" ${type:+ -- set interface "$port" type="$type"} |  | ||||||
| 	ovs_bridge_port_up "$port" |  | ||||||
| 	__port_list="$__port_list ${port} " |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_port_add_complex() { |  | ||||||
| 	local cfg="$1" |  | ||||||
| 	local cur_bridge="$2" |  | ||||||
|  |  | ||||||
| 	local bridge disabled ofport port tag type |  | ||||||
| 	local cur_tag cur_type del_port |  | ||||||
|  |  | ||||||
| 	config_get_bool disabled "$cfg" disabled 0 |  | ||||||
| 	[ "$disabled" = "0" ] || return |  | ||||||
|  |  | ||||||
| 	config_get bridge "$cfg" bridge |  | ||||||
| 	[ "$bridge" = "$cur_bridge" ] || return |  | ||||||
| 	ovs-vsctl br-exists "$bridge" || return |  | ||||||
|  |  | ||||||
| 	config_get port "$cfg" port |  | ||||||
| 	[ -n "$port" ] || return |  | ||||||
|  |  | ||||||
| 	config_get ofport "$cfg" ofport |  | ||||||
|  |  | ||||||
| 	config_get tag "$cfg" tag |  | ||||||
| 	if [ -n "$tag" ]; then |  | ||||||
| 		if cur_tag="$(ovs-vsctl get port "$port" tag 2>/dev/null)"; then |  | ||||||
| 			[ "$tag" = "$cur_tag" ] || del_port=1 |  | ||||||
| 		fi |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	config_get type "$cfg" type |  | ||||||
| 	if [ -n "$type" ]; then |  | ||||||
| 		if cur_type="$(ovs-vsctl get interface "$port" type 2>/dev/null)"; then |  | ||||||
| 			[ "$type" = "$cur_type" ] || del_port=1 |  | ||||||
| 		fi |  | ||||||
| 	fi |  | ||||||
|  |  | ||||||
| 	[ "${del_port:-0}" -eq 1 ] && ovs-vsctl --if-exists del-port "$bridge" "$port" |  | ||||||
|  |  | ||||||
| 	ovs-vsctl --may-exist add-port "$bridge" "$port" ${tag:+tag="$tag"} \ |  | ||||||
| 		${ofport:+ -- set interface "$port" ofport_request="$ofport"} \ |  | ||||||
| 		${type:+ -- set interface "$port" type="$type"} |  | ||||||
| 	ovs_bridge_port_up "$port" |  | ||||||
| 	__port_list="$__port_list ${port} " |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_port_cleanup() { |  | ||||||
| 	for port in `ovs-vsctl list-ports "$name"`; do |  | ||||||
| 		case "$__port_list" in |  | ||||||
| 			*" $port "*);; |  | ||||||
| 			*) ovs-vsctl del-port "$port";; |  | ||||||
| 		esac |  | ||||||
| 	done |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_port_up() { |  | ||||||
| 	local port="$1" |  | ||||||
|  |  | ||||||
| 	ip link set dev "$port" up |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_validate_datapath_id() { |  | ||||||
| 	local dpid="$1" |  | ||||||
|  |  | ||||||
| 	if expr "$dpid" : '[[:xdigit:]]\{16\}$' > /dev/null; then |  | ||||||
| 		return 0 |  | ||||||
| 	elif expr "$dpid" : '0x[[:xdigit:]]\{1,16\}$' > /dev/null; then |  | ||||||
| 		return 0 |  | ||||||
| 	else |  | ||||||
| 		logger -t openvswitch "invalid datapath_id: $dpid" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_validate_datapath_desc() { |  | ||||||
| 	local dpdesc="$1" |  | ||||||
|  |  | ||||||
| 	if [ "$(echo $dpdesc | wc -c)" -le 255 ]; then |  | ||||||
| 		return 0 |  | ||||||
| 	else |  | ||||||
| 		logger -t openvswitch "invalid datapath_desc: $dpdesc" |  | ||||||
| 		return 1 |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_validate_fail_mode() { |  | ||||||
| 	local fail_mode="$1" |  | ||||||
|  |  | ||||||
| 	case "$fail_mode" in |  | ||||||
| 		secure|standalone) |  | ||||||
| 			return 0 |  | ||||||
| 			;; |  | ||||||
| 		*) |  | ||||||
| 			logger -t openvswitch "invalid fail_mode: $fail_mode" |  | ||||||
| 			return 1 |  | ||||||
| 			;; |  | ||||||
| 	esac |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_bridge_init() { |  | ||||||
| 	local cfg="$1" |  | ||||||
|  |  | ||||||
| 	local disabled |  | ||||||
| 	local name |  | ||||||
| 	local controller |  | ||||||
| 	local datapath_id |  | ||||||
|  |  | ||||||
| 	config_get_bool disabled "$cfg" disabled 0 |  | ||||||
| 	[ "$disabled" == "0" ] || return |  | ||||||
|  |  | ||||||
| 	config_get name "$cfg" name $cfg |  | ||||||
| 	ovs-vsctl --may-exist add-br "$name" |  | ||||||
|  |  | ||||||
| 	config_get datapath_id "$cfg" datapath_id |  | ||||||
| 	[ -n "$datapath_id" ] && { |  | ||||||
| 		ovs_bridge_validate_datapath_id "$datapath_id" && { |  | ||||||
| 			ovs-vsctl --if-exists set bridge "$name" other-config:datapath-id="$datapath_id" |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	config_get datapath_desc "$cfg" datapath_desc |  | ||||||
| 	[ -n "$datapath_desc" ] && { |  | ||||||
| 		ovs_bridge_validate_datapath_desc "$datapath_desc" && { |  | ||||||
| 			ovs-vsctl --if-exists set bridge "$name" other-config:dp-desc="$datapath_desc" |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	config_get fail_mode "$cfg" fail_mode |  | ||||||
| 	[ -n "$fail_mode" ] && { |  | ||||||
| 		ovs_bridge_validate_fail_mode "$fail_mode" && { |  | ||||||
| 			ovs-vsctl set-fail-mode "$name" "$fail_mode" 2> /dev/null |  | ||||||
| 		} || { |  | ||||||
| 			ovs-vsctl del-fail-mode "$name" 2> /dev/null |  | ||||||
| 		} |  | ||||||
| 	} || { |  | ||||||
| 		ovs-vsctl del-fail-mode "$name" 2> /dev/null |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	config_list_foreach "$cfg" "ports" ovs_bridge_port_add |  | ||||||
| 	config_foreach ovs_bridge_port_add_complex ovs_port "$name" |  | ||||||
| 	config_get_bool drop "$cfg" "drop_unknown_ports" 0 |  | ||||||
| 	[ "$drop" == 1 ] && ovs_bridge_port_cleanup |  | ||||||
|  |  | ||||||
| 	config_get controller "$cfg" controller |  | ||||||
| 	[ -n "$controller" ] && \ |  | ||||||
| 		ovs-vsctl set-controller "$name" "$controller" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ovs_set_ssl() { |  | ||||||
| 	local ca="$(uci -q get openvswitch.ovs.ca)" |  | ||||||
| 	[ -f "$ca" ] || return |  | ||||||
| 	local cert="$(uci get openvswitch.ovs.cert)" |  | ||||||
| 	[ -f "$cert" ] || return |  | ||||||
| 	local key="$(uci get openvswitch.ovs.key)" |  | ||||||
| 	[ -f "$key" ] || return |  | ||||||
|  |  | ||||||
| 	ovs-vsctl set-ssl "$key" "$cert" "$ca" |  | ||||||
| } |  | ||||||
| @@ -1,9 +0,0 @@ | |||||||
| #!/bin/sh |  | ||||||
|  |  | ||||||
| s=/usr/share/openvswitch/scripts |  | ||||||
| case "$0" in |  | ||||||
| 	*ovs-ctl) "$s/ovs-ctl" "$@" ;; |  | ||||||
| 	*ovs-kmod-ctl) "$s/ovs-kmod-ctl" "$@" ;; |  | ||||||
| 	*ovn-ctl) "/usr/share/ovn/scripts/ovn-ctl" "$@" ;; |  | ||||||
| 	*) exit 1;; |  | ||||||
| esac |  | ||||||
| @@ -1,36 +0,0 @@ | |||||||
| # Copyright (C) 2020 Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| # |  | ||||||
| # This is free software, licensed under the GNU General Public License v2. |  | ||||||
| # See /LICENSE for more information. |  | ||||||
|  |  | ||||||
| # Versions |  | ||||||
|  |  | ||||||
| ovs_version:=2.15.1 |  | ||||||
| ovs_builddir=$(KERNEL_BUILD_DIR)/openvswitch-$(ovs_version) |  | ||||||
|  |  | ||||||
| # Shared vars, macros |  | ||||||
|  |  | ||||||
| ovs_packages:= |  | ||||||
|  |  | ||||||
| ovs_package_name=$(if $(filter openvswitch,$(1)),openvswitch,openvswitch-$(1)) |  | ||||||
| define OvsPackageTemplate |  | ||||||
|   define Package/$(call ovs_package_name,$(1)) |  | ||||||
|      SECTION:=net |  | ||||||
|      SUBMENU:=Open vSwitch |  | ||||||
|      CATEGORY:=Network |  | ||||||
|      URL:=https://www.openvswitch.org |  | ||||||
|      TITLE:=$(ovs_$(1)_title) |  | ||||||
|      HIDDEN:=$(ovs_$(1)_hidden) |  | ||||||
|      DEPENDS:=$(ovs_$(1)_depends) |  | ||||||
|   endef |  | ||||||
|  |  | ||||||
|   define Package/$(call ovs_package_name,$(1))/install |  | ||||||
| 	$(foreach f,$(ovs_$(1)_files), |  | ||||||
| 		$(INSTALL_DIR) $$(1)/$(dir $(f)) |  | ||||||
| 		$(CP) $(PKG_INSTALL_DIR)/$(f) $$(1)/$(dir $(f)) |  | ||||||
| 	) |  | ||||||
| 	$(ovs_$(1)_install) |  | ||||||
|   endef |  | ||||||
|  |  | ||||||
|   ovs_packages+=$(call ovs_package_name,$(1)) |  | ||||||
| endef |  | ||||||
| @@ -1,35 +0,0 @@ | |||||||
| From 974dc36a87274d7bae13e7dddd3364fecf5b3e7c Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Helmut Schaa <helmut.schaa@googlemail.com> |  | ||||||
| Date: Wed, 8 Jan 2014 13:48:49 +0100 |  | ||||||
| Subject: [PATCH] netdev-linux: Let interface flag survive internal port setup |  | ||||||
|  |  | ||||||
| Due to a race condition when bringing up an internal port on Linux |  | ||||||
| some interface flags (e.g. IFF_MULTICAST) are falsely reset. This |  | ||||||
| happens because netlink events may be processed after the according |  | ||||||
| netdev has been brought up (which sets interface flags). |  | ||||||
|  |  | ||||||
| Fix this by reading the interface flags just before updating them |  | ||||||
| if they have not been updated by from the kernel yet. |  | ||||||
|  |  | ||||||
| Signed-off-by: Helmut Schaa <helmut.schaa@googlemail.com> |  | ||||||
| --- |  | ||||||
|  lib/netdev-linux.c | 8 +++++++- |  | ||||||
|  1 file changed, 7 insertions(+), 1 deletion(-) |  | ||||||
|  |  | ||||||
| --- a/lib/netdev-linux.c |  | ||||||
| +++ b/lib/netdev-linux.c |  | ||||||
| @@ -3469,7 +3469,13 @@ update_flags(struct netdev_linux *netdev |  | ||||||
|      unsigned int old_flags, new_flags; |  | ||||||
|      int error = 0; |  | ||||||
|   |  | ||||||
| -    old_flags = netdev->ifi_flags; |  | ||||||
| +    if (!(netdev->cache_valid & VALID_DRVINFO)) { |  | ||||||
| +        /* Most likely the debvice flags are not in sync yet, fetch them now */ |  | ||||||
| +        get_flags(&netdev->up, &old_flags); |  | ||||||
| +    } else { |  | ||||||
| +        old_flags = netdev->ifi_flags; |  | ||||||
| +    } |  | ||||||
| + |  | ||||||
|      *old_flagsp = iff_to_nd_flags(old_flags); |  | ||||||
|      new_flags = (old_flags & ~nd_to_iff_flags(off)) | nd_to_iff_flags(on); |  | ||||||
|      if (new_flags != old_flags) { |  | ||||||
| @@ -1,33 +0,0 @@ | |||||||
| From 54484e79aca0981ebc42ddc68487e6531da9b59d Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| Date: Fri, 20 Mar 2020 15:11:31 +0800 |  | ||||||
| Subject: [PATCH] python: separate host/target python for cross-compile |  | ||||||
|  |  | ||||||
| Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| --- |  | ||||||
|  Makefile.am       | 2 +- |  | ||||||
|  m4/openvswitch.m4 | 2 ++ |  | ||||||
|  2 files changed, 3 insertions(+), 1 deletion(-) |  | ||||||
|  |  | ||||||
| --- a/Makefile.am |  | ||||||
| +++ b/Makefile.am |  | ||||||
| @@ -60,7 +60,7 @@ endif |  | ||||||
|  # foo/__init__.pyc will cause Python to ignore foo.py. |  | ||||||
|  run_python = \ |  | ||||||
|  	PYTHONPATH=$(top_srcdir)/python$(psep)$$PYTHONPATH \ |  | ||||||
| -	PYTHONDONTWRITEBYTECODE=yes $(PYTHON3) |  | ||||||
| +	PYTHONDONTWRITEBYTECODE=yes $(PYTHON3_HOST) |  | ||||||
|   |  | ||||||
|  ALL_LOCAL = |  | ||||||
|  BUILT_SOURCES = |  | ||||||
| --- a/m4/openvswitch.m4 |  | ||||||
| +++ b/m4/openvswitch.m4 |  | ||||||
| @@ -372,6 +372,8 @@ else: |  | ||||||
|       AC_MSG_ERROR([Python 3.4 or later is required but not found in $PATH, please install it or set $PYTHON3 to point to it]) |  | ||||||
|     fi |  | ||||||
|     AC_ARG_VAR([PYTHON3]) |  | ||||||
| +   PYTHON3_HOST=$ovs_cv_python3_host |  | ||||||
| +   AM_MISSING_PROG([PYTHON3_HOST], [python3]) |  | ||||||
|     PYTHON3=$ovs_cv_python3]) |  | ||||||
|   |  | ||||||
|  dnl Checks for flake8. |  | ||||||
| @@ -1,26 +0,0 @@ | |||||||
| From 444991b95ed25d58c3cd1646fa823620380b6ce6 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| Date: Wed, 14 Mar 2018 16:44:13 +0800 |  | ||||||
| Subject: [PATCH] ovs-lib: fix install_dir() |  | ||||||
|  |  | ||||||
| The command "install" is not available in OpenWrt by default |  | ||||||
|  |  | ||||||
| Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| --- |  | ||||||
|  utilities/ovs-lib.in | 5 ++++- |  | ||||||
|  1 file changed, 4 insertions(+), 1 deletion(-) |  | ||||||
|  |  | ||||||
| --- a/utilities/ovs-lib.in |  | ||||||
| +++ b/utilities/ovs-lib.in |  | ||||||
| @@ -159,7 +159,10 @@ install_dir () { |  | ||||||
|      [ "${OVS_USER##*:}" != "" ] && INSTALL_GROUP="${OVS_USER##*:}" |  | ||||||
|   |  | ||||||
|      if test ! -d "$DIR"; then |  | ||||||
| -        install -d -m "$INSTALL_MODE" -o "$INSTALL_USER" -g "$INSTALL_GROUP" "$DIR" |  | ||||||
| +        mkdir -p "$DIR" |  | ||||||
| +        chmod "$INSTALL_MODE" "$DIR" |  | ||||||
| +        chown "$INSTALL_USER" "$DIR" |  | ||||||
| +        chgrp "$INSTALL_GROUP" "$DIR" |  | ||||||
|          restorecon "$DIR" >/dev/null 2>&1 |  | ||||||
|      fi |  | ||||||
|  } |  | ||||||
| @@ -1,25 +0,0 @@ | |||||||
| From 31514742de07d595ac23c2b0abf0e092f8b26140 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Yousong Zhou <zhouyousong@yunionyun.com> |  | ||||||
| Date: Tue, 21 Aug 2018 13:02:21 +0000 |  | ||||||
| Subject: [PATCH] build: trim build |  | ||||||
|  |  | ||||||
| Signed-off-by: Yousong Zhou <zhouyousong@yunionyun.com> |  | ||||||
| --- |  | ||||||
|  Makefile.am | 2 -- |  | ||||||
|  1 file changed, 2 deletions(-) |  | ||||||
|  |  | ||||||
| --- a/Makefile.am |  | ||||||
| +++ b/Makefile.am |  | ||||||
| @@ -477,12 +477,10 @@ dist-docs: |  | ||||||
|  	VERSION=$(VERSION) MAKE='$(MAKE)' $(srcdir)/build-aux/dist-docs $(srcdir) $(docs) |  | ||||||
|  .PHONY: dist-docs |  | ||||||
|   |  | ||||||
| -include Documentation/automake.mk |  | ||||||
|  include m4/automake.mk |  | ||||||
|  include lib/automake.mk |  | ||||||
|  include ofproto/automake.mk |  | ||||||
|  include utilities/automake.mk |  | ||||||
| -include tests/automake.mk |  | ||||||
|  include include/automake.mk |  | ||||||
|  include third-party/automake.mk |  | ||||||
|  include debian/automake.mk |  | ||||||
| @@ -1,23 +0,0 @@ | |||||||
| From 1df5a0eaf78e93e21d21f1438afbe5fa8a37ea61 Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| Date: Tue, 26 May 2020 22:45:53 +0800 |  | ||||||
| Subject: [PATCH] datapath: allow passing additional $(OVS_KERNEL_MAKE_FLAGS) |  | ||||||
|  |  | ||||||
| This can be useful for passing args like -iremap for reproducible builds |  | ||||||
|  |  | ||||||
| Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| --- |  | ||||||
|  datapath/linux/Makefile.main.in | 2 +- |  | ||||||
|  1 file changed, 1 insertion(+), 1 deletion(-) |  | ||||||
|  |  | ||||||
| --- a/datapath/linux/Makefile.main.in |  | ||||||
| +++ b/datapath/linux/Makefile.main.in |  | ||||||
| @@ -68,7 +68,7 @@ ifeq (,$(wildcard $(CONFIG_FILE))) |  | ||||||
|  endif |  | ||||||
|   |  | ||||||
|  default: |  | ||||||
| -	$(MAKE) -C $(KSRC) $(if @KARCH@,ARCH=@KARCH@) M=$(builddir) modules |  | ||||||
| +	$(MAKE) -C $(KSRC) $(OVS_KERNEL_MAKE_FLAGS) $(if @KARCH@,ARCH=@KARCH@) M=$(builddir) modules |  | ||||||
|   |  | ||||||
|  modules_install: |  | ||||||
|  	$(MAKE) -C $(KSRC) $(if @KARCH@,ARCH=@KARCH@) M=$(builddir) modules_install |  | ||||||
| @@ -1,54 +0,0 @@ | |||||||
| From e81ccb671014db62bf622cd8f960d7930d27d9dc Mon Sep 17 00:00:00 2001 |  | ||||||
| From: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| Date: Wed, 29 Jul 2020 17:29:14 +0800 |  | ||||||
| Subject: [PATCH] build: only link libopenvswitch with libunwind, libunbound |  | ||||||
|  |  | ||||||
| Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com> |  | ||||||
| --- |  | ||||||
|  lib/automake.mk          | 2 ++ |  | ||||||
|  lib/libopenvswitch.pc.in | 2 +- |  | ||||||
|  m4/openvswitch.m4        | 6 ++++-- |  | ||||||
|  3 files changed, 7 insertions(+), 3 deletions(-) |  | ||||||
|  |  | ||||||
| --- a/lib/automake.mk |  | ||||||
| +++ b/lib/automake.mk |  | ||||||
| @@ -10,6 +10,8 @@ lib_LTLIBRARIES += lib/libopenvswitch.la |  | ||||||
|  lib_libopenvswitch_la_LIBADD = $(SSL_LIBS) |  | ||||||
|  lib_libopenvswitch_la_LIBADD += $(CAPNG_LDADD) |  | ||||||
|  lib_libopenvswitch_la_LIBADD += $(LIBBPF_LDADD) |  | ||||||
| +lib_libopenvswitch_la_LIBADD += $(LIBUNBOUND_LDADD) |  | ||||||
| +lib_libopenvswitch_la_LIBADD += $(LIBUNWIND_LDADD) |  | ||||||
|   |  | ||||||
|   |  | ||||||
|  if WIN32 |  | ||||||
| --- a/lib/libopenvswitch.pc.in |  | ||||||
| +++ b/lib/libopenvswitch.pc.in |  | ||||||
| @@ -7,5 +7,5 @@ Name: libopenvswitch |  | ||||||
|  Description: Open vSwitch library |  | ||||||
|  Version: @VERSION@ |  | ||||||
|  Libs: -L${libdir} -lopenvswitch |  | ||||||
| -Libs.private: @LIBS@ |  | ||||||
| +Libs.private: @LIBS@ @SSL_LIBS@ @CAPNG_LDADD@ @LIBBPF_LDADD@ @LIBUNBOUND_LDADD@ @LIBUNWIND_LDADD@ |  | ||||||
|  Cflags: -I${includedir}/openvswitch |  | ||||||
| --- a/m4/openvswitch.m4 |  | ||||||
| +++ b/m4/openvswitch.m4 |  | ||||||
| @@ -646,7 +646,8 @@ AC_DEFUN([OVS_CHECK_UNBOUND], |  | ||||||
|    [AC_CHECK_LIB(unbound, ub_ctx_create, [HAVE_UNBOUND=yes], [HAVE_UNBOUND=no]) |  | ||||||
|     if test "$HAVE_UNBOUND" = yes; then |  | ||||||
|       AC_DEFINE([HAVE_UNBOUND], [1], [Define to 1 if unbound is detected.]) |  | ||||||
| -     LIBS="$LIBS -lunbound" |  | ||||||
| +     LIBUNBOUND_LDADD="-lunbound" |  | ||||||
| +     AC_SUBST(LIBUNBOUND_LDADD) |  | ||||||
|     fi |  | ||||||
|     AM_CONDITIONAL([HAVE_UNBOUND], [test "$HAVE_UNBOUND" = yes]) |  | ||||||
|     AC_SUBST([HAVE_UNBOUND])]) |  | ||||||
| @@ -658,7 +659,8 @@ AC_DEFUN([OVS_CHECK_UNWIND], |  | ||||||
|     [HAVE_UNWIND=no]) |  | ||||||
|     if test "$HAVE_UNWIND" = yes; then |  | ||||||
|       AC_DEFINE([HAVE_UNWIND], [1], [Define to 1 if unwind is detected.]) |  | ||||||
| -     LIBS="$LIBS -lunwind" |  | ||||||
| +     LIBUNWIND_LDADD="-lunwind" |  | ||||||
| +     AC_SUBST(LIBUNWIND_LDADD) |  | ||||||
|     fi |  | ||||||
|     AM_CONDITIONAL([HAVE_UNWIND], [test "$HAVE_UNWIND" = yes]) |  | ||||||
|     AC_SUBST([HAVE_UNWIND])]) |  | ||||||
| @@ -1,40 +0,0 @@ | |||||||
| include $(TOPDIR)/rules.mk |  | ||||||
|  |  | ||||||
| PKG_NAME:=libJudy |  | ||||||
| PKG_VERSION:=1.0.5 |  | ||||||
| PKG_RELEASE:=1 |  | ||||||
|  |  | ||||||
| PKG_FIXUP=autoreconf |  | ||||||
| PKG_INSTALL:=1 |  | ||||||
|  |  | ||||||
| include $(INCLUDE_DIR)/package.mk |  | ||||||
|  |  | ||||||
| define Package/libJudy |  | ||||||
|   SECTION:=base |  | ||||||
|   CATEGORY:=Libraries |  | ||||||
|   DEFAULT:=y |  | ||||||
|   TITLE:=General purpose dynamic array |  | ||||||
|   URL:=http://judy.sourceforge.net/ |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| MAKE_FLAGS += \ |  | ||||||
| 	HOSTCC="$(HOSTCC)" \ |  | ||||||
| 	HOSTCCFLAGS="" |  | ||||||
|  |  | ||||||
| #define Build/Configure |  | ||||||
| #	$(call Build/Configure/Default,--prefix=/usr) |  | ||||||
| #endef |  | ||||||
|  |  | ||||||
| define Build/InstallDev |  | ||||||
| 	$(INSTALL_DIR) $(1)/usr/include |  | ||||||
| 	$(CP) $(PKG_INSTALL_DIR)/usr/include/Judy.h $(1)/usr/include/ |  | ||||||
| 	$(INSTALL_DIR) $(1)/usr/lib |  | ||||||
| 	$(CP) $(PKG_INSTALL_DIR)/usr/lib/libJudy.{a,so*} $(1)/usr/lib/ |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| define Package/libJudy/install |  | ||||||
| 	$(INSTALL_DIR) $(1)/usr/lib |  | ||||||
| 	$(CP) $(PKG_INSTALL_DIR)/usr/lib/libJudy.so.* $(1)/usr/lib/ |  | ||||||
| endef |  | ||||||
|  |  | ||||||
| $(eval $(call BuildPackage,libJudy)) |  | ||||||
| @@ -1,8 +0,0 @@ | |||||||
| Doug Baskinks  |  | ||||||
|      Owner and Main Author |  | ||||||
|  |  | ||||||
| Contributors:  |  | ||||||
|  |  | ||||||
| 	Troy Heber:  |  | ||||||
| 	    Repackaging  |  | ||||||
| 	    Project Administration |  | ||||||
| @@ -1,516 +0,0 @@ | |||||||
| Judy - C library functions for creating and accessing dynamic arrays |  | ||||||
| Copyright (C) 2004  Doug Baskins |  | ||||||
|  |  | ||||||
| This library is free software; you can redistribute it and/or modify |  | ||||||
| it under the terms of the GNU Lesser General Public License as |  | ||||||
| published by the Free Software Foundation; either version 2.1 of the |  | ||||||
| License, or (at your option) any later version. |  | ||||||
|  |  | ||||||
| This library is distributed in the hope that it will be useful, but |  | ||||||
| WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU |  | ||||||
| Lesser General Public License for more details. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 		  GNU LESSER GENERAL PUBLIC LICENSE |  | ||||||
| 		       Version 2.1, February 1999 |  | ||||||
|  |  | ||||||
|  Copyright (C) 1991, 1999 Free Software Foundation, Inc. |  | ||||||
|      59 Temple Place, Suite 330, Boston, MA  02111-1307  USA |  | ||||||
|  Everyone is permitted to copy and distribute verbatim copies |  | ||||||
|  of this license document, but changing it is not allowed. |  | ||||||
|  |  | ||||||
| [This is the first released version of the Lesser GPL.  It also counts |  | ||||||
|  as the successor of the GNU Library Public License, version 2, hence |  | ||||||
|  the version number 2.1.] |  | ||||||
|  |  | ||||||
| 			    Preamble |  | ||||||
|  |  | ||||||
|   The licenses for most software are designed to take away your |  | ||||||
| freedom to share and change it.  By contrast, the GNU General Public |  | ||||||
| Licenses are intended to guarantee your freedom to share and change |  | ||||||
| free software--to make sure the software is free for all its users. |  | ||||||
|  |  | ||||||
|   This license, the Lesser General Public License, applies to some |  | ||||||
| specially designated software packages--typically libraries--of the |  | ||||||
| Free Software Foundation and other authors who decide to use it.  You |  | ||||||
| can use it too, but we suggest you first think carefully about whether |  | ||||||
| this license or the ordinary General Public License is the better |  | ||||||
| strategy to use in any particular case, based on the explanations below. |  | ||||||
|  |  | ||||||
|   When we speak of free software, we are referring to freedom of use, |  | ||||||
| not price.  Our General Public Licenses are designed to make sure that |  | ||||||
| you have the freedom to distribute copies of free software (and charge |  | ||||||
| for this service if you wish); that you receive source code or can get |  | ||||||
| it if you want it; that you can change the software and use pieces of |  | ||||||
| it in new free programs; and that you are informed that you can do |  | ||||||
| these things. |  | ||||||
|  |  | ||||||
|   To protect your rights, we need to make restrictions that forbid |  | ||||||
| distributors to deny you these rights or to ask you to surrender these |  | ||||||
| rights.  These restrictions translate to certain responsibilities for |  | ||||||
| you if you distribute copies of the library or if you modify it. |  | ||||||
|  |  | ||||||
|   For example, if you distribute copies of the library, whether gratis |  | ||||||
| or for a fee, you must give the recipients all the rights that we gave |  | ||||||
| you.  You must make sure that they, too, receive or can get the source |  | ||||||
| code.  If you link other code with the library, you must provide |  | ||||||
| complete object files to the recipients, so that they can relink them |  | ||||||
| with the library after making changes to the library and recompiling |  | ||||||
| it.  And you must show them these terms so they know their rights. |  | ||||||
|  |  | ||||||
|   We protect your rights with a two-step method: (1) we copyright the |  | ||||||
| library, and (2) we offer you this license, which gives you legal |  | ||||||
| permission to copy, distribute and/or modify the library. |  | ||||||
|  |  | ||||||
|   To protect each distributor, we want to make it very clear that |  | ||||||
| there is no warranty for the free library.  Also, if the library is |  | ||||||
| modified by someone else and passed on, the recipients should know |  | ||||||
| that what they have is not the original version, so that the original |  | ||||||
| author's reputation will not be affected by problems that might be |  | ||||||
| introduced by others. |  | ||||||
|  |  | ||||||
|   Finally, software patents pose a constant threat to the existence of |  | ||||||
| any free program.  We wish to make sure that a company cannot |  | ||||||
| effectively restrict the users of a free program by obtaining a |  | ||||||
| restrictive license from a patent holder.  Therefore, we insist that |  | ||||||
| any patent license obtained for a version of the library must be |  | ||||||
| consistent with the full freedom of use specified in this license. |  | ||||||
|  |  | ||||||
|   Most GNU software, including some libraries, is covered by the |  | ||||||
| ordinary GNU General Public License.  This license, the GNU Lesser |  | ||||||
| General Public License, applies to certain designated libraries, and |  | ||||||
| is quite different from the ordinary General Public License.  We use |  | ||||||
| this license for certain libraries in order to permit linking those |  | ||||||
| libraries into non-free programs. |  | ||||||
|  |  | ||||||
|   When a program is linked with a library, whether statically or using |  | ||||||
| a shared library, the combination of the two is legally speaking a |  | ||||||
| combined work, a derivative of the original library.  The ordinary |  | ||||||
| General Public License therefore permits such linking only if the |  | ||||||
| entire combination fits its criteria of freedom.  The Lesser General |  | ||||||
| Public License permits more lax criteria for linking other code with |  | ||||||
| the library. |  | ||||||
|  |  | ||||||
|   We call this license the "Lesser" General Public License because it |  | ||||||
| does Less to protect the user's freedom than the ordinary General |  | ||||||
| Public License.  It also provides other free software developers Less |  | ||||||
| of an advantage over competing non-free programs.  These disadvantages |  | ||||||
| are the reason we use the ordinary General Public License for many |  | ||||||
| libraries.  However, the Lesser license provides advantages in certain |  | ||||||
| special circumstances. |  | ||||||
|  |  | ||||||
|   For example, on rare occasions, there may be a special need to |  | ||||||
| encourage the widest possible use of a certain library, so that it becomes |  | ||||||
| a de-facto standard.  To achieve this, non-free programs must be |  | ||||||
| allowed to use the library.  A more frequent case is that a free |  | ||||||
| library does the same job as widely used non-free libraries.  In this |  | ||||||
| case, there is little to gain by limiting the free library to free |  | ||||||
| software only, so we use the Lesser General Public License. |  | ||||||
|  |  | ||||||
|   In other cases, permission to use a particular library in non-free |  | ||||||
| programs enables a greater number of people to use a large body of |  | ||||||
| free software.  For example, permission to use the GNU C Library in |  | ||||||
| non-free programs enables many more people to use the whole GNU |  | ||||||
| operating system, as well as its variant, the GNU/Linux operating |  | ||||||
| system. |  | ||||||
|  |  | ||||||
|   Although the Lesser General Public License is Less protective of the |  | ||||||
| users' freedom, it does ensure that the user of a program that is |  | ||||||
| linked with the Library has the freedom and the wherewithal to run |  | ||||||
| that program using a modified version of the Library. |  | ||||||
|  |  | ||||||
|   The precise terms and conditions for copying, distribution and |  | ||||||
| modification follow.  Pay close attention to the difference between a |  | ||||||
| "work based on the library" and a "work that uses the library".  The |  | ||||||
| former contains code derived from the library, whereas the latter must |  | ||||||
| be combined with the library in order to run. |  | ||||||
|  |  | ||||||
| 		  GNU LESSER GENERAL PUBLIC LICENSE |  | ||||||
|    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION |  | ||||||
|  |  | ||||||
|   0. This License Agreement applies to any software library or other |  | ||||||
| program which contains a notice placed by the copyright holder or |  | ||||||
| other authorized party saying it may be distributed under the terms of |  | ||||||
| this Lesser General Public License (also called "this License"). |  | ||||||
| Each licensee is addressed as "you". |  | ||||||
|  |  | ||||||
|   A "library" means a collection of software functions and/or data |  | ||||||
| prepared so as to be conveniently linked with application programs |  | ||||||
| (which use some of those functions and data) to form executables. |  | ||||||
|  |  | ||||||
|   The "Library", below, refers to any such software library or work |  | ||||||
| which has been distributed under these terms.  A "work based on the |  | ||||||
| Library" means either the Library or any derivative work under |  | ||||||
| copyright law: that is to say, a work containing the Library or a |  | ||||||
| portion of it, either verbatim or with modifications and/or translated |  | ||||||
| straightforwardly into another language.  (Hereinafter, translation is |  | ||||||
| included without limitation in the term "modification".) |  | ||||||
|  |  | ||||||
|   "Source code" for a work means the preferred form of the work for |  | ||||||
| making modifications to it.  For a library, complete source code means |  | ||||||
| all the source code for all modules it contains, plus any associated |  | ||||||
| interface definition files, plus the scripts used to control compilation |  | ||||||
| and installation of the library. |  | ||||||
|  |  | ||||||
|   Activities other than copying, distribution and modification are not |  | ||||||
| covered by this License; they are outside its scope.  The act of |  | ||||||
| running a program using the Library is not restricted, and output from |  | ||||||
| such a program is covered only if its contents constitute a work based |  | ||||||
| on the Library (independent of the use of the Library in a tool for |  | ||||||
| writing it).  Whether that is true depends on what the Library does |  | ||||||
| and what the program that uses the Library does. |  | ||||||
|  |  | ||||||
|   1. You may copy and distribute verbatim copies of the Library's |  | ||||||
| complete source code as you receive it, in any medium, provided that |  | ||||||
| you conspicuously and appropriately publish on each copy an |  | ||||||
| appropriate copyright notice and disclaimer of warranty; keep intact |  | ||||||
| all the notices that refer to this License and to the absence of any |  | ||||||
| warranty; and distribute a copy of this License along with the |  | ||||||
| Library. |  | ||||||
|  |  | ||||||
|   You may charge a fee for the physical act of transferring a copy, |  | ||||||
| and you may at your option offer warranty protection in exchange for a |  | ||||||
| fee. |  | ||||||
|  |  | ||||||
|   2. You may modify your copy or copies of the Library or any portion |  | ||||||
| of it, thus forming a work based on the Library, and copy and |  | ||||||
| distribute such modifications or work under the terms of Section 1 |  | ||||||
| above, provided that you also meet all of these conditions: |  | ||||||
|  |  | ||||||
|     a) The modified work must itself be a software library. |  | ||||||
|  |  | ||||||
|     b) You must cause the files modified to carry prominent notices |  | ||||||
|     stating that you changed the files and the date of any change. |  | ||||||
|  |  | ||||||
|     c) You must cause the whole of the work to be licensed at no |  | ||||||
|     charge to all third parties under the terms of this License. |  | ||||||
|  |  | ||||||
|     d) If a facility in the modified Library refers to a function or a |  | ||||||
|     table of data to be supplied by an application program that uses |  | ||||||
|     the facility, other than as an argument passed when the facility |  | ||||||
|     is invoked, then you must make a good faith effort to ensure that, |  | ||||||
|     in the event an application does not supply such function or |  | ||||||
|     table, the facility still operates, and performs whatever part of |  | ||||||
|     its purpose remains meaningful. |  | ||||||
|  |  | ||||||
|     (For example, a function in a library to compute square roots has |  | ||||||
|     a purpose that is entirely well-defined independent of the |  | ||||||
|     application.  Therefore, Subsection 2d requires that any |  | ||||||
|     application-supplied function or table used by this function must |  | ||||||
|     be optional: if the application does not supply it, the square |  | ||||||
|     root function must still compute square roots.) |  | ||||||
|  |  | ||||||
| These requirements apply to the modified work as a whole.  If |  | ||||||
| identifiable sections of that work are not derived from the Library, |  | ||||||
| and can be reasonably considered independent and separate works in |  | ||||||
| themselves, then this License, and its terms, do not apply to those |  | ||||||
| sections when you distribute them as separate works.  But when you |  | ||||||
| distribute the same sections as part of a whole which is a work based |  | ||||||
| on the Library, the distribution of the whole must be on the terms of |  | ||||||
| this License, whose permissions for other licensees extend to the |  | ||||||
| entire whole, and thus to each and every part regardless of who wrote |  | ||||||
| it. |  | ||||||
|  |  | ||||||
| Thus, it is not the intent of this section to claim rights or contest |  | ||||||
| your rights to work written entirely by you; rather, the intent is to |  | ||||||
| exercise the right to control the distribution of derivative or |  | ||||||
| collective works based on the Library. |  | ||||||
|  |  | ||||||
| In addition, mere aggregation of another work not based on the Library |  | ||||||
| with the Library (or with a work based on the Library) on a volume of |  | ||||||
| a storage or distribution medium does not bring the other work under |  | ||||||
| the scope of this License. |  | ||||||
|  |  | ||||||
|   3. You may opt to apply the terms of the ordinary GNU General Public |  | ||||||
| License instead of this License to a given copy of the Library.  To do |  | ||||||
| this, you must alter all the notices that refer to this License, so |  | ||||||
| that they refer to the ordinary GNU General Public License, version 2, |  | ||||||
| instead of to this License.  (If a newer version than version 2 of the |  | ||||||
| ordinary GNU General Public License has appeared, then you can specify |  | ||||||
| that version instead if you wish.)  Do not make any other change in |  | ||||||
| these notices. |  | ||||||
|  |  | ||||||
|   Once this change is made in a given copy, it is irreversible for |  | ||||||
| that copy, so the ordinary GNU General Public License applies to all |  | ||||||
| subsequent copies and derivative works made from that copy. |  | ||||||
|  |  | ||||||
|   This option is useful when you wish to copy part of the code of |  | ||||||
| the Library into a program that is not a library. |  | ||||||
|  |  | ||||||
|   4. You may copy and distribute the Library (or a portion or |  | ||||||
| derivative of it, under Section 2) in object code or executable form |  | ||||||
| under the terms of Sections 1 and 2 above provided that you accompany |  | ||||||
| it with the complete corresponding machine-readable source code, which |  | ||||||
| must be distributed under the terms of Sections 1 and 2 above on a |  | ||||||
| medium customarily used for software interchange. |  | ||||||
|  |  | ||||||
|   If distribution of object code is made by offering access to copy |  | ||||||
| from a designated place, then offering equivalent access to copy the |  | ||||||
| source code from the same place satisfies the requirement to |  | ||||||
| distribute the source code, even though third parties are not |  | ||||||
| compelled to copy the source along with the object code. |  | ||||||
|  |  | ||||||
|   5. A program that contains no derivative of any portion of the |  | ||||||
| Library, but is designed to work with the Library by being compiled or |  | ||||||
| linked with it, is called a "work that uses the Library".  Such a |  | ||||||
| work, in isolation, is not a derivative work of the Library, and |  | ||||||
| therefore falls outside the scope of this License. |  | ||||||
|  |  | ||||||
|   However, linking a "work that uses the Library" with the Library |  | ||||||
| creates an executable that is a derivative of the Library (because it |  | ||||||
| contains portions of the Library), rather than a "work that uses the |  | ||||||
| library".  The executable is therefore covered by this License. |  | ||||||
| Section 6 states terms for distribution of such executables. |  | ||||||
|  |  | ||||||
|   When a "work that uses the Library" uses material from a header file |  | ||||||
| that is part of the Library, the object code for the work may be a |  | ||||||
| derivative work of the Library even though the source code is not. |  | ||||||
| Whether this is true is especially significant if the work can be |  | ||||||
| linked without the Library, or if the work is itself a library.  The |  | ||||||
| threshold for this to be true is not precisely defined by law. |  | ||||||
|  |  | ||||||
|   If such an object file uses only numerical parameters, data |  | ||||||
| structure layouts and accessors, and small macros and small inline |  | ||||||
| functions (ten lines or less in length), then the use of the object |  | ||||||
| file is unrestricted, regardless of whether it is legally a derivative |  | ||||||
| work.  (Executables containing this object code plus portions of the |  | ||||||
| Library will still fall under Section 6.) |  | ||||||
|  |  | ||||||
|   Otherwise, if the work is a derivative of the Library, you may |  | ||||||
| distribute the object code for the work under the terms of Section 6. |  | ||||||
| Any executables containing that work also fall under Section 6, |  | ||||||
| whether or not they are linked directly with the Library itself. |  | ||||||
|  |  | ||||||
|   6. As an exception to the Sections above, you may also combine or |  | ||||||
| link a "work that uses the Library" with the Library to produce a |  | ||||||
| work containing portions of the Library, and distribute that work |  | ||||||
| under terms of your choice, provided that the terms permit |  | ||||||
| modification of the work for the customer's own use and reverse |  | ||||||
| engineering for debugging such modifications. |  | ||||||
|  |  | ||||||
|   You must give prominent notice with each copy of the work that the |  | ||||||
| Library is used in it and that the Library and its use are covered by |  | ||||||
| this License.  You must supply a copy of this License.  If the work |  | ||||||
| during execution displays copyright notices, you must include the |  | ||||||
| copyright notice for the Library among them, as well as a reference |  | ||||||
| directing the user to the copy of this License.  Also, you must do one |  | ||||||
| of these things: |  | ||||||
|  |  | ||||||
|     a) Accompany the work with the complete corresponding |  | ||||||
|     machine-readable source code for the Library including whatever |  | ||||||
|     changes were used in the work (which must be distributed under |  | ||||||
|     Sections 1 and 2 above); and, if the work is an executable linked |  | ||||||
|     with the Library, with the complete machine-readable "work that |  | ||||||
|     uses the Library", as object code and/or source code, so that the |  | ||||||
|     user can modify the Library and then relink to produce a modified |  | ||||||
|     executable containing the modified Library.  (It is understood |  | ||||||
|     that the user who changes the contents of definitions files in the |  | ||||||
|     Library will not necessarily be able to recompile the application |  | ||||||
|     to use the modified definitions.) |  | ||||||
|  |  | ||||||
|     b) Use a suitable shared library mechanism for linking with the |  | ||||||
|     Library.  A suitable mechanism is one that (1) uses at run time a |  | ||||||
|     copy of the library already present on the user's computer system, |  | ||||||
|     rather than copying library functions into the executable, and (2) |  | ||||||
|     will operate properly with a modified version of the library, if |  | ||||||
|     the user installs one, as long as the modified version is |  | ||||||
|     interface-compatible with the version that the work was made with. |  | ||||||
|  |  | ||||||
|     c) Accompany the work with a written offer, valid for at |  | ||||||
|     least three years, to give the same user the materials |  | ||||||
|     specified in Subsection 6a, above, for a charge no more |  | ||||||
|     than the cost of performing this distribution. |  | ||||||
|  |  | ||||||
|     d) If distribution of the work is made by offering access to copy |  | ||||||
|     from a designated place, offer equivalent access to copy the above |  | ||||||
|     specified materials from the same place. |  | ||||||
|  |  | ||||||
|     e) Verify that the user has already received a copy of these |  | ||||||
|     materials or that you have already sent this user a copy. |  | ||||||
|  |  | ||||||
|   For an executable, the required form of the "work that uses the |  | ||||||
| Library" must include any data and utility programs needed for |  | ||||||
| reproducing the executable from it.  However, as a special exception, |  | ||||||
| the materials to be distributed need not include anything that is |  | ||||||
| normally distributed (in either source or binary form) with the major |  | ||||||
| components (compiler, kernel, and so on) of the operating system on |  | ||||||
| which the executable runs, unless that component itself accompanies |  | ||||||
| the executable. |  | ||||||
|  |  | ||||||
|   It may happen that this requirement contradicts the license |  | ||||||
| restrictions of other proprietary libraries that do not normally |  | ||||||
| accompany the operating system.  Such a contradiction means you cannot |  | ||||||
| use both them and the Library together in an executable that you |  | ||||||
| distribute. |  | ||||||
|  |  | ||||||
|   7. You may place library facilities that are a work based on the |  | ||||||
| Library side-by-side in a single library together with other library |  | ||||||
| facilities not covered by this License, and distribute such a combined |  | ||||||
| library, provided that the separate distribution of the work based on |  | ||||||
| the Library and of the other library facilities is otherwise |  | ||||||
| permitted, and provided that you do these two things: |  | ||||||
|  |  | ||||||
|     a) Accompany the combined library with a copy of the same work |  | ||||||
|     based on the Library, uncombined with any other library |  | ||||||
|     facilities.  This must be distributed under the terms of the |  | ||||||
|     Sections above. |  | ||||||
|  |  | ||||||
|     b) Give prominent notice with the combined library of the fact |  | ||||||
|     that part of it is a work based on the Library, and explaining |  | ||||||
|     where to find the accompanying uncombined form of the same work. |  | ||||||
|  |  | ||||||
|   8. You may not copy, modify, sublicense, link with, or distribute |  | ||||||
| the Library except as expressly provided under this License.  Any |  | ||||||
| attempt otherwise to copy, modify, sublicense, link with, or |  | ||||||
| distribute the Library is void, and will automatically terminate your |  | ||||||
| rights under this License.  However, parties who have received copies, |  | ||||||
| or rights, from you under this License will not have their licenses |  | ||||||
| terminated so long as such parties remain in full compliance. |  | ||||||
|  |  | ||||||
|   9. You are not required to accept this License, since you have not |  | ||||||
| signed it.  However, nothing else grants you permission to modify or |  | ||||||
| distribute the Library or its derivative works.  These actions are |  | ||||||
| prohibited by law if you do not accept this License.  Therefore, by |  | ||||||
| modifying or distributing the Library (or any work based on the |  | ||||||
| Library), you indicate your acceptance of this License to do so, and |  | ||||||
| all its terms and conditions for copying, distributing or modifying |  | ||||||
| the Library or works based on it. |  | ||||||
|  |  | ||||||
|   10. Each time you redistribute the Library (or any work based on the |  | ||||||
| Library), the recipient automatically receives a license from the |  | ||||||
| original licensor to copy, distribute, link with or modify the Library |  | ||||||
| subject to these terms and conditions.  You may not impose any further |  | ||||||
| restrictions on the recipients' exercise of the rights granted herein. |  | ||||||
| You are not responsible for enforcing compliance by third parties with |  | ||||||
| this License. |  | ||||||
|  |  | ||||||
|   11. If, as a consequence of a court judgment or allegation of patent |  | ||||||
| infringement or for any other reason (not limited to patent issues), |  | ||||||
| conditions are imposed on you (whether by court order, agreement or |  | ||||||
| otherwise) that contradict the conditions of this License, they do not |  | ||||||
| excuse you from the conditions of this License.  If you cannot |  | ||||||
| distribute so as to satisfy simultaneously your obligations under this |  | ||||||
| License and any other pertinent obligations, then as a consequence you |  | ||||||
| may not distribute the Library at all.  For example, if a patent |  | ||||||
| license would not permit royalty-free redistribution of the Library by |  | ||||||
| all those who receive copies directly or indirectly through you, then |  | ||||||
| the only way you could satisfy both it and this License would be to |  | ||||||
| refrain entirely from distribution of the Library. |  | ||||||
|  |  | ||||||
| If any portion of this section is held invalid or unenforceable under any |  | ||||||
| particular circumstance, the balance of the section is intended to apply, |  | ||||||
| and the section as a whole is intended to apply in other circumstances. |  | ||||||
|  |  | ||||||
| It is not the purpose of this section to induce you to infringe any |  | ||||||
| patents or other property right claims or to contest validity of any |  | ||||||
| such claims; this section has the sole purpose of protecting the |  | ||||||
| integrity of the free software distribution system which is |  | ||||||
| implemented by public license practices.  Many people have made |  | ||||||
| generous contributions to the wide range of software distributed |  | ||||||
| through that system in reliance on consistent application of that |  | ||||||
| system; it is up to the author/donor to decide if he or she is willing |  | ||||||
| to distribute software through any other system and a licensee cannot |  | ||||||
| impose that choice. |  | ||||||
|  |  | ||||||
| This section is intended to make thoroughly clear what is believed to |  | ||||||
| be a consequence of the rest of this License. |  | ||||||
|  |  | ||||||
|   12. If the distribution and/or use of the Library is restricted in |  | ||||||
| certain countries either by patents or by copyrighted interfaces, the |  | ||||||
| original copyright holder who places the Library under this License may add |  | ||||||
| an explicit geographical distribution limitation excluding those countries, |  | ||||||
| so that distribution is permitted only in or among countries not thus |  | ||||||
| excluded.  In such case, this License incorporates the limitation as if |  | ||||||
| written in the body of this License. |  | ||||||
|  |  | ||||||
|   13. The Free Software Foundation may publish revised and/or new |  | ||||||
| versions of the Lesser General Public License from time to time. |  | ||||||
| Such new versions will be similar in spirit to the present version, |  | ||||||
| but may differ in detail to address new problems or concerns. |  | ||||||
|  |  | ||||||
| Each version is given a distinguishing version number.  If the Library |  | ||||||
| specifies a version number of this License which applies to it and |  | ||||||
| "any later version", you have the option of following the terms and |  | ||||||
| conditions either of that version or of any later version published by |  | ||||||
| the Free Software Foundation.  If the Library does not specify a |  | ||||||
| license version number, you may choose any version ever published by |  | ||||||
| the Free Software Foundation. |  | ||||||
|  |  | ||||||
|   14. If you wish to incorporate parts of the Library into other free |  | ||||||
| programs whose distribution conditions are incompatible with these, |  | ||||||
| write to the author to ask for permission.  For software which is |  | ||||||
| copyrighted by the Free Software Foundation, write to the Free |  | ||||||
| Software Foundation; we sometimes make exceptions for this.  Our |  | ||||||
| decision will be guided by the two goals of preserving the free status |  | ||||||
| of all derivatives of our free software and of promoting the sharing |  | ||||||
| and reuse of software generally. |  | ||||||
|  |  | ||||||
| 			    NO WARRANTY |  | ||||||
|  |  | ||||||
|   15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO |  | ||||||
| WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. |  | ||||||
| EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR |  | ||||||
| OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY |  | ||||||
| KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE |  | ||||||
| IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |  | ||||||
| PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE |  | ||||||
| LIBRARY IS WITH YOU.  SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME |  | ||||||
| THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. |  | ||||||
|  |  | ||||||
|   16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN |  | ||||||
| WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY |  | ||||||
| AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU |  | ||||||
| FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR |  | ||||||
| CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE |  | ||||||
| LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING |  | ||||||
| RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A |  | ||||||
| FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF |  | ||||||
| SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH |  | ||||||
| DAMAGES. |  | ||||||
|  |  | ||||||
| 		     END OF TERMS AND CONDITIONS |  | ||||||
|  |  | ||||||
|            How to Apply These Terms to Your New Libraries |  | ||||||
|  |  | ||||||
|   If you develop a new library, and you want it to be of the greatest |  | ||||||
| possible use to the public, we recommend making it free software that |  | ||||||
| everyone can redistribute and change.  You can do so by permitting |  | ||||||
| redistribution under these terms (or, alternatively, under the terms of the |  | ||||||
| ordinary General Public License). |  | ||||||
|  |  | ||||||
|   To apply these terms, attach the following notices to the library.  It is |  | ||||||
| safest to attach them to the start of each source file to most effectively |  | ||||||
| convey the exclusion of warranty; and each file should have at least the |  | ||||||
| "copyright" line and a pointer to where the full notice is found. |  | ||||||
|  |  | ||||||
|     <one line to give the library's name and a brief idea of what it does.> |  | ||||||
|     Copyright (C) <year>  <name of author> |  | ||||||
|  |  | ||||||
|     This library is free software; you can redistribute it and/or |  | ||||||
|     modify it under the terms of the GNU Lesser General Public |  | ||||||
|     License as published by the Free Software Foundation; either |  | ||||||
|     version 2.1 of the License, or (at your option) any later version. |  | ||||||
|  |  | ||||||
|     This library is distributed in the hope that it will be useful, |  | ||||||
|     but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU |  | ||||||
|     Lesser General Public License for more details. |  | ||||||
|  |  | ||||||
|     You should have received a copy of the GNU Lesser General Public |  | ||||||
|     License along with this library; if not, write to the Free Software |  | ||||||
|     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA |  | ||||||
|  |  | ||||||
| Also add information on how to contact you by electronic and paper mail. |  | ||||||
|  |  | ||||||
| You should also get your employer (if you work as a programmer) or your |  | ||||||
| school, if any, to sign a "copyright disclaimer" for the library, if |  | ||||||
| necessary.  Here is a sample; alter the names: |  | ||||||
|  |  | ||||||
|   Yoyodyne, Inc., hereby disclaims all copyright interest in the |  | ||||||
|   library `Frob' (a library for tweaking knobs) written by James Random Hacker. |  | ||||||
|  |  | ||||||
|   <signature of Ty Coon>, 1 April 1990 |  | ||||||
|   Ty Coon, President of Vice |  | ||||||
|  |  | ||||||
| That's all there is to it! |  | ||||||
| @@ -1,60 +0,0 @@ | |||||||
| 1.0.5  Version (May 2007) by (twh) |  | ||||||
| o added proper clean targets to enable multiple builds |  | ||||||
| o added examples directory |  | ||||||
| o Correctly Detects 32/64-bit build environment |  | ||||||
| o Allow explicit configure for 32/64-bit environment |  | ||||||
|  |  | ||||||
| 1.0.4  Version (May 2007) by (twh) |  | ||||||
| o fixed the Checkit problem "error Judy1PrevEmpty Rcode != 1 = 0" |  | ||||||
| o Fixed memory allignment in JudyMallocIF.c (doug) |  | ||||||
| o Fixed messages from "make check" (doug). |  | ||||||
|  |  | ||||||
| 1.0.3  Version (Feb 2006 ) by (twh) |  | ||||||
| o fixed make files to break out each copy element |  | ||||||
| to be a unique target, this also seems to have  |  | ||||||
| resolved the issue where running make check rebuilds |  | ||||||
| the entire library again. |  | ||||||
|  |  | ||||||
| 1.0.2  Version (Jan 2006 ) by (twh) |  | ||||||
|  |  | ||||||
| o fixed assumption of signed char in test programs. |  | ||||||
| o updated sh_build |  | ||||||
| o fixed generation of man pages from html |  | ||||||
| o fixed 32-bit and 64-bit configure |  | ||||||
|  |  | ||||||
| 1.0.1 Version (Dec 2004) by (twh) |  | ||||||
|  |  | ||||||
| o fixed bootstrap to use later versions |  | ||||||
| o fixed manpage naming from (3X) to (3) |  | ||||||
| o Code changes to support Microsoft __inline directive |  | ||||||
| o Move away from using symlinks to using copies |  | ||||||
| o Added build.bat to support building on Windows |  | ||||||
|  |  | ||||||
| 1.0.0 Version (Sept 2004) by (twh) |  | ||||||
|  |  | ||||||
| o Complete Autoconfisication of Judy |  | ||||||
| o Removed previous build environment |  | ||||||
| o Change INSTALL_IT back to INSTALL |  | ||||||
| o Moving to 1.0.0 to denote API change.  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| 0.1.6 Version (1June2004) by (dlb) |  | ||||||
|  |  | ||||||
| o See src/sh_build in case of 'make' failures |  | ||||||
| o The is an endian-neutral version I.E. (jp_DcdPop0 deleted) |  | ||||||
| o Should not require any special platform specific compile flags |  | ||||||
| o Includes JudyHS*() -- very fast, scalable string version  |  | ||||||
| o JudyHS*() is still preliminary and may need additional functionality. |  | ||||||
| o See test/manual/StringCompare.c for comparing different 'string' ADT's |  | ||||||
| o Deleted files: JudyMalloc.h, JudySL.h, JudySearch* |  | ||||||
| o All malloc() and free() is done thru interface routines in JudyMalloc.c |  | ||||||
| o Judy.h should work on all platforms that conform to ISO standards. |  | ||||||
| o After trying on many platforms, <stdint.h> was changed to <inttypes.h> |  | ||||||
| o jbgraph has some 'bash/ksh' isms that need to be removed. |  | ||||||
| o See test/manual/testjbgraph for plotting performance graphs |  | ||||||
| o 'libtools' stuff is in unknown shape. |  | ||||||
| o Does not "mangle" the root pointer (so old valgrind is not confused) |  | ||||||
| o Conform to standard "C" |  | ||||||
| o Change INSTALL to INSTALL_IT because it confused "make install" |  | ||||||
| o To he man pages need work to clean up the .html to be portable |  | ||||||
| o Plus hundreds of changes to make the source more portable. |  | ||||||
| @@ -1,20 +0,0 @@ | |||||||
| === QUICK INSTALLATION OF JUDY LIBRARY AND MANUAL ENTRIES === |  | ||||||
|  |  | ||||||
| 1.  ./configure 		#NOTE: you must do configure with either |  | ||||||
| 				--enable-32-bit or --enable-64-bit |  | ||||||
| 				depending on your system. Also note if you |  | ||||||
| 				are doing a non-native compile you are |  | ||||||
| 				responsiable for setting the appropriate |  | ||||||
| 				CFLAGS. See README for more information.  |  | ||||||
| 2.  make |  | ||||||
| 3.  make check |  | ||||||
| 4.  make install                # NOTE: must be SUPERUSER for make install |  | ||||||
| 				# This installs /opt/Judy/* and symlinks to |  | ||||||
| 				# files there from /usr/include/, /usr/lib/, |  | ||||||
| 				# /usr/share/man/, and /usr/share/doc/Judy/. |  | ||||||
|  |  | ||||||
| (Installation done!  The rest is optional but recommended.) |  | ||||||
|  |  | ||||||
| 5) man Judy			# nroff -man version, or... |  | ||||||
|  |  | ||||||
| 6) file:/opt/Judy/usr/share/doc/Judy/Judy_3x.htm   # from LOCAL Web browser. |  | ||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user