mirror of
				https://github.com/optim-enterprises-bv/openwrt-ipq.git
				synced 2025-11-04 04:08:34 +00:00 
			
		
		
		
	base-files: Add new functions for ath11k caldata
Add new functions for ath11k caldata: - ath11k_patch_mac (from 0 to 5) - ath11k_remove_regdomain - ath11k_set_macflag (some pre-caldata have the nvMacFlag flag unset which is needed to change the MAC address) Additionaly for ath10k caldata: - ath10k_remove_regdomain Signed-off-by: Paweł Owoc <frut3k7@gmail.com>
This commit is contained in:
		@@ -32,6 +32,30 @@ xor() {
 | 
				
			|||||||
	printf "%0${retlen}x" "$ret"
 | 
						printf "%0${retlen}x" "$ret"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					data_2bin() {
 | 
				
			||||||
 | 
						local data=$1
 | 
				
			||||||
 | 
						local len=${#1}
 | 
				
			||||||
 | 
						local bin_data
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for i in $(seq 0 2 $(($len - 1))); do
 | 
				
			||||||
 | 
							bin_data="${bin_data}\x${data:i:2}"
 | 
				
			||||||
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						echo -ne $bin_data
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					data_2xor_val() {
 | 
				
			||||||
 | 
						local data=$1
 | 
				
			||||||
 | 
						local len=${#1}
 | 
				
			||||||
 | 
						local xor_data
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						for i in $(seq 0 4 $(($len - 1))); do
 | 
				
			||||||
 | 
							xor_data="${xor_data}${data:i:4} "
 | 
				
			||||||
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						echo -n ${xor_data:0:-1}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
append() {
 | 
					append() {
 | 
				
			||||||
	local var="$1"
 | 
						local var="$1"
 | 
				
			||||||
	local value="$2"
 | 
						local value="$2"
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -70,7 +70,7 @@ caldata_extract_reverse() {
 | 
				
			|||||||
	local caldata
 | 
						local caldata
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	mtd=$(find_mtd_chardev "$part")
 | 
						mtd=$(find_mtd_chardev "$part")
 | 
				
			||||||
	reversed=$(hexdump -v -s $offset -n $count -e '/1 "%02x "' $mtd)
 | 
						reversed=$(hexdump -v -s $offset -n $count -e '1/1 "%02x "' $mtd)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for byte in $reversed; do
 | 
						for byte in $reversed; do
 | 
				
			||||||
		caldata="\x${byte}${caldata}"
 | 
							caldata="\x${byte}${caldata}"
 | 
				
			||||||
@@ -122,49 +122,43 @@ caldata_valid() {
 | 
				
			|||||||
	return $?
 | 
						return $?
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
caldata_patch_chksum() {
 | 
					caldata_patch_data() {
 | 
				
			||||||
	local mac=$1
 | 
						local data=$1
 | 
				
			||||||
	local mac_offset=$(($2))
 | 
						local data_count=$((${#1} / 2))
 | 
				
			||||||
 | 
						local data_offset=$(($2))
 | 
				
			||||||
	local chksum_offset=$(($3))
 | 
						local chksum_offset=$(($3))
 | 
				
			||||||
	local target=$4
 | 
						local target=$4
 | 
				
			||||||
	local xor_mac
 | 
						local fw_data
 | 
				
			||||||
	local xor_fw_mac
 | 
						local fw_chksum
 | 
				
			||||||
	local xor_fw_chksum
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	xor_mac=${mac//:/}
 | 
						[ -z "$data" -o -z "$data_offset" ] && return
 | 
				
			||||||
	xor_mac="${xor_mac:0:4} ${xor_mac:4:4} ${xor_mac:8:4}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	xor_fw_mac=$(hexdump -v -n 6 -s $mac_offset -e '/1 "%02x"' /lib/firmware/$FIRMWARE)
 | 
					 | 
				
			||||||
	xor_fw_mac="${xor_fw_mac:0:4} ${xor_fw_mac:4:4} ${xor_fw_mac:8:4}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	xor_fw_chksum=$(hexdump -v -n 2 -s $chksum_offset -e '/1 "%02x"' /lib/firmware/$FIRMWARE)
 | 
					 | 
				
			||||||
	xor_fw_chksum=$(xor $xor_fw_chksum $xor_fw_mac $xor_mac)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	printf "%b" "\x${xor_fw_chksum:0:2}\x${xor_fw_chksum:2:2}" | \
 | 
					 | 
				
			||||||
		dd of=$target conv=notrunc bs=1 seek=$chksum_offset count=2
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
caldata_patch_mac() {
 | 
					 | 
				
			||||||
	local mac=$1
 | 
					 | 
				
			||||||
	local mac_offset=$(($2))
 | 
					 | 
				
			||||||
	local chksum_offset=$3
 | 
					 | 
				
			||||||
	local target=$4
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	[ -z "$mac" -o -z "$mac_offset" ] && return
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	[ -n "$target" ] || target=/lib/firmware/$FIRMWARE
 | 
						[ -n "$target" ] || target=/lib/firmware/$FIRMWARE
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	[ -n "$chksum_offset" ] && caldata_patch_chksum "$mac" "$mac_offset" "$chksum_offset" "$target"
 | 
						fw_data=$(hexdump -v -n $data_count -s $data_offset -e '1/1 "%02x"' $target)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	macaddr_2bin $mac | dd of=$target conv=notrunc oflag=seek_bytes bs=6 seek=$mac_offset count=1 || \
 | 
						if [ "$data" != "$fw_data" ]; then
 | 
				
			||||||
		caldata_die "failed to write MAC address to eeprom file"
 | 
					
 | 
				
			||||||
 | 
							if [ -n "$chksum_offset" ]; then
 | 
				
			||||||
 | 
								fw_chksum=$(hexdump -v -n 2 -s $chksum_offset -e '1/1 "%02x"' $target)
 | 
				
			||||||
 | 
								fw_chksum=$(xor $fw_chksum $(data_2xor_val $fw_data) $(data_2xor_val $data))
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								data_2bin $fw_chksum | \
 | 
				
			||||||
 | 
									dd of=$target conv=notrunc bs=1 seek=$chksum_offset count=2 || \
 | 
				
			||||||
 | 
									caldata_die "failed to write chksum to eeprom file"
 | 
				
			||||||
 | 
							fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							data_2bin $data | \
 | 
				
			||||||
 | 
								dd of=$target conv=notrunc bs=1 seek=$data_offset count=$data_count || \
 | 
				
			||||||
 | 
								caldata_die "failed to write data to eeprom file"
 | 
				
			||||||
 | 
						fi
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ath9k_patch_mac() {
 | 
					ath9k_patch_mac() {
 | 
				
			||||||
	local mac=$1
 | 
						local mac=$1
 | 
				
			||||||
	local target=$2
 | 
						local target=$2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	caldata_patch_mac "$mac" 0x2 "" "$target"
 | 
						caldata_patch_data "${mac//:/}" 0x2 "" "$target"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ath9k_patch_mac_crc() {
 | 
					ath9k_patch_mac_crc() {
 | 
				
			||||||
@@ -173,12 +167,52 @@ ath9k_patch_mac_crc() {
 | 
				
			|||||||
	local chksum_offset=$((mac_offset - 10))
 | 
						local chksum_offset=$((mac_offset - 10))
 | 
				
			||||||
	local target=$4
 | 
						local target=$4
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	caldata_patch_mac "$mac" "$mac_offset" "$chksum_offset" "$target"
 | 
						caldata_patch_data "${mac//:/}" "$mac_offset" "$chksum_offset" "$target"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ath10k_patch_mac() {
 | 
					ath10k_patch_mac() {
 | 
				
			||||||
	local mac=$1
 | 
						local mac=$1
 | 
				
			||||||
	local target=$2
 | 
						local target=$2
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	caldata_patch_mac "$mac" 0x6 0x2 "$target"
 | 
						caldata_patch_data "${mac//:/}" 0x6 0x2 "$target"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ath11k_patch_mac() {
 | 
				
			||||||
 | 
						local mac=$1
 | 
				
			||||||
 | 
						# mac_id from 0 to 5
 | 
				
			||||||
 | 
						local mac_id=$2
 | 
				
			||||||
 | 
						local target=$3
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						[ -z "$mac_id" ] && return
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						caldata_patch_data "${mac//:/}" $(printf "0x%x" $(($mac_id * 0x6 + 0xe))) 0xa "$target"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ath10k_remove_regdomain() {
 | 
				
			||||||
 | 
						local target=$1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						caldata_patch_data "0000" 0xc 0x2 "$target"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ath11k_remove_regdomain() {
 | 
				
			||||||
 | 
						local target=$1
 | 
				
			||||||
 | 
						local regdomain
 | 
				
			||||||
 | 
						local regdomain_data
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						regdomain=$(hexdump -v -n 2 -s 0x34 -e '1/1 "%02x"' $target)
 | 
				
			||||||
 | 
						caldata_patch_data "0000" 0x34 0xa "$target"
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						for offset in 0x450 0x458 0x500 0x5a8; do
 | 
				
			||||||
 | 
							regdomain_data=$(hexdump -v -n 2 -s $offset -e '1/1 "%02x"' $target)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
							if [ "$regdomain" == "$regdomain_data" ]; then
 | 
				
			||||||
 | 
								caldata_patch_data "0000" $offset 0xa "$target"
 | 
				
			||||||
 | 
							fi
 | 
				
			||||||
 | 
						done
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ath11k_set_macflag() {
 | 
				
			||||||
 | 
						local target=$1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						caldata_patch_data "0100" 0x3e 0xa "$target"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -279,12 +279,6 @@ macaddr_random() {
 | 
				
			|||||||
	echo "$(macaddr_unsetbit_mc "$(macaddr_setbit_la "${randsrc}")")"
 | 
						echo "$(macaddr_unsetbit_mc "$(macaddr_setbit_la "${randsrc}")")"
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
macaddr_2bin() {
 | 
					 | 
				
			||||||
	local mac=$1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	echo -ne \\x${mac//:/\\x}
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
macaddr_canonicalize() {
 | 
					macaddr_canonicalize() {
 | 
				
			||||||
	local mac="$1"
 | 
						local mac="$1"
 | 
				
			||||||
	local canon=""
 | 
						local canon=""
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user