Skip to content

Commit

Permalink
dev-embedded/esp-idf: add patch for invalid type conversion error
Browse files Browse the repository at this point in the history
Signed-off-by: David Roman <[email protected]>
  • Loading branch information
stkw0 committed Jul 30, 2024
1 parent b76ef69 commit fc244b1
Show file tree
Hide file tree
Showing 2 changed files with 284 additions and 0 deletions.
159 changes: 159 additions & 0 deletions dev-embedded/esp-idf/esp-idf-5.3-r1.ebuild
Original file line number Diff line number Diff line change
@@ -0,0 +1,159 @@
# Copyright 1999-2024 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2

EAPI=8

PYTHON_COMPAT=( python3_{11,12} )

VER="13.2.0_20240530"
GDB_VER="14.2_20240403"

CROSSTOOL_URL="https://github.com/espressif/crosstool-NG/releases/download/esp-${VER}"

inherit estack python-r1

DESCRIPTION="Espressif IoT Development Framework"
HOMEPAGE="https://www.espressif.com/"

# See https://dl.espressif.com/dl/esp-idf/espidf.constraints.v5.3.txt for information about version dependencies

SRC_URI="https://dl.espressif.com/github_assets/espressif/${PN}/releases/download/v${PV}/${PN}-v${PV}.zip -> ${P}.zip
https://github.com/espressif/openocd-esp32/releases/download/v0.12.0-esp32-20240318/openocd-esp32-linux-amd64-0.12.0-esp32-20240318.tar.gz
https://github.com/espressif/binutils-gdb/releases/download/esp-gdb-v${GDB_VER}/xtensa-esp-elf-gdb-${GDB_VER}-x86_64-linux-gnu.tar.gz"
SRC_URI+=" ${CROSSTOOL_URL}/xtensa-esp-elf-${VER}-x86_64-linux-gnu.tar.xz"
SRC_URI+=" riscv32? (
${CROSSTOOL_URL}/riscv32-esp-elf-${VER}-x86_64-linux-gnu.tar.xz
https://github.com/espressif/binutils-gdb/releases/download/esp-gdb-v${GDB_VER}/riscv32-esp-elf-gdb-${GDB_VER}-x86_64-linux-gnu.tar.gz
)"

S="${WORKDIR}/${PN}-v${PV}"

LICENSE="Apache-2.0"
SLOT="0"
KEYWORDS="~amd64"

IUSE="riscv32"
REQUIRED_USE="${PYTHON_REQUIRED_USE}"

BDEPEND="app-arch/unzip"
RDEPEND="
${PYTHON_DEPS}
dev-libs/libusb:1
dev-python/click[${PYTHON_USEDEP}]
dev-python/pyserial[${PYTHON_USEDEP}]
dev-python/cryptography[${PYTHON_USEDEP}]
dev-python/pyparsing[${PYTHON_USEDEP}]
dev-python/pyelftools[${PYTHON_USEDEP}]
dev-embedded/esp-coredump[${PYTHON_USEDEP}]
dev-embedded/esptool
dev-embedded/esp-idf-kconfig[${PYTHON_USEDEP}]
dev-embedded/esp-idf-monitor[${PYTHON_USEDEP}]
dev-embedded/esp-idf-panic-decoder[${PYTHON_USEDEP}]
dev-embedded/esp-idf-size[${PYTHON_USEDEP}]
dev-embedded/freertos-gdb[${PYTHON_USEDEP}]
dev-embedded/idf-component-manager[${PYTHON_USEDEP}]
sys-libs/zlib
"

RESTRICT="strip"

QA_PREBUILT="opt/* usr/lib* usr/share/esp-idf/*"
QA_PRESTRIPPED="opt/*"

PATCHES=(
"${FILESDIR}/allow-system-install-${PN}-5.3.patch"
"${FILESDIR}/${P}-fix-cpp-build-eth.patch"
)

install_tool() {
eshopts_push -s globstar

into /opt/${1}

if [[ -d "../${1}/lib" ]]; then
if stat *.so &>/dev/null; then
for i in ../${1}/lib/**/*.so*; do
dolib.so ${i}
done
fi

if stat *.a &>/dev/null; then
for i in ../${1}/lib/**/*.a*; do
dolib.a ${i}
done
fi

insinto /opt/${1}/lib
doins -r ../${1}/lib/*
fi

exeinto /opt/${1}/bin
doexe ../${1}/bin/*
(
cd ../${1}
for i in libexec/**/*; do
exeinto /opt/${1}/$(dirname ${i})
if [[ -x "${i}" && ! -d "${i}" ]]; then
doexe ${i}
fi
done

if [[ -d "include" ]]; then
insinto /opt/${1}
doins -r include
fi

if [[ -d "share" ]]; then
insinto /opt/${1}
doins -r share
fi
)

(
cd "${D}"/opt/${1}/bin/ || die
for i in *; do
dodir /opt/bin
cd "${D}"/opt/bin || die
dosym ../${1}/bin/${i} /opt/bin/${i}
done
)

eshopts_pop
}

src_install() {
newbin - idf <<-EOF
#!/bin/sh
# Silence a warning by idf.py
export IDF_PYTHON_ENV_PATH=
exec python /usr/share/${PN}/tools/idf.py \$@
EOF

install_tool xtensa-esp-elf
install_tool xtensa-esp-elf/xtensa-esp-elf

if use riscv32; then
install_tool riscv32-esp-elf
install_tool riscv32-esp-elf/riscv32-esp-elf
fi

install_tool openocd-esp32

# Remove unsupported python versions
rm "${WORKDIR}"/xtensa-esp-elf-gdb/bin/xtensa-esp-elf-gdb-3.{8..10} || die
install_tool xtensa-esp-elf-gdb
if use riscv32; then
install_tool riscv32-esp-elf-gdb
fi

echo "IDF_PATH=/usr/share/${PN}" > 99esp-idf || die
doenvd 99esp-idf

insinto /usr/share/${PN}

rm -r .git || die
find . -name ".git" -exec rm -rf {} \; || die
doins -r .
}
125 changes: 125 additions & 0 deletions dev-embedded/esp-idf/files/esp-idf-5.3-fix-cpp-build-eth.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
diff --git a/components/esp_eth/include/esp_eth_mac_esp.h b/components/esp_eth/include/esp_eth_mac_esp.h
index 8c4909b8c5..39db373798 100644
--- a/components/esp_eth/include/esp_eth_mac_esp.h
+++ b/components/esp_eth/include/esp_eth_mac_esp.h
@@ -217,64 +217,64 @@ typedef enum {
#error "Unsupported RMII clock mode"
#endif // CONFIG_ETH_RMII_CLK_INPUT

-#define ETH_ESP32_EMAC_DEFAULT_CONFIG() \
- { \
- .smi_gpio = \
- { \
- .mdc_num = 23, \
- .mdio_num = 18 \
- }, \
- .interface = EMAC_DATA_INTERFACE_RMII, \
- .clock_config = \
- { \
- .rmii = \
- { \
- .clock_mode = DEFAULT_RMII_CLK_MODE, \
- .clock_gpio = DEFAULT_RMII_CLK_GPIO \
- } \
- }, \
- .dma_burst_len = ETH_DMA_BURST_LEN_32, \
- .intr_priority = 0, \
+#define ETH_ESP32_EMAC_DEFAULT_CONFIG() \
+ { \
+ .smi_gpio = \
+ { \
+ .mdc_num = 23, \
+ .mdio_num = 18 \
+ }, \
+ .interface = EMAC_DATA_INTERFACE_RMII, \
+ .clock_config = \
+ { \
+ .rmii = \
+ { \
+ .clock_mode = DEFAULT_RMII_CLK_MODE, \
+ .clock_gpio = (emac_rmii_clock_gpio_t) DEFAULT_RMII_CLK_GPIO \
+ } \
+ }, \
+ .dma_burst_len = ETH_DMA_BURST_LEN_32, \
+ .intr_priority = 0, \
}
#elif CONFIG_IDF_TARGET_ESP32P4
-#define ETH_ESP32_EMAC_DEFAULT_CONFIG() \
- { \
- .smi_gpio = \
- { \
- .mdc_num = 31, \
- .mdio_num = 27 \
- }, \
- .interface = EMAC_DATA_INTERFACE_RMII, \
- .clock_config = \
- { \
- .rmii = \
- { \
- .clock_mode = EMAC_CLK_EXT_IN, \
- .clock_gpio = 50 \
- } \
- }, \
- .clock_config_out_in = \
- { \
- .rmii = \
- { \
- .clock_mode = EMAC_CLK_EXT_IN, \
- .clock_gpio = -1 \
- } \
- }, \
- .dma_burst_len = ETH_DMA_BURST_LEN_32, \
- .intr_priority = 0, \
- .emac_dataif_gpio = \
- { \
- .rmii = \
- { \
- .tx_en_num = 49, \
- .txd0_num = 34, \
- .txd1_num = 35, \
- .crs_dv_num = 28, \
- .rxd0_num = 29, \
- .rxd1_num = 30 \
- } \
- }, \
+#define ETH_ESP32_EMAC_DEFAULT_CONFIG() \
+ { \
+ .smi_gpio = \
+ { \
+ .mdc_num = 31, \
+ .mdio_num = 27 \
+ }, \
+ .interface = EMAC_DATA_INTERFACE_RMII, \
+ .clock_config = \
+ { \
+ .rmii = \
+ { \
+ .clock_mode = EMAC_CLK_EXT_IN, \
+ .clock_gpio = (emac_rmii_clock_gpio_t) 50 \
+ } \
+ }, \
+ .clock_config_out_in = \
+ { \
+ .rmii = \
+ { \
+ .clock_mode = EMAC_CLK_EXT_IN, \
+ .clock_gpio = (emac_rmii_clock_gpio_t) -1 \
+ } \
+ }, \
+ .dma_burst_len = ETH_DMA_BURST_LEN_32, \
+ .intr_priority = 0, \
+ .emac_dataif_gpio = \
+ { \
+ .rmii = \
+ { \
+ .tx_en_num = 49, \
+ .txd0_num = 34, \
+ .txd1_num = 35, \
+ .crs_dv_num = 28, \
+ .rxd0_num = 29, \
+ .rxd1_num = 30 \
+ } \
+ }, \
}
#endif // CONFIG_IDF_TARGET_ESP32P4

0 comments on commit fc244b1

Please sign in to comment.