Commit 5db585fcde

Jacob Young <jacobly0@users.noreply.github.com>
2025-02-15 01:53:27
x86_64: reuse integer `@divTrunc` for `@divExact`
1 parent f98f5a5
Changed files (1)
src
arch
src/arch/x86_64/CodeGen.zig
@@ -6903,12 +6903,12 @@ fn genBody(cg: *CodeGen, body: []const Air.Inst.Index) InnerError!void {
                 else => unreachable,
                 .div_float, .div_float_optimized => .div_float,
                 .div_exact, .div_exact_optimized => .div_exact,
-            }) else fallback: {
+            }) else {
                 const bin_op = air_datas[@intFromEnum(inst)].bin_op;
-                if (cg.floatBits(cg.typeOf(bin_op.lhs).scalarType(zcu)) == null) break :fallback try cg.airMulDivBinOp(inst, .div_exact);
+                const ty = cg.typeOf(bin_op.lhs);
                 var ops = try cg.tempsFromOperands(inst, .{ bin_op.lhs, bin_op.rhs });
                 var res: [1]Temp = undefined;
-                cg.select(&res, &.{cg.typeOf(bin_op.lhs)}, &ops, comptime &.{ .{
+                (if (cg.floatBits(ty.scalarType(zcu))) |_| cg.select(&res, &.{ty}, &ops, comptime &.{ .{
                     .required_features = .{ .f16c, null, null, null },
                     .src_constraints = .{
                         .{ .scalar_float = .{ .of = .word, .is = .word } },
@@ -7772,10 +7772,13 @@ fn genBody(cg: *CodeGen, body: []const Air.Inst.Index) InnerError!void {
                         .{ ._, ._, .add, .tmp0p, .si(16), ._, ._ },
                         .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
                     } },
-                } }) catch |err| switch (err) {
+                } }) else err: {
+                    assert(air_tag == .div_exact);
+                    res[0] = ops[0].divTruncInts(&ops[1], cg) catch |err| break :err err;
+                }) catch |err| switch (err) {
                     error.SelectFailed => return cg.fail("failed to select {s} {} {} {}", .{
                         @tagName(air_tag),
-                        cg.typeOf(bin_op.lhs).fmt(pt),
+                        ty.fmt(pt),
                         ops[0].tracking(cg),
                         ops[1].tracking(cg),
                     }),
@@ -7785,743 +7788,10 @@ fn genBody(cg: *CodeGen, body: []const Air.Inst.Index) InnerError!void {
             },
             .div_trunc => |air_tag| if (use_old) try cg.airMulDivBinOp(inst, air_tag) else {
                 const bin_op = air_datas[@intFromEnum(inst)].bin_op;
+                const ty = cg.typeOf(bin_op.lhs);
                 var ops = try cg.tempsFromOperands(inst, .{ bin_op.lhs, bin_op.rhs });
                 var res: [1]Temp = undefined;
-                cg.select(&res, &.{cg.typeOf(bin_op.lhs)}, &ops, comptime &.{ .{
-                    .src_constraints = .{ .{ .signed_int = .byte }, .{ .signed_int = .byte }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .mem, .mem, .none } },
-                        .{ .src = .{ .to_gpr, .mem, .none } },
-                        .{ .src = .{ .mem, .to_gpr, .none } },
-                        .{ .src = .{ .to_gpr, .to_gpr, .none } },
-                    },
-                    .dst_temps = .{ .{ .reg = .al }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .movsx, .dst0d, .src0b, ._, ._ },
-                        .{ ._, .i_, .div, .src1b, ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{ .{ .unsigned_int = .byte }, .{ .unsigned_int = .byte }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .mem, .mem, .none } },
-                        .{ .src = .{ .to_gpr, .mem, .none } },
-                        .{ .src = .{ .mem, .to_gpr, .none } },
-                        .{ .src = .{ .to_gpr, .to_gpr, .none } },
-                    },
-                    .dst_temps = .{ .{ .reg = .al }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .movzx, .dst0d, .src0b, ._, ._ },
-                        .{ ._, ._, .div, .src1b, ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{ .{ .signed_int = .word }, .{ .signed_int = .word }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .{ .to_reg = .ax }, .mem, .none } },
-                        .{ .src = .{ .{ .to_reg = .ax }, .to_gpr, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .i16, .kind = .{ .reg = .dx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ref = .src0 }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .cwd, ._, ._, ._, ._ },
-                        .{ ._, .i_, .div, .src1w, ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{ .{ .unsigned_int = .word }, .{ .unsigned_int = .word }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .{ .to_reg = .ax }, .mem, .none } },
-                        .{ .src = .{ .{ .to_reg = .ax }, .to_gpr, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .u16, .kind = .{ .reg = .dx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ref = .src0 }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .xor, .tmp0d, .tmp0d, ._, ._ },
-                        .{ ._, ._, .div, .src1w, ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{ .{ .signed_int = .dword }, .{ .signed_int = .dword }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .{ .to_reg = .eax }, .mem, .none } },
-                        .{ .src = .{ .{ .to_reg = .eax }, .to_gpr, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .i32, .kind = .{ .reg = .edx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ref = .src0 }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .cdq, ._, ._, ._, ._ },
-                        .{ ._, .i_, .div, .src1d, ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{ .{ .unsigned_int = .dword }, .{ .unsigned_int = .dword }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .{ .to_reg = .eax }, .mem, .none } },
-                        .{ .src = .{ .{ .to_reg = .eax }, .to_gpr, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .u32, .kind = .{ .reg = .edx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ref = .src0 }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .xor, .tmp0d, .tmp0d, ._, ._ },
-                        .{ ._, ._, .div, .src1d, ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{ .{ .signed_int = .qword }, .{ .signed_int = .qword }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .{ .to_reg = .rax }, .mem, .none } },
-                        .{ .src = .{ .{ .to_reg = .rax }, .to_gpr, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .i64, .kind = .{ .reg = .rdx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ref = .src0 }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .cqo, ._, ._, ._, ._ },
-                        .{ ._, .i_, .div, .src1q, ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{ .{ .unsigned_int = .qword }, .{ .unsigned_int = .qword }, .any },
-                    .patterns = &.{
-                        .{ .src = .{ .{ .to_reg = .rax }, .mem, .none } },
-                        .{ .src = .{ .{ .to_reg = .rax }, .to_gpr, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .u64, .kind = .{ .reg = .rdx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ref = .src0 }, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .xor, .tmp0q, .tmp0q, ._, ._ },
-                        .{ ._, ._, .div, .src1q, ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{ .{ .signed_int = .xword }, .{ .signed_int = .xword }, .any },
-                    .patterns = &.{
-                        .{ .src = .{
-                            .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 0 } },
-                            .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 2 } },
-                            .none,
-                        } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divti3" } } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ret_gpr_pair = .{ .cc = .ccc, .index = 0 } }, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .call, .tmp0d, ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{ .{ .unsigned_int = .xword }, .{ .unsigned_int = .xword }, .any },
-                    .patterns = &.{
-                        .{ .src = .{
-                            .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 0 } },
-                            .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 2 } },
-                            .none,
-                        } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivti3" } } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .{ .ret_gpr_pair = .{ .cc = .ccc, .index = 0 } }, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .call, .tmp0d, ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .remainder_signed_int = .{ .of = .dword, .is = .dword } },
-                        .{ .remainder_signed_int = .{ .of = .dword, .is = .dword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mut_mem, .to_mut_mem, .none } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divei4" } } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .lea, .tmp0p, .mem(.dst0), ._, ._ },
-                        .{ ._, ._, .lea, .tmp1p, .mem(.src0), ._, ._ },
-                        .{ ._, ._, .lea, .tmp2p, .mem(.src1), ._, ._ },
-                        .{ ._, ._, .mov, .tmp3d, .sa(.src0, .add_8_size), ._, ._ },
-                        .{ ._, ._, .call, .tmp4d, ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
-                        .{ .remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivei4" } } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .lea, .tmp0p, .mem(.dst0), ._, ._ },
-                        .{ ._, ._, .lea, .tmp1p, .mem(.src0), ._, ._ },
-                        .{ ._, ._, .lea, .tmp2p, .mem(.src1), ._, ._ },
-                        .{ ._, ._, .mov, .tmp3d, .sa(.src0, .add_8_size), ._, ._ },
-                        .{ ._, ._, .call, .tmp4d, ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .slow_incdec, null, null, null },
-                    .src_constraints = .{
-                        .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
-                        .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .i8, .kind = .{ .reg = .al } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .movsx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, .i_, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(1), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{
-                        .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
-                        .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .i8, .kind = .{ .reg = .al } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .movsx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, .i_, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
-                        .{ ._, ._c, .in, .tmp0p, ._, ._, ._ },
-                        .{ ._, ._nz, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .slow_incdec, null, null, null },
-                    .src_constraints = .{
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .u8, .kind = .{ .reg = .al } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .movzx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(1), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .u8, .kind = .{ .reg = .al } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .movzx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
-                        .{ ._, ._c, .in, .tmp0p, ._, ._, ._ },
-                        .{ ._, ._nz, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{
-                        .{ .multiple_scalar_signed_int = .{ .of = .word, .is = .word } },
-                        .{ .multiple_scalar_signed_int = .{ .of = .word, .is = .word } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .i16, .kind = .{ .reg = .ax } },
-                        .{ .type = .i16, .kind = .{ .reg = .dx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .movsx, .tmp1d, .memia(.src0w, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .cwd, ._, ._, ._, ._ },
-                        .{ ._, .i_, .div, .memia(.src1w, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0w, .tmp0, .add_unaligned_size), .tmp1w, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(2), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .word, .is = .word } },
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .word, .is = .word } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .u16, .kind = .{ .reg = .ax } },
-                        .{ .type = .u16, .kind = .{ .reg = .dx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .movzx, .tmp1d, .memia(.src0w, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .xor, .tmp2d, .tmp2d, ._, ._ },
-                        .{ ._, ._, .div, .memia(.src1w, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0w, .tmp0, .add_unaligned_size), .tmp1w, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(2), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{
-                        .{ .multiple_scalar_signed_int = .{ .of = .dword, .is = .dword } },
-                        .{ .multiple_scalar_signed_int = .{ .of = .dword, .is = .dword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .i32, .kind = .{ .reg = .eax } },
-                        .{ .type = .i32, .kind = .{ .reg = .edx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .mov, .tmp1d, .memia(.src0d, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .cdq, ._, ._, ._, ._ },
-                        .{ ._, .i_, .div, .memia(.src1d, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0d, .tmp0, .add_unaligned_size), .tmp1d, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(4), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .src_constraints = .{
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .dword, .is = .dword } },
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .dword, .is = .dword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .u32, .kind = .{ .reg = .eax } },
-                        .{ .type = .u32, .kind = .{ .reg = .edx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .mov, .tmp1d, .memia(.src0d, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .xor, .tmp2d, .tmp2d, ._, ._ },
-                        .{ ._, ._, .div, .memia(.src1d, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0d, .tmp0, .add_unaligned_size), .tmp1d, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(4), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .multiple_scalar_signed_int = .{ .of = .qword, .is = .qword } },
-                        .{ .multiple_scalar_signed_int = .{ .of = .qword, .is = .qword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .i64, .kind = .{ .reg = .rax } },
-                        .{ .type = .i64, .kind = .{ .reg = .rdx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .cqo, ._, ._, ._, ._ },
-                        .{ ._, .i_, .div, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp1q, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(8), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .qword, .is = .qword } },
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .qword, .is = .qword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .u64, .kind = .{ .reg = .rax } },
-                        .{ .type = .u64, .kind = .{ .reg = .rdx } },
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .xor, .tmp2d, .tmp2d, ._, ._ },
-                        .{ ._, ._, .div, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp1q, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(8), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .multiple_scalar_signed_int = .{ .of = .xword, .is = .xword } },
-                        .{ .multiple_scalar_signed_int = .{ .of = .xword, .is = .xword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .{ .type = .i64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
-                        .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
-                        .{ .type = .i64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divti3" } } },
-                        .{ .type = .u64, .kind = .{ .ret_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .mov, .tmp2q, .memiad(.src0q, .tmp0, .add_unaligned_size, 8), ._, ._ },
-                        .{ ._, ._, .mov, .tmp3q, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .mov, .tmp4q, .memiad(.src1q, .tmp0, .add_unaligned_size, 8), ._, ._ },
-                        .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp6q, ._, ._ },
-                        .{ ._, ._, .mov, .memiad(.dst0q, .tmp0, .add_unaligned_size, 8), .tmp3q, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(16), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .xword, .is = .xword } },
-                        .{ .multiple_scalar_unsigned_int = .{ .of = .xword, .is = .xword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mem, .to_mem, .none } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
-                        .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
-                        .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivti3" } } },
-                        .{ .type = .u64, .kind = .{ .ret_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .mov, .tmp2q, .memiad(.src0q, .tmp0, .add_unaligned_size, 8), ._, ._ },
-                        .{ ._, ._, .mov, .tmp3q, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .mov, .tmp4q, .memiad(.src1q, .tmp0, .add_unaligned_size, 8), ._, ._ },
-                        .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
-                        .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp6q, ._, ._ },
-                        .{ ._, ._, .mov, .memiad(.dst0q, .tmp0, .add_unaligned_size, 8), .tmp3q, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .si(16), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .scalar_remainder_signed_int = .{ .of = .dword, .is = .dword } },
-                        .{ .scalar_remainder_signed_int = .{ .of = .dword, .is = .dword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mut_mem, .to_mut_mem, .none } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divei4" } } },
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .lea, .tmp1p, .memia(.dst0, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .lea, .tmp2p, .memia(.src0, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .lea, .tmp3p, .memia(.src1, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .mov, .tmp4d, .sa(.src0, .add_8_elem_size), ._, ._ },
-                        .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .sa(.src0, .add_elem_size), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
-                    .required_features = .{ .@"64bit", null, null, null },
-                    .src_constraints = .{
-                        .{ .scalar_remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
-                        .{ .scalar_remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
-                        .any,
-                    },
-                    .patterns = &.{
-                        .{ .src = .{ .to_mut_mem, .to_mut_mem, .none } },
-                    },
-                    .call_frame = .{ .alignment = .@"16" },
-                    .extra_temps = .{
-                        .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
-                        .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
-                        .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivei4" } } },
-                        .unused,
-                        .unused,
-                        .unused,
-                    },
-                    .dst_temps = .{ .mem, .unused },
-                    .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
-                    .each = .{ .once = &.{
-                        .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
-                        .{ .@"0:", ._, .lea, .tmp1p, .memia(.dst0, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .lea, .tmp2p, .memia(.src0, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .lea, .tmp3p, .memia(.src1, .tmp0, .add_unaligned_size), ._, ._ },
-                        .{ ._, ._, .mov, .tmp4d, .sa(.src0, .add_8_elem_size), ._, ._ },
-                        .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
-                        .{ ._, ._, .add, .tmp0p, .sa(.src0, .add_elem_size), ._, ._ },
-                        .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
-                    } },
-                }, .{
+                (if (cg.floatBits(ty.scalarType(zcu))) |_| cg.select(&res, &.{ty}, &ops, comptime &.{ .{
                     .required_features = .{ .f16c, null, null, null },
                     .src_constraints = .{
                         .{ .scalar_float = .{ .of = .word, .is = .word } },
@@ -9502,10 +8772,12 @@ fn genBody(cg: *CodeGen, body: []const Air.Inst.Index) InnerError!void {
                         .{ ._, ._, .add, .tmp0p, .si(16), ._, ._ },
                         .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
                     } },
-                } }) catch |err| switch (err) {
+                } }) else err: {
+                    res[0] = ops[0].divTruncInts(&ops[1], cg) catch |err| break :err err;
+                }) catch |err| switch (err) {
                     error.SelectFailed => return cg.fail("failed to select {s} {} {} {}", .{
                         @tagName(air_tag),
-                        cg.typeOf(bin_op.lhs).fmt(pt),
+                        ty.fmt(pt),
                         ops[0].tracking(cg),
                         ops[1].tracking(cg),
                     }),
@@ -92399,6 +91671,748 @@ const Temp = struct {
         return res[0];
     }
 
+    fn divTruncInts(lhs: *Temp, rhs: *Temp, cg: *CodeGen) Select.Error!Temp {
+        var ops: [2]Temp = .{ lhs.*, rhs.* };
+        var res: [1]Temp = undefined;
+        try cg.select(&res, &.{lhs.typeOf(cg)}, &ops, comptime &.{ .{
+            .src_constraints = .{ .{ .signed_int = .byte }, .{ .signed_int = .byte }, .any },
+            .patterns = &.{
+                .{ .src = .{ .mem, .mem, .none } },
+                .{ .src = .{ .to_gpr, .mem, .none } },
+                .{ .src = .{ .mem, .to_gpr, .none } },
+                .{ .src = .{ .to_gpr, .to_gpr, .none } },
+            },
+            .dst_temps = .{ .{ .reg = .al }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .movsx, .dst0d, .src0b, ._, ._ },
+                .{ ._, .i_, .div, .src1b, ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{ .{ .unsigned_int = .byte }, .{ .unsigned_int = .byte }, .any },
+            .patterns = &.{
+                .{ .src = .{ .mem, .mem, .none } },
+                .{ .src = .{ .to_gpr, .mem, .none } },
+                .{ .src = .{ .mem, .to_gpr, .none } },
+                .{ .src = .{ .to_gpr, .to_gpr, .none } },
+            },
+            .dst_temps = .{ .{ .reg = .al }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .movzx, .dst0d, .src0b, ._, ._ },
+                .{ ._, ._, .div, .src1b, ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{ .{ .signed_int = .word }, .{ .signed_int = .word }, .any },
+            .patterns = &.{
+                .{ .src = .{ .{ .to_reg = .ax }, .mem, .none } },
+                .{ .src = .{ .{ .to_reg = .ax }, .to_gpr, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .i16, .kind = .{ .reg = .dx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ref = .src0 }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .cwd, ._, ._, ._, ._ },
+                .{ ._, .i_, .div, .src1w, ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{ .{ .unsigned_int = .word }, .{ .unsigned_int = .word }, .any },
+            .patterns = &.{
+                .{ .src = .{ .{ .to_reg = .ax }, .mem, .none } },
+                .{ .src = .{ .{ .to_reg = .ax }, .to_gpr, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .u16, .kind = .{ .reg = .dx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ref = .src0 }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .xor, .tmp0d, .tmp0d, ._, ._ },
+                .{ ._, ._, .div, .src1w, ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{ .{ .signed_int = .dword }, .{ .signed_int = .dword }, .any },
+            .patterns = &.{
+                .{ .src = .{ .{ .to_reg = .eax }, .mem, .none } },
+                .{ .src = .{ .{ .to_reg = .eax }, .to_gpr, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .i32, .kind = .{ .reg = .edx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ref = .src0 }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .cdq, ._, ._, ._, ._ },
+                .{ ._, .i_, .div, .src1d, ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{ .{ .unsigned_int = .dword }, .{ .unsigned_int = .dword }, .any },
+            .patterns = &.{
+                .{ .src = .{ .{ .to_reg = .eax }, .mem, .none } },
+                .{ .src = .{ .{ .to_reg = .eax }, .to_gpr, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .u32, .kind = .{ .reg = .edx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ref = .src0 }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .xor, .tmp0d, .tmp0d, ._, ._ },
+                .{ ._, ._, .div, .src1d, ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{ .{ .signed_int = .qword }, .{ .signed_int = .qword }, .any },
+            .patterns = &.{
+                .{ .src = .{ .{ .to_reg = .rax }, .mem, .none } },
+                .{ .src = .{ .{ .to_reg = .rax }, .to_gpr, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .i64, .kind = .{ .reg = .rdx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ref = .src0 }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .cqo, ._, ._, ._, ._ },
+                .{ ._, .i_, .div, .src1q, ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{ .{ .unsigned_int = .qword }, .{ .unsigned_int = .qword }, .any },
+            .patterns = &.{
+                .{ .src = .{ .{ .to_reg = .rax }, .mem, .none } },
+                .{ .src = .{ .{ .to_reg = .rax }, .to_gpr, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .u64, .kind = .{ .reg = .rdx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ref = .src0 }, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .xor, .tmp0q, .tmp0q, ._, ._ },
+                .{ ._, ._, .div, .src1q, ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{ .{ .signed_int = .xword }, .{ .signed_int = .xword }, .any },
+            .patterns = &.{
+                .{ .src = .{
+                    .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 0 } },
+                    .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 2 } },
+                    .none,
+                } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divti3" } } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ret_gpr_pair = .{ .cc = .ccc, .index = 0 } }, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .call, .tmp0d, ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{ .{ .unsigned_int = .xword }, .{ .unsigned_int = .xword }, .any },
+            .patterns = &.{
+                .{ .src = .{
+                    .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 0 } },
+                    .{ .to_param_gpr_pair = .{ .cc = .ccc, .index = 2 } },
+                    .none,
+                } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivti3" } } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .{ .ret_gpr_pair = .{ .cc = .ccc, .index = 0 } }, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .call, .tmp0d, ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .remainder_signed_int = .{ .of = .dword, .is = .dword } },
+                .{ .remainder_signed_int = .{ .of = .dword, .is = .dword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mut_mem, .to_mut_mem, .none } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divei4" } } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .lea, .tmp0p, .mem(.dst0), ._, ._ },
+                .{ ._, ._, .lea, .tmp1p, .mem(.src0), ._, ._ },
+                .{ ._, ._, .lea, .tmp2p, .mem(.src1), ._, ._ },
+                .{ ._, ._, .mov, .tmp3d, .sa(.src0, .add_8_size), ._, ._ },
+                .{ ._, ._, .call, .tmp4d, ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
+                .{ .remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivei4" } } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .lea, .tmp0p, .mem(.dst0), ._, ._ },
+                .{ ._, ._, .lea, .tmp1p, .mem(.src0), ._, ._ },
+                .{ ._, ._, .lea, .tmp2p, .mem(.src1), ._, ._ },
+                .{ ._, ._, .mov, .tmp3d, .sa(.src0, .add_8_size), ._, ._ },
+                .{ ._, ._, .call, .tmp4d, ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .slow_incdec, null, null, null },
+            .src_constraints = .{
+                .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
+                .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .i8, .kind = .{ .reg = .al } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .movsx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, .i_, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(1), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{
+                .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
+                .{ .multiple_scalar_signed_int = .{ .of = .byte, .is = .byte } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .i8, .kind = .{ .reg = .al } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .movsx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, .i_, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
+                .{ ._, ._c, .in, .tmp0p, ._, ._, ._ },
+                .{ ._, ._nz, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .slow_incdec, null, null, null },
+            .src_constraints = .{
+                .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
+                .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .u8, .kind = .{ .reg = .al } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .movzx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(1), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{
+                .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
+                .{ .multiple_scalar_unsigned_int = .{ .of = .byte, .is = .byte } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .u8, .kind = .{ .reg = .al } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .movzx, .tmp1d, .memia(.src0b, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .div, .memia(.src1b, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0b, .tmp0, .add_unaligned_size), .tmp1b, ._, ._ },
+                .{ ._, ._c, .in, .tmp0p, ._, ._, ._ },
+                .{ ._, ._nz, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{
+                .{ .multiple_scalar_signed_int = .{ .of = .word, .is = .word } },
+                .{ .multiple_scalar_signed_int = .{ .of = .word, .is = .word } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .i16, .kind = .{ .reg = .ax } },
+                .{ .type = .i16, .kind = .{ .reg = .dx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .movsx, .tmp1d, .memia(.src0w, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .cwd, ._, ._, ._, ._ },
+                .{ ._, .i_, .div, .memia(.src1w, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0w, .tmp0, .add_unaligned_size), .tmp1w, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(2), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{
+                .{ .multiple_scalar_unsigned_int = .{ .of = .word, .is = .word } },
+                .{ .multiple_scalar_unsigned_int = .{ .of = .word, .is = .word } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .u16, .kind = .{ .reg = .ax } },
+                .{ .type = .u16, .kind = .{ .reg = .dx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .movzx, .tmp1d, .memia(.src0w, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .xor, .tmp2d, .tmp2d, ._, ._ },
+                .{ ._, ._, .div, .memia(.src1w, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0w, .tmp0, .add_unaligned_size), .tmp1w, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(2), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{
+                .{ .multiple_scalar_signed_int = .{ .of = .dword, .is = .dword } },
+                .{ .multiple_scalar_signed_int = .{ .of = .dword, .is = .dword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .i32, .kind = .{ .reg = .eax } },
+                .{ .type = .i32, .kind = .{ .reg = .edx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .mov, .tmp1d, .memia(.src0d, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .cdq, ._, ._, ._, ._ },
+                .{ ._, .i_, .div, .memia(.src1d, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0d, .tmp0, .add_unaligned_size), .tmp1d, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(4), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .src_constraints = .{
+                .{ .multiple_scalar_unsigned_int = .{ .of = .dword, .is = .dword } },
+                .{ .multiple_scalar_unsigned_int = .{ .of = .dword, .is = .dword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .u32, .kind = .{ .reg = .eax } },
+                .{ .type = .u32, .kind = .{ .reg = .edx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .mov, .tmp1d, .memia(.src0d, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .xor, .tmp2d, .tmp2d, ._, ._ },
+                .{ ._, ._, .div, .memia(.src1d, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0d, .tmp0, .add_unaligned_size), .tmp1d, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(4), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .multiple_scalar_signed_int = .{ .of = .qword, .is = .qword } },
+                .{ .multiple_scalar_signed_int = .{ .of = .qword, .is = .qword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .i64, .kind = .{ .reg = .rax } },
+                .{ .type = .i64, .kind = .{ .reg = .rdx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .cqo, ._, ._, ._, ._ },
+                .{ ._, .i_, .div, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp1q, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(8), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .multiple_scalar_unsigned_int = .{ .of = .qword, .is = .qword } },
+                .{ .multiple_scalar_unsigned_int = .{ .of = .qword, .is = .qword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .u64, .kind = .{ .reg = .rax } },
+                .{ .type = .u64, .kind = .{ .reg = .rdx } },
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .xor, .tmp2d, .tmp2d, ._, ._ },
+                .{ ._, ._, .div, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp1q, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(8), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .multiple_scalar_signed_int = .{ .of = .xword, .is = .xword } },
+                .{ .multiple_scalar_signed_int = .{ .of = .xword, .is = .xword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .{ .type = .i64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
+                .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
+                .{ .type = .i64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divti3" } } },
+                .{ .type = .u64, .kind = .{ .ret_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .mov, .tmp2q, .memiad(.src0q, .tmp0, .add_unaligned_size, 8), ._, ._ },
+                .{ ._, ._, .mov, .tmp3q, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .mov, .tmp4q, .memiad(.src1q, .tmp0, .add_unaligned_size, 8), ._, ._ },
+                .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp6q, ._, ._ },
+                .{ ._, ._, .mov, .memiad(.dst0q, .tmp0, .add_unaligned_size, 8), .tmp3q, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(16), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .multiple_scalar_unsigned_int = .{ .of = .xword, .is = .xword } },
+                .{ .multiple_scalar_unsigned_int = .{ .of = .xword, .is = .xword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mem, .to_mem, .none } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
+                .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
+                .{ .type = .u64, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivti3" } } },
+                .{ .type = .u64, .kind = .{ .ret_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .mov, .tmp1q, .memia(.src0q, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .mov, .tmp2q, .memiad(.src0q, .tmp0, .add_unaligned_size, 8), ._, ._ },
+                .{ ._, ._, .mov, .tmp3q, .memia(.src1q, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .mov, .tmp4q, .memiad(.src1q, .tmp0, .add_unaligned_size, 8), ._, ._ },
+                .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
+                .{ ._, ._, .mov, .memia(.dst0q, .tmp0, .add_unaligned_size), .tmp6q, ._, ._ },
+                .{ ._, ._, .mov, .memiad(.dst0q, .tmp0, .add_unaligned_size, 8), .tmp3q, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .si(16), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .scalar_remainder_signed_int = .{ .of = .dword, .is = .dword } },
+                .{ .scalar_remainder_signed_int = .{ .of = .dword, .is = .dword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mut_mem, .to_mut_mem, .none } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__divei4" } } },
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .lea, .tmp1p, .memia(.dst0, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .lea, .tmp2p, .memia(.src0, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .lea, .tmp3p, .memia(.src1, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .mov, .tmp4d, .sa(.src0, .add_8_elem_size), ._, ._ },
+                .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .sa(.src0, .add_elem_size), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        }, .{
+            .required_features = .{ .@"64bit", null, null, null },
+            .src_constraints = .{
+                .{ .scalar_remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
+                .{ .scalar_remainder_unsigned_int = .{ .of = .dword, .is = .dword } },
+                .any,
+            },
+            .patterns = &.{
+                .{ .src = .{ .to_mut_mem, .to_mut_mem, .none } },
+            },
+            .call_frame = .{ .alignment = .@"16" },
+            .extra_temps = .{
+                .{ .type = .isize, .kind = .{ .rc = .general_purpose } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 0 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 1 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 2 } } },
+                .{ .type = .usize, .kind = .{ .param_gpr = .{ .cc = .ccc, .index = 3 } } },
+                .{ .type = .usize, .kind = .{ .symbol = &.{ .name = "__udivei4" } } },
+                .unused,
+                .unused,
+                .unused,
+            },
+            .dst_temps = .{ .mem, .unused },
+            .clobbers = .{ .eflags = true, .caller_preserved = .ccc },
+            .each = .{ .once = &.{
+                .{ ._, ._, .mov, .tmp0p, .sa(.src0, .sub_unaligned_size), ._, ._ },
+                .{ .@"0:", ._, .lea, .tmp1p, .memia(.dst0, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .lea, .tmp2p, .memia(.src0, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .lea, .tmp3p, .memia(.src1, .tmp0, .add_unaligned_size), ._, ._ },
+                .{ ._, ._, .mov, .tmp4d, .sa(.src0, .add_8_elem_size), ._, ._ },
+                .{ ._, ._, .call, .tmp5d, ._, ._, ._ },
+                .{ ._, ._, .add, .tmp0p, .sa(.src0, .add_elem_size), ._, ._ },
+                .{ ._, ._nc, .j, .@"0b", ._, ._, ._ },
+            } },
+        } });
+        lhs.*, rhs.* = ops;
+        return res[0];
+    }
+
     fn finish(
         temp: Temp,
         inst: Air.Inst.Index,