mirror of
https://github.com/topjohnwu/Magisk.git
synced 2025-01-12 02:03:39 +00:00
Don't use xwrite() when patching legacy rootfs init
Fix topjohnwu#4810 > [ 2.927463] [1: init: 1] magiskinit: Replace [/system/etc/selinux/plat_sepolicy.cil] -> [xxx] [ 2.936801] [1: init: 1] magiskinit: write failed with 14: Bad address Since topjohnwu#4596, magisk fails to patch `/init`, xwrite() fails with EFAULT, break the original `/init` file and make the device unbootable. Reverting this commit for legacy rootfs devices fixes the problem. I think this is a Samsung kernel magic since currently I can't reproduce this on other devices or find something special in the log currently we have.
This commit is contained in:
parent
89c2c21774
commit
e3f6399473
@ -343,11 +343,16 @@ void RootFSBase::patch_rootfs() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (patch_sepolicy("/sepolicy")) {
|
if (patch_sepolicy("/sepolicy")) {
|
||||||
auto init = mmap_data::ro(access("/system/bin/init",F_OK) == 0 ? "/system/bin/init" : "/init");
|
if (access("/system/bin/init", F_OK) == 0) {
|
||||||
|
auto init = mmap_data::ro("/system/bin/init");
|
||||||
init.patch({ make_pair(SPLIT_PLAT_CIL, "xxx") });
|
init.patch({ make_pair(SPLIT_PLAT_CIL, "xxx") });
|
||||||
int dest = xopen("/init", O_TRUNC | O_WRONLY | O_CLOEXEC, 0);
|
int dest = xopen("/init", O_TRUNC | O_WRONLY | O_CLOEXEC, 0);
|
||||||
xwrite(dest, init.buf, init.sz);
|
xwrite(dest, init.buf, init.sz);
|
||||||
close(dest);
|
close(dest);
|
||||||
|
} else {
|
||||||
|
auto init = mmap_data::rw("/init");
|
||||||
|
init.patch({ make_pair(SPLIT_PLAT_CIL, "xxx") });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle overlays
|
// Handle overlays
|
||||||
|
Loading…
x
Reference in New Issue
Block a user