Skip to content

Commit

Permalink
Fix iOS 18.0b3 amfi_mac_syscall
Browse files Browse the repository at this point in the history
  • Loading branch information
asdfugil committed Jul 21, 2024
1 parent 7973d54 commit a612a25
Showing 1 changed file with 10 additions and 6 deletions.
16 changes: 10 additions & 6 deletions checkra1n/kpf/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -1091,11 +1091,15 @@ bool kpf_amfi_mac_syscall(struct xnu_pf_patch *patch, uint32_t *opcode_stream) {
panic_at(bl, "Failed to follow call to check_dyld_policy_internal");
}
// Find call to proc_issetuid
uint32_t *ref = find_next_insn(check_dyld_policy_internal, 10, 0x94000000, 0xfc000000);
if((ref[1] & 0xff00001f) != 0x34000000)
{
panic_at(ref, "CBZ missing after call to proc_issetuid");
uint32_t *ref = NULL;
for (size_t i = 0; i < 0x10; i++) {
if ((check_dyld_policy_internal[i] & 0xfc000000) == 0x94000000 // bl
&& (check_dyld_policy_internal[i+1] & 0xff00001f) == 0x34000000) { // cbz
ref = &check_dyld_policy_internal[i];
break;
}
}
if (!ref) panic_at(check_dyld_policy_internal, "Missing call to proc_issetuid");
// Save offset of p_flags
kpf_find_offset_p_flags(follow_call(ref));
// Follow CBZ
Expand Down Expand Up @@ -1134,9 +1138,9 @@ bool kpf_amfi_mac_syscall(struct xnu_pf_patch *patch, uint32_t *opcode_stream) {
}
ref += 2;
}
// Move from high reg, bl, and either tbz, 0 or cmp, 0
uint32_t op = ref[2];
if((ref[0] & 0xfff003ff) != 0xaa1003e0 || (ref[1] & 0xfc000000) != 0x94000000 || ((op & 0xfff8001f) != 0x36000000 && op != 0x7100001f))
// Move from high reg, bl, and either tb(n)z, 0 or cmp, 0
if((ref[0] & 0xfff003ff) != 0xaa1003e0 || (ref[1] & 0xfc000000) != 0x94000000 || ((op & 0xfef8001f) != 0x36000000 && op != 0x7100001f))
{
panic_at(check_dyld_policy_internal, "CMP/TBZ missing after call to %s", entitlement ? "proc_has_entitlement" : "proc_has_get_task_allow");
}
Expand Down

0 comments on commit a612a25

Please sign in to comment.