mirror of
https://github.com/topjohnwu/Magisk.git
synced 2025-12-12 08:22:43 +00:00
Install one single ABI in ramdisk
This commit is contained in:
@@ -41,6 +41,12 @@ static bool magisk_env() {
|
||||
cp_afc(DATABIN "/busybox", buf);
|
||||
exec_command_async(buf, "--install", "-s", dirname(buf));
|
||||
|
||||
// magisk32 and magiskpolicy are not installed into ramdisk and has to be copied
|
||||
// from data to magisk tmp
|
||||
if (access(DATABIN "/magisk32", X_OK) == 0) {
|
||||
ssprintf(buf, sizeof(buf), "%s/magisk32", get_magisk_tmp());
|
||||
cp_afc(DATABIN "/magisk32", buf);
|
||||
}
|
||||
if (access(DATABIN "/magiskpolicy", X_OK) == 0) {
|
||||
ssprintf(buf, sizeof(buf), "%s/magiskpolicy", get_magisk_tmp());
|
||||
cp_afc(DATABIN "/magiskpolicy", buf);
|
||||
|
||||
@@ -203,11 +203,16 @@ public:
|
||||
|
||||
class zygisk_node : public node_entry {
|
||||
public:
|
||||
explicit zygisk_node(const char *name, bool is64bit) : node_entry(name, DT_REG, this),
|
||||
is64bit(is64bit) {}
|
||||
explicit zygisk_node(const char *name, bool is64bit)
|
||||
: node_entry(name, DT_REG, this), is64bit(is64bit) {}
|
||||
|
||||
void mount() override {
|
||||
const string src = get_magisk_tmp() + "/magisk"s + (is64bit ? "64" : "32");
|
||||
#if defined(__LP64__)
|
||||
const string src = get_magisk_tmp() + "/magisk"s + (is64bit ? "" : "32");
|
||||
#else
|
||||
const string src = get_magisk_tmp() + "/magisk"s;
|
||||
(void) is64bit;
|
||||
#endif
|
||||
create_and_mount("zygisk", src, true);
|
||||
}
|
||||
|
||||
|
||||
@@ -97,7 +97,11 @@ static void connect_companion(int client, bool is_64_bit) {
|
||||
zygiskd_socket = fds[0];
|
||||
if (fork_dont_care() == 0) {
|
||||
char exe[64];
|
||||
ssprintf(exe, sizeof(exe), "%s/magisk%s", get_magisk_tmp(), (is_64_bit ? "64" : "32"));
|
||||
#if defined(__LP64__)
|
||||
ssprintf(exe, sizeof(exe), "%s/magisk%s", get_magisk_tmp(), (is_64_bit ? "" : "32"));
|
||||
#else
|
||||
ssprintf(exe, sizeof(exe), "%s/magisk", get_magisk_tmp());
|
||||
#endif
|
||||
// This fd has to survive exec
|
||||
fcntl(fds[1], F_SETFD, 0);
|
||||
char buf[16];
|
||||
|
||||
Reference in New Issue
Block a user