mirror of
https://github.com/esp8266/Arduino.git
synced 2025-06-12 01:53:07 +03:00
Heap addendum to handle changes in NON-OS SDK 3.0.x (#8746)
## WPA2 Enterprise connections
References - merged PRs:
* https://github.com/esp8266/Arduino/pull/8529
* https://github.com/esp8266/Arduino/pull/8566 - these occurred with connect/disconnect with WPA-Enterprise
* https://github.com/esp8266/Arduino/pull/8736#issue-1470774550
The NON-OS SDK 3.0.x has breaking changes to the [`pvPortMalloc`](bf890b22e5/include/mem.h (L42)
) function. They added a new `bool` argument for selecting a heap.
```cpp
void *pvPortMalloc (size_t sz, const char *, unsigned, bool);
```
To avoid breaking the build, I added a new thin wrapper function `sdk3_pvPortMalloc` to `heap.cpp`.
Edited new SDK LIBs to call `pvPortMalloc`'s replacement `sdk3_pvPortMalloc`.
They also added `pvPortZallocIram` and `pvPortCallocIram`, which are not a problem to support. Support added to `heap.cpp`.
Issues with WPA2 Enterprise in new SDKs:
* v3.0.0 and v3.0.1 - have the same memory leak and duplicate free bugs from before
* v3.0.2 through v3.0.5 - have the same memory leak; however, _no_ duplicate free crash.
* memory leak can be seen by cycling through setup, connect, disconnect, and clear setup - repeatedly.
Updated `wpa2_eap_patch.cpp` and binary patch scripts to handle v3.0.0 through v3.0.5.
Patched SDKs v3.0.0 through v3.0.5
## Duplicate Non-32-bit exception handler
Issue: At v3.0.0 and above `libmain.a` supplies a built-in exception handler (`load_non_32_wide_handler`) for non-32-bit access. Our non-32-bit access handler (`non32xfer_exception_handler`) overrides it.
Solution: Add "weak" attribute to symbol `load_non_32_wide_handler`. Adjust the build to default to the SDK's built-in non-32-bit handler. If there is a need to use our non-32-bit handler, make the selection from the Arduino IDE Tools menu `Non-32-Bit Access: "Byte/Word access to IRAM/PROGMEM (very slow)"`.
With SDKs v3.0.0 and above a "non-32-bit exception handler" is always present.
This commit is contained in:
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -1,8 +1,20 @@
|
||||
## Adding a new SDK library
|
||||
|
||||
- Create a directory for the new SDK.
|
||||
- Copy .a files from SDK `lib` directory to the new directory
|
||||
- Add the new SDK directory to those supported in `eval_fix_sdks.sh` and `fix_sdk_libs.sh`.
|
||||
- To support WPA2 Enterprise connections, some patches are reguired review `wpa2_eap_patch.cpp` and `eval_fix_sdks.sh` for details.
|
||||
- Use `./eval_fix_sdks.sh --analyze` to aid in finding relevant differences.
|
||||
- Also, you can compare two SDKs with something like `./eval_fix_sdks.sh --analyze "NONOSDK305\nNONOSDK306"`
|
||||
- Apply updates to `fix_sdk_libs.sh` and `wpa2_eap_patch.cpp`. You can run `./eval_fix_sdks.sh --patch` to do a batch run of `fix_sdk_libs.sh` against each SDK.
|
||||
- If you used this section, you can skip _Updating SDK libraries_.
|
||||
|
||||
## Updating SDK libraries
|
||||
|
||||
- Copy .a files from SDK `lib` directory to this directory
|
||||
- Run `fix_sdk_libs.sh`
|
||||
|
||||
|
||||
## Updating libstdc++
|
||||
|
||||
After building gcc using crosstool-NG, get compiled libstdc++ and remove some objects:
|
||||
@ -17,4 +29,3 @@ xtensa-lx106-elf-ar d libstdc++.a del_opv.o
|
||||
xtensa-lx106-elf-ar d libstdc++.a new_op.o
|
||||
xtensa-lx106-elf-ar d libstdc++.a new_opv.o
|
||||
```
|
||||
|
||||
|
@ -1,6 +1,13 @@
|
||||
#!/bin/bash
|
||||
# set -e
|
||||
|
||||
single_sdk="${2}"
|
||||
if [[ -n "$single_sdk" ]]; then
|
||||
if [[ "NONOSDK" != "${single_sdk:0:7}" ]]; then
|
||||
single_sdk=""
|
||||
fi
|
||||
fi
|
||||
|
||||
add_path_ifexist() {
|
||||
if [[ -d $1 ]]; then
|
||||
export PATH=$( realpath $1 ):$PATH
|
||||
@ -24,6 +31,10 @@ EOF
|
||||
}
|
||||
|
||||
list_sdks() {
|
||||
if [[ -n "$single_sdk" ]]; then
|
||||
echo -e "$single_sdk"
|
||||
return
|
||||
fi
|
||||
cat <<EOF
|
||||
NONOSDK22x_190313
|
||||
NONOSDK22x_190703
|
||||
@ -68,7 +79,7 @@ analyze() {
|
||||
done
|
||||
echo ""
|
||||
|
||||
find . -name eap.o -exec md5sum {} \; | sort
|
||||
find . -name eap.o -exec md5sum {} \; | sort -k2
|
||||
echo ""
|
||||
|
||||
unset prev_sdk
|
||||
|
@ -42,6 +42,58 @@ patchFile() {
|
||||
fi
|
||||
}
|
||||
|
||||
grepPatchFiles() {
|
||||
local SDKVER OLDNAME NEWNAME FILES OLDNAME64 NEWNAME64 FILE OFFSET PATTERN
|
||||
SDKVER="${1}"
|
||||
OLDNAME="${2}"
|
||||
NEWNAME="${3}"
|
||||
FILES="${4}"
|
||||
[[ "${SDKVER:0:9}" != "NONOSDK30" ]] && return
|
||||
if [[ -z "${FILES}" ]]; then
|
||||
echo "grepPatchFile: bad input: file specification required"
|
||||
exit 1
|
||||
fi
|
||||
if [[ "${#OLDNAME}" != "${#NEWNAME}" ]]; then
|
||||
echo "grepPatchFile: bad input: old name ${OLDNAME}(${#OLDNAME}) and new name ${NEWNAME}(${#NEWNAME}) must be the same length."
|
||||
exit 1
|
||||
fi
|
||||
OLDNAME64=( `echo -n "${OLDNAME}" | base64 -w0` )
|
||||
NEWNAME64=( `echo -n "${NEWNAME}" | base64 -w0` )
|
||||
|
||||
while read -u3 FILE OFFSET PATTERN; do
|
||||
if [[ "${#OLDNAME}" == "${#PATTERN}" ]] && [[ "${OLDNAME}" == "${PATTERN}" ]]; then
|
||||
patchFile "$FILE" "$OFFSET" "${#PATTERN}" "${OLDNAME64}" "${NEWNAME64}"
|
||||
else
|
||||
echo "grepPatchFile: bad parameters FILE=${FILE} OFFSET=${OFFSET} PATTERN=${PATTERN}"
|
||||
exit 1
|
||||
fi
|
||||
done 3< <( grep --with-filename --byte-offset --only-matching --text "${OLDNAME}" $FILES | tr ":" " " )
|
||||
return
|
||||
}
|
||||
|
||||
redefineSym() {
|
||||
local SDKVER OLDNAME NEWNAME FILES FILE EXTRA PATTERN
|
||||
SDKVER="${1}"
|
||||
OLDNAME="${2}"
|
||||
NEWNAME="${3}"
|
||||
FILES="${4}"
|
||||
[[ "${SDKVER:0:9}" != "NONOSDK30" ]] && return
|
||||
if [[ -z "${FILES}" ]]; then
|
||||
echo "redefineSym: bad input: file specification required"
|
||||
exit 1
|
||||
fi
|
||||
PATTERN="UND ${OLDNAME}"
|
||||
for FILE in $FILES ; do
|
||||
echo "xtensa-lx106-elf-objcopy --redefine-sym ${OLDNAME}=${NEWNAME} \"$FILE\""
|
||||
echo "Before:"
|
||||
xtensa-lx106-elf-nm "$FILE" | grep ${OLDNAME} | sort -u
|
||||
xtensa-lx106-elf-objcopy --redefine-sym ${OLDNAME}=${NEWNAME} "$FILE"
|
||||
echo "After:"
|
||||
xtensa-lx106-elf-nm "$FILE" | grep ${OLDNAME} | sort -u
|
||||
done
|
||||
return
|
||||
}
|
||||
|
||||
# # xtensa-lx106-elf-ar x libwpa2.a eap.o
|
||||
if [[ "--shell" == "$1" ]]; then
|
||||
# need to poke around a bit
|
||||
@ -81,12 +133,28 @@ elif [[ ${VERSION} == "NONOSDK22x"* ]]; then
|
||||
addSymbol_system_func1 "0x54"
|
||||
patchFile "eap.o" "3059" "2" "wAA=" "8CA=" # WPA2-Enterprise patch which replaces a double-free with nop, see #8082
|
||||
patchFile "eap.o" "26356" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
elif [[ ${VERSION} == "NONOSDK3V0"* ]]; then
|
||||
elif [[ ${VERSION} == "NONOSDK3V0" ]]; then
|
||||
addSymbol_system_func1 "0x60"
|
||||
patchFile "eap.o" "3059" "2" "wAA=" "8CA=" # WPA2-Enterprise patch which replaces a double-free with nop, see #8082
|
||||
patchFile "eap.o" "26356" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
elif [[ ${VERSION} == "NONOSDK3"* ]]; then
|
||||
elif [[ ${VERSION} == "NONOSDK300" ]]; then
|
||||
addSymbol_system_func1 "0x54"
|
||||
patchFile "eap.o" "19204" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
elif [[ ${VERSION} == "NONOSDK301" ]]; then
|
||||
addSymbol_system_func1 "0x54"
|
||||
patchFile "eap.o" "26364" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
elif [[ ${VERSION} == "NONOSDK302" ]]; then
|
||||
addSymbol_system_func1 "0x54"
|
||||
patchFile "eap.o" "26536" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
elif [[ ${VERSION} == "NONOSDK303" ]]; then
|
||||
addSymbol_system_func1 "0x54"
|
||||
patchFile "eap.o" "26536" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
elif [[ ${VERSION} == "NONOSDK304" ]]; then
|
||||
addSymbol_system_func1 "0x54"
|
||||
patchFile "eap.o" "19376" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
elif [[ ${VERSION} == "NONOSDK305" ]]; then
|
||||
addSymbol_system_func1 "0x54"
|
||||
patchFile "eap.o" "67670" "9" "dlBvcnRGcmVl" "ejJFYXBGcmVl" # special vPortFree to recover leaked memory
|
||||
else
|
||||
echo "WARN: Unknown address for system_func1() called by system_restart_local()"
|
||||
fi
|
||||
@ -98,3 +166,12 @@ if [[ $(sha256sum user_interface.o | awk '{print $1}') != $uics || $(sha256sum e
|
||||
xtensa-lx106-elf-ar r libmain.a eagle_lwip_if.o user_interface.o
|
||||
fi
|
||||
rm -f eagle_lwip_if.o user_interface.o eap.o
|
||||
|
||||
if [[ ${VERSION} == "NONOSDK3V0" ]]; then
|
||||
xtensa-lx106-elf-objcopy --weaken-symbol load_non_32_wide_handler libmain.a
|
||||
elif [[ ${VERSION:0:9} == "NONOSDK30" ]]; then
|
||||
# v3.0.0 and up use a non-standard pvPortMalloc.
|
||||
# SDK Library global replace
|
||||
redefineSym "${VERSION}" "pvPortMalloc" "sdk3_pvPortMalloc" '*.a'
|
||||
xtensa-lx106-elf-objcopy --weaken-symbol load_non_32_wide_handler libmain.a
|
||||
fi
|
||||
|
Reference in New Issue
Block a user