Skip to content

Commit

Permalink
addpatch: electron33 33.0.0-1
Browse files Browse the repository at this point in the history
Changes at riscv-forks/electron:

Update patchset for electron33(chromium 130):
riscv-forks/electron@c7dff70

Packaging changes compared to electron 32:

Use native rollup instead of wasm rollup, to workaround wasm errors
like:

RuntimeError: Command '/build/electron33/src/src/third_party/node/linux/node-linux-x64/bin/node /build/electron33/src/src/third_party/node/node_modules/@rollup/wasm-node/dist/bin/rollup /build/electron33/src/src/out/Release/gen/third_pa
rty/lit/v3_0/lit.js --format esm --dir /build/electron33/src/src/out/Release/gen/third_party/lit/v3_0/bundled --entryFileNames [name].rollup.js --sourcemap --sourcemapExcludeSources --config ../../third_party/lit/v3_0/rollup.config.mjs'
 failed

/build/electron33/src/src/out/Release/gen/third_party/lit/v3_0/lit.js → gen/third_party/lit/v3_0/bundled...
[!] RuntimeError: unreachable
    at null.<anonymous> (wasm://wasm/005abe4a:1:1224394)
    at null.<anonymous> (wasm://wasm/005abe4a:1:1353214)
    at null.<anonymous> (wasm://wasm/005abe4a:1:998801)
    at null.<anonymous> (wasm://wasm/005abe4a:1:95196)
    at null.<anonymous> (wasm://wasm/005abe4a:1:93978)
    at null.<anonymous> (wasm://wasm/005abe4a:1:1037939)
    at null.<anonymous> (wasm://wasm/005abe4a:1:93359)
    at null.<anonymous> (wasm://wasm/005abe4a:1:91561)
    at null.<anonymous> (wasm://wasm/005abe4a:1:93978)
    at null.<anonymous> (wasm://wasm/005abe4a:1:218801)

I am not familiar with wasm debugging. Not sure if it is a v8 bug.
  • Loading branch information
kxxt committed Oct 23, 2024
1 parent 859478e commit 4b8eeba
Show file tree
Hide file tree
Showing 2 changed files with 197 additions and 0 deletions.
47 changes: 47 additions & 0 deletions electron33/Debian-fix-rust-linking.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
--- build/toolchain/gcc_toolchain.gni.orig 2024-08-19 14:13:35.233954725 +0200
+++ build/toolchain/gcc_toolchain.gni 2024-08-22 00:56:01.438433033 +0200
@@ -441,7 +441,13 @@
# -soname flag is not available on aix ld
soname_flag = "-Wl,-soname=\"$soname\""
}
- link_command = "$ld -shared $soname_flag {{ldflags}}${extra_ldflags} -o \"$unstripped_sofile\" @\"$rspfile\" {{rlibs}}"
+ if (target_cpu == "riscv64") {
+ # Work around linker failures due to Rust libraries and the use of whole-archive
+ link_command = "$ld -shared $soname_flag -Wl,--start-group {{ldflags}}${extra_ldflags} -o \"$unstripped_sofile\" @\"$rspfile\" {{rlibs}} -Wl,--end-group"
+ }
+ else {
+ link_command = "$ld -shared $soname_flag {{ldflags}}${extra_ldflags} -o \"$unstripped_sofile\" @\"$rspfile\" {{rlibs}}"
+ }

# Generate a map file to be used for binary size analysis.
# Map file adds ~10% to the link time on a z620.
@@ -553,7 +559,13 @@
whole_archive_flag = "-Wl,--whole-archive"
no_whole_archive_flag = "-Wl,--no-whole-archive"
}
- command = "$ld -shared {{ldflags}}${extra_ldflags} -o \"$unstripped_sofile\" $soname_flag @\"$rspfile\""
+ if (target_cpu == "riscv64") {
+ # Work around linker failures due to Rust libraries and the use of whole-archive
+ command = "$ld -shared -Wl,--start-group {{ldflags}}${extra_ldflags} -o \"$unstripped_sofile\" $soname_flag @\"$rspfile\" -Wl,--end-group"
+ }
+ else {
+ command = "$ld -shared {{ldflags}}${extra_ldflags} -o \"$unstripped_sofile\" $soname_flag @\"$rspfile\""
+ }

if (defined(invoker.strip)) {
strip_command = "${invoker.strip} -o \"$sofile\" \"$unstripped_sofile\""
@@ -617,8 +629,12 @@
# We need to specify link groups, at least, for single pass linkers. I.e.
# Rust libraries are alpha-sorted instead of by dependencies so they fail
# to link if not properly ordered or grouped.
- link_command = "$ld {{ldflags}}${extra_ldflags} -o \"$unstripped_outfile\" $start_group_flag @\"$rspfile\" $end_group_flag {{solibs}} {{libs}} $start_group_flag {{rlibs}} $end_group_flag"
-
+ if (target_cpu == "riscv64") {
+ link_command = "$ld -Wl,--start-group {{ldflags}}${extra_ldflags} -o \"$unstripped_outfile\" @\"$rspfile\" {{solibs}} {{libs}} {{rlibs}} -Wl,--end-group"
+ }
+ else {
+ link_command = "$ld {{ldflags}}${extra_ldflags} -o \"$unstripped_outfile\" $start_group_flag @\"$rspfile\" $end_group_flag {{solibs}} {{libs}} $start_group_flag {{rlibs}} $end_group_flag"
+ }
# Generate a map file to be used for binary size analysis.
# Map file adds ~10% to the link time on a z620.
# With target_os="android", libchrome.so.map.gz is ~20MB.
150 changes: 150 additions & 0 deletions electron33/riscv64.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,150 @@
--- PKGBUILD
+++ PKGBUILD
@@ -29,10 +29,12 @@ depends=(c-ares
makedepends=(clang
git
gn
+ go
gperf
harfbuzz-icu
http-parser
java-runtime-headless
+ jq
libnotify
libva
lld
@@ -63,7 +65,7 @@ optdepends=('kde-cli-tools: file deletion support (kioclient5)'
'trash-cli: file deletion support (trash-put)'
'xdg-utils: open URLs with desktop’s default (xdg-email, xdg-open)')
options=('!lto') # Electron adds its own flags for ThinLTO
-source=("git+https://github.com/electron/electron.git#tag=v$pkgver"
+source=("git+https://github.com/riscv-forks/electron.git#branch=v$pkgver-riscv"
https://gitlab.com/Matt.Jolly/chromium-patches/-/archive/$_gcc_patches/chromium-patches-$_gcc_patches.tar.bz2
# Chromium
compiler-rt-adjust-paths.patch
@@ -74,6 +76,7 @@ source=("git+https://github.com/electron/electron.git#tag=v$pkgver"
electron.desktop
jinja-python-3.10.patch
use-system-libraries-in-node.patch
+ Debian-fix-rust-linking.patch
makepkg-source-roller.py
# BEGIN managed sources
chromium-mirror::git+https://github.com/chromium/chromium.git#tag=130.0.6723.44
@@ -242,13 +245,14 @@ source=("git+https://github.com/electron/electron.git#tag=v$pkgver"
)
sha256sums=('098351c5b5fbd2903c5f4d2f4b5cf734682447673142e3ba649154e63ae0c5f5'
'b5fd4b943ae307680cd5c2050a01f85ef94d3f880a157eef8d17eb9fa23864f5'
- 'b3de01b7df227478687d7517f61a777450dca765756002c80c4915f271e2d961'
+ '8e128dec0d9416029ea8124e14963c9e0caf897bf60d347a070e393edebdff1c'
'a4a822e135b253c93089a80c679842cc470c6936742767ae09d952646889abd6'
'dd2d248831dd4944d385ebf008426e66efe61d6fdf66f8932c963a12167947b4'
'13fcf26193f4417fd5dfbc82a3f24e5c7a1cce82f729f6a73f1b1d3a7b580b34'
'4484200d90b76830b69eea3a471c103999a3ce86bb2c29e6c14c945bf4102bae'
'55dbe71dbc1f3ab60bf1fa79f7aea7ef1fe76436b1d7df48728a1f8227d2134e'
'ff588a8a4fd2f79eb8a4f11cf1aa151298ffb895be566c57cc355d47f161f53f'
+ '3eb5e621757be3f2984acb76d16cf3571bfe5bbbc71ad230b21aa983041ff5ea'
'2c8cd28cee0e1df1862e801794f210d2b7cac652f943cf94f43c2abe26f2a2f4'
'89a485a9b48e80e65b4bc6ea081d6738217fbfb52910d3deadf9fdf45acf853b'
'0b7a546ee6913c49519c10c293ac530ff381641a8a465fa2e184d6dbe0fb784d'
@@ -459,12 +463,22 @@ prepare() {
cp -r chromium-mirror_third_party_depot_tools depot_tools
export PATH+=":$PWD/depot_tools" DEPOT_TOOLS_UPDATE=0
#export VPYTHON_BYPASS='manually managed python not supported by chrome operations'
+ # Use a known commit that supports riscv64
+ git -C depot_tools checkout --detach 2a18f6d3245450d8c96c843a6584aaea561ef873
+ # Python 3.12 breaks gsutils
+ # Bundled wheels are not available for riscv64
+ sed -i '/wheel: </,$d' depot_tools/.vpython3
+ sed -i '/wheel: </,$d' depot_tools/gsutil.vpython3
+ # Manually install required wheels
+ vpython3 -m pip install httplib2==0.13.1 six==1.10.0 requests==2.31.0

echo "Putting together electron sources"
# Generate gclient gn args file and prepare-electron-source-tree.sh
python makepkg-source-roller.py generate electron/DEPS $pkgname
+ sed -i '/esbuild/d' prepare-electron-source-tree.sh
rbash prepare-electron-source-tree.sh "$CARCH"
mv electron src/electron
+ GOBIN=$(realpath src/third_party/devtools-frontend/src/third_party/esbuild/) go install "github.com/evanw/esbuild/cmd/esbuild@v0.14.13"

echo "Running hooks..."
# depot_tools/gclient.py runhooks
@@ -480,6 +494,12 @@ prepare() {
# src/tools/update_pgo_profiles.py --target=linux update \
# --gs-url-base=chromium-optimization-profiles/pgo_profiles

+ pushd src/third_party/node/
+ sed -i -e 's/@rollup/rollup/' -e "s/'wasm-node',//" node_modules.py
+ local _rollup_ver="$(jq -r .dependencies.\"@rollup/wasm-node\" package.json)"
+ jq ".dependencies.rollup=\"$_rollup_ver\"" package.json > package.json.new
+ mv package.json{.new,}
+ popd
# https://gitlab.archlinux.org/archlinux/packaging/packages/electron32/-/issues/1
src/third_party/node/update_npm_deps

@@ -505,6 +525,8 @@ prepare() {

patch -Np0 -i ../blink-fix-missing-stdlib-include.patch

+ patch -Np0 -i ../Debian-fix-rust-linking.patch
+
## Upstream fixes

# Allow libclang_rt.builtins from compiler-rt >= 16 to be used
@@ -578,6 +600,8 @@ build() {
'enable_hangout_services_extension=true'
'enable_widevine=false'
'enable_nacl=false'
+ 'is_clang=true'
+ "override_electron_version=\"$pkgver\""
)

if [[ -n ${_system_libs[icu]+set} ]]; then
@@ -613,6 +637,10 @@ build() {
CFLAGS+=' -Wno-unknown-warning-option'
CXXFLAGS+=' -Wno-unknown-warning-option'

+ # Remove flags that are causing weird bugs on riscv64
+ CFLAGS=${CFLAGS/-Wp,-D_FORTIFY_SOURCE=2}
+ CXXFLAGS=${CXXFLAGS/-Wp,-D_FORTIFY_SOURCE=2}
+
# Let Chromium set its own symbol level
CFLAGS=${CFLAGS/-g }
CXXFLAGS=${CXXFLAGS/-g }
@@ -660,3 +688,5 @@ package() {
install -Dm644 src/electron/default_app/icon.png \
"${pkgdir}/usr/share/pixmaps/${pkgname}.png" # hicolor has no 1024x1024
}
+
+sha256sums[0]=SKIP
diff --git compiler-rt-adjust-paths.patch compiler-rt-adjust-paths.patch
index 0469220..8ee7f55 100644
--- compiler-rt-adjust-paths.patch
+++ compiler-rt-adjust-paths.patch
@@ -1,8 +1,6 @@
-diff --git a/build/config/clang/BUILD.gn b/build/config/clang/BUILD.gn
-index d4de2e0cca0..57359c32121 100644
---- a/build/config/clang/BUILD.gn
-+++ b/build/config/clang/BUILD.gn
-@@ -130,12 +130,15 @@ template("clang_lib") {
+--- a/build/config/clang/BUILD.gn 2024-03-09 04:32:07.577338262 +0100
++++ b/build/config/clang/BUILD.gn 2024-03-09 04:55:29.376410067 +0100
+@@ -124,14 +124,18 @@
} else if (is_linux || is_chromeos) {
if (current_cpu == "x64") {
_dir = "x86_64-unknown-linux-gnu"
@@ -15,10 +13,13 @@ index d4de2e0cca0..57359c32121 100644
} else if (current_cpu == "arm64") {
_dir = "aarch64-unknown-linux-gnu"
+ _suffix = "-aarch64"
+ } else if (current_cpu == "riscv64") {
+ _dir = "riscv64-unknown-linux-gnu"
++ _suffix = "-riscv64"
} else {
assert(false) # Unhandled cpu type
}
-@@ -166,6 +169,11 @@ template("clang_lib") {
+@@ -162,6 +166,11 @@
assert(false) # Unhandled target platform
}

0 comments on commit 4b8eeba

Please sign in to comment.