mirror of
				https://github.com/thelsing/knx.git
				synced 2025-10-22 11:14:38 +02:00 
			
		
		
		
	Merge branch 'thelsing:master' into master
This commit is contained in:
		
						commit
						eb0d62666d
					
				
							
								
								
									
										25
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										25
									
								
								.github/workflows/codeql-analysis.yml
									
									
									
									
										vendored
									
									
								
							| @ -18,32 +18,27 @@ jobs: | |||||||
|   analyze: |   analyze: | ||||||
|     name: Analyze |     name: Analyze | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|  |     permissions: | ||||||
|  |       actions: read | ||||||
|  |       contents: read | ||||||
|  |       security-events: write | ||||||
| 
 | 
 | ||||||
|     strategy: |     strategy: | ||||||
|       fail-fast: false |       fail-fast: false | ||||||
|       matrix: |       matrix: | ||||||
|         # Override automatic language detection by changing the below list |         # Override automatic language detection by changing the below list | ||||||
|         # Supported options are ['csharp', 'cpp', 'go', 'java', 'javascript', 'python'] |         # Supported options are ['csharp', 'cpp', 'go', 'java', 'javascript', 'python'] | ||||||
|         language: ['cpp'] |         language: ['cpp', 'python'] | ||||||
|         # Learn more... |         # Learn more... | ||||||
|         # https://docs.github.com/en/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#overriding-automatic-language-detection |         # Learn more about CodeQL language support at https://aka.ms/codeql-docs/language-support | ||||||
| 
 | 
 | ||||||
|     steps: |     steps: | ||||||
|     - name: Checkout repository |     - name: Checkout repository | ||||||
|       uses: actions/checkout@v2 |       uses: actions/checkout@v3 | ||||||
|       with: |  | ||||||
|         # We must fetch at least the immediate parents so that if this is |  | ||||||
|         # a pull request then we can checkout the head. |  | ||||||
|         fetch-depth: 2 |  | ||||||
| 
 |  | ||||||
|     # If this run was triggered by a pull request event, then checkout |  | ||||||
|     # the head of the pull request instead of the merge commit. |  | ||||||
|     - run: git checkout HEAD^2 |  | ||||||
|       if: ${{ github.event_name == 'pull_request' }} |  | ||||||
| 
 | 
 | ||||||
|     # Initializes the CodeQL tools for scanning. |     # Initializes the CodeQL tools for scanning. | ||||||
|     - name: Initialize CodeQL |     - name: Initialize CodeQL | ||||||
|       uses: github/codeql-action/init@v1 |       uses: github/codeql-action/init@v2 | ||||||
|       with: |       with: | ||||||
|         languages: ${{ matrix.language }} |         languages: ${{ matrix.language }} | ||||||
|         # If you wish to specify custom queries, you can do so here or in a config file. |         # If you wish to specify custom queries, you can do so here or in a config file. | ||||||
| @ -54,7 +49,7 @@ jobs: | |||||||
|     # Autobuild attempts to build any compiled languages  (C/C++, C#, or Java). |     # Autobuild attempts to build any compiled languages  (C/C++, C#, or Java). | ||||||
|     # If this step fails, then you should remove it and run the build manually (see below) |     # If this step fails, then you should remove it and run the build manually (see below) | ||||||
|     - name: Autobuild |     - name: Autobuild | ||||||
|       uses: github/codeql-action/autobuild@v1 |       uses: github/codeql-action/autobuild@v2 | ||||||
| 
 | 
 | ||||||
|     # ℹ️ Command-line programs to run using the OS shell. |     # ℹ️ Command-line programs to run using the OS shell. | ||||||
|     # 📚 https://git.io/JvXDl |     # 📚 https://git.io/JvXDl | ||||||
| @ -68,4 +63,4 @@ jobs: | |||||||
|     #   make release |     #   make release | ||||||
| 
 | 
 | ||||||
|     - name: Perform CodeQL Analysis |     - name: Perform CodeQL Analysis | ||||||
|       uses: github/codeql-action/analyze@v1 |       uses: github/codeql-action/analyze@v2 | ||||||
|  | |||||||
| @ -37,9 +37,28 @@ uint16_t AddressTableObject::getGroupAddress(uint16_t tsap) | |||||||
| uint16_t AddressTableObject::getTsap(uint16_t addr) | uint16_t AddressTableObject::getTsap(uint16_t addr) | ||||||
| { | { | ||||||
|     uint16_t size = entryCount(); |     uint16_t size = entryCount(); | ||||||
|  |     #ifdef USE_BINSEARCH | ||||||
|  | 
 | ||||||
|  |     uint16_t low,high,i; | ||||||
|  |     low = 1; | ||||||
|  |     high = size; | ||||||
|  | 
 | ||||||
|  |     while(low <= high) | ||||||
|  |     { | ||||||
|  |         i = (low+high)/2; | ||||||
|  |         uint16_t ga = ntohs(_groupAddresses[i]); | ||||||
|  |         if (ga == addr) | ||||||
|  |             return i; | ||||||
|  |         if(addr < ga) | ||||||
|  |             high = i - 1; | ||||||
|  |         else | ||||||
|  |             low = i + 1 ; | ||||||
|  |     } | ||||||
|  |     #else | ||||||
|     for (uint16_t i = 1; i <= size; i++) |     for (uint16_t i = 1; i <= size; i++) | ||||||
|         if (ntohs(_groupAddresses[i]) == addr) |         if (ntohs(_groupAddresses[i]) == addr) | ||||||
|             return i; |             return i; | ||||||
|  |     #endif | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -58,12 +77,7 @@ const uint8_t* AddressTableObject::restore(const uint8_t* buffer) | |||||||
| 
 | 
 | ||||||
| bool AddressTableObject::contains(uint16_t addr) | bool AddressTableObject::contains(uint16_t addr) | ||||||
| { | { | ||||||
|     uint16_t size = entryCount(); |     return (getTsap(addr) > 0); | ||||||
|     for (uint16_t i = 1; i <= size; i++) |  | ||||||
|         if (ntohs(_groupAddresses[i]) == addr) |  | ||||||
|             return true; |  | ||||||
| 
 |  | ||||||
|     return false; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AddressTableObject::beforeStateChange(LoadState& newState) | void AddressTableObject::beforeStateChange(LoadState& newState) | ||||||
|  | |||||||
| @ -50,11 +50,35 @@ const uint8_t* AssociationTableObject::restore(const uint8_t* buffer) | |||||||
| int32_t AssociationTableObject::translateAsap(uint16_t asap) | int32_t AssociationTableObject::translateAsap(uint16_t asap) | ||||||
| { | { | ||||||
|     uint16_t entries = entryCount(); |     uint16_t entries = entryCount(); | ||||||
|  |     #ifdef USE_BINSEARCH | ||||||
|  |     uint16_t low,high,i; | ||||||
|  |     low = 0; | ||||||
|  |     high = entries-1; | ||||||
|  | 
 | ||||||
|  |     while(low <= high) | ||||||
|  |     { | ||||||
|  |         i = (low+high)/2; | ||||||
|  |         uint16_t asap_i = getASAP(i); | ||||||
|  |         if (asap_i == asap) | ||||||
|  |         { | ||||||
|  |              // as the binary search does not hit the first element in a list with identical items,
 | ||||||
|  |              // search downwards to return the first occurence in the table
 | ||||||
|  |             while(getASAP(--i) == asap) | ||||||
|  |                 ; | ||||||
|  |             return getTSAP(i+1); | ||||||
|  |         } | ||||||
|  |         if(asap_i > asap) | ||||||
|  |             high = i - 1; | ||||||
|  |         else | ||||||
|  |             low = i + 1 ; | ||||||
|  |     } | ||||||
|  |     #else | ||||||
|     for (uint16_t i = 0; i < entries; i++) |     for (uint16_t i = 0; i < entries; i++) | ||||||
|     { |     { | ||||||
|         if (getASAP(i) == asap) |         if (getASAP(i) == asap) | ||||||
|             return getTSAP(i); |             return getTSAP(i); | ||||||
|     } |     } | ||||||
|  |     #endif | ||||||
|     return -1; |     return -1; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user