mirror of
				https://github.com/topjohnwu/Magisk.git
				synced 2025-10-25 07:09:14 +00:00 
			
		
		
		
	Invalidate Samsung's persist.sys.zygote.early
Samsung FDE devices with the "persist.sys.zygote.early=true" property will cause Zygote to start before post-fs-data. According to Magisk's document, the post-fs-data phase should always happen before Zygote is started. Features assuming this behavior (like Zygisk and modules that need to control zygote) will not work. To avoid breaking existing modules, we simply invalidate this property to prevent this non-standard behavior from happening Fix #5299, fix #5328, fix #5308 Co-authored-by: LoveSy <shana@zju.edu.cn>
This commit is contained in:
		| @@ -31,6 +31,12 @@ static void patch_init_rc(const char *src, const char *dest, const char *tmp_dir | |||||||
|             fprintf(rc, "service flash_recovery /system/bin/xxxxx\n"); |             fprintf(rc, "service flash_recovery /system/bin/xxxxx\n"); | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|  |         // Samsung's persist.sys.zygote.early will start zygotes before actual post-fs-data phase | ||||||
|  |         if (str_starts(line, "on property:persist.sys.zygote.early=")) { | ||||||
|  |             LOGD("Invalidate persist.sys.zygote.early\n"); | ||||||
|  |             fprintf(rc, "on property:persist.sys.zygote.early.xxxxx=true\n"); | ||||||
|  |             return true; | ||||||
|  |         } | ||||||
|         // Else just write the line |         // Else just write the line | ||||||
|         fprintf(rc, "%s", line.data()); |         fprintf(rc, "%s", line.data()); | ||||||
|         return true; |         return true; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 残页
					残页