mirror of
https://github.com/esphome/esphome.git
synced 2026-05-28 13:37:24 +08:00
Revert "Merge branch 'benchmark-crypto-o2' into integration"
This reverts commitc58447ad3a, reversing changes made to3b02c6d5ef.
This commit is contained in:
@@ -1,6 +1,5 @@
|
|||||||
import base64
|
import base64
|
||||||
import logging
|
import logging
|
||||||
import pathlib
|
|
||||||
|
|
||||||
from esphome import automation
|
from esphome import automation
|
||||||
from esphome.automation import Condition
|
from esphome.automation import Condition
|
||||||
@@ -459,10 +458,6 @@ async def to_code(config: ConfigType) -> None:
|
|||||||
# Enable optimized memzero/memcmp in libsodium instead of volatile byte loops
|
# Enable optimized memzero/memcmp in libsodium instead of volatile byte loops
|
||||||
cg.add_build_flag("-DHAVE_WEAK_SYMBOLS=1")
|
cg.add_build_flag("-DHAVE_WEAK_SYMBOLS=1")
|
||||||
cg.add_build_flag("-DHAVE_INLINE_ASM=1")
|
cg.add_build_flag("-DHAVE_INLINE_ASM=1")
|
||||||
# Compile crypto libraries with -O2 for speed instead of -Os.
|
|
||||||
# Crypto is CPU-bound and benefits significantly from speed optimization.
|
|
||||||
# GCC uses the last -O flag, so appending -O2 overrides the global -Os.
|
|
||||||
_write_crypto_optimize_script()
|
|
||||||
else:
|
else:
|
||||||
cg.add_define("USE_API_PLAINTEXT")
|
cg.add_define("USE_API_PLAINTEXT")
|
||||||
|
|
||||||
@@ -470,17 +465,6 @@ async def to_code(config: ConfigType) -> None:
|
|||||||
cg.add_global(api_ns.using)
|
cg.add_global(api_ns.using)
|
||||||
|
|
||||||
|
|
||||||
_CRYPTO_OPTIMIZE_SCRIPT = "crypto_optimize.py"
|
|
||||||
|
|
||||||
|
|
||||||
def _write_crypto_optimize_script() -> None:
|
|
||||||
from esphome.helpers import copy_file_if_changed
|
|
||||||
|
|
||||||
script_src = pathlib.Path(__file__).parent / f"{_CRYPTO_OPTIMIZE_SCRIPT}.script"
|
|
||||||
copy_file_if_changed(script_src, CORE.relative_build_path(_CRYPTO_OPTIMIZE_SCRIPT))
|
|
||||||
cg.add_platformio_option("extra_scripts", [f"post:{_CRYPTO_OPTIMIZE_SCRIPT}"])
|
|
||||||
|
|
||||||
|
|
||||||
KEY_VALUE_SCHEMA = cv.Schema({cv.string: cv.templatable(cv.string_strict)})
|
KEY_VALUE_SCHEMA = cv.Schema({cv.string: cv.templatable(cv.string_strict)})
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +0,0 @@
|
|||||||
# Compile libsodium with -O2 for speed instead of the default -Os.
|
|
||||||
# libsodium provides the crypto primitives (Curve25519, ChaCha20, Poly1305)
|
|
||||||
# used by the Noise protocol and benefits significantly from speed optimization.
|
|
||||||
# GCC uses the last -O flag, so appending -O2 overrides the global -Os.
|
|
||||||
Import("env")
|
|
||||||
|
|
||||||
for lb in env.GetLibBuilders():
|
|
||||||
if lb.name == "libsodium":
|
|
||||||
lb.env.Append(CCFLAGS=["-O2"])
|
|
||||||
@@ -26,11 +26,12 @@ CORE_BENCHMARKS_DIR: Path = Path(root_path) / "tests" / "benchmarks" / "core"
|
|||||||
STUBS_DIR: Path = Path(root_path) / "tests" / "benchmarks" / "stubs"
|
STUBS_DIR: Path = Path(root_path) / "tests" / "benchmarks" / "stubs"
|
||||||
|
|
||||||
PLATFORMIO_OPTIONS = {
|
PLATFORMIO_OPTIONS = {
|
||||||
|
"build_unflags": [
|
||||||
|
"-Os", # remove default size-opt
|
||||||
|
],
|
||||||
"build_flags": [
|
"build_flags": [
|
||||||
"-Os", # match firmware optimization level (detects inlining regressions)
|
"-O2", # optimize for speed (CodSpeed recommends RelWithDebInfo)
|
||||||
"-g", # debug symbols for profiling
|
"-g", # debug symbols for profiling
|
||||||
"-ffunction-sections", # required for dead-code stripping with -Os
|
|
||||||
"-fdata-sections", # required for dead-code stripping with -Os
|
|
||||||
"-DUSE_BENCHMARK", # disable WarnIfComponentBlockingGuard in finish()
|
"-DUSE_BENCHMARK", # disable WarnIfComponentBlockingGuard in finish()
|
||||||
f"-I{STUBS_DIR}", # stub headers for ESP32-only components
|
f"-I{STUBS_DIR}", # stub headers for ESP32-only components
|
||||||
],
|
],
|
||||||
|
|||||||
Reference in New Issue
Block a user