Commit 73f0d1d7 authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'x86-asm-2024-03-11' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip

Pull x86 asm updates from Ingo Molnar:
 "Two changes to simplify the x86 decoder logic a bit"

* tag 'x86-asm-2024-03-11' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  x86/insn: Directly assign x86_64 state in insn_init()
  x86/insn: Remove superfluous checks from instruction decoding routines
parents 89c572e2 07a5d4bc
...@@ -71,7 +71,7 @@ void insn_init(struct insn *insn, const void *kaddr, int buf_len, int x86_64) ...@@ -71,7 +71,7 @@ void insn_init(struct insn *insn, const void *kaddr, int buf_len, int x86_64)
insn->kaddr = kaddr; insn->kaddr = kaddr;
insn->end_kaddr = kaddr + buf_len; insn->end_kaddr = kaddr + buf_len;
insn->next_byte = kaddr; insn->next_byte = kaddr;
insn->x86_64 = x86_64 ? 1 : 0; insn->x86_64 = x86_64;
insn->opnd_bytes = 4; insn->opnd_bytes = 4;
if (x86_64) if (x86_64)
insn->addr_bytes = 8; insn->addr_bytes = 8;
...@@ -268,11 +268,9 @@ int insn_get_opcode(struct insn *insn) ...@@ -268,11 +268,9 @@ int insn_get_opcode(struct insn *insn)
if (opcode->got) if (opcode->got)
return 0; return 0;
if (!insn->prefixes.got) { ret = insn_get_prefixes(insn);
ret = insn_get_prefixes(insn); if (ret)
if (ret) return ret;
return ret;
}
/* Get first opcode */ /* Get first opcode */
op = get_next(insn_byte_t, insn); op = get_next(insn_byte_t, insn);
...@@ -339,11 +337,9 @@ int insn_get_modrm(struct insn *insn) ...@@ -339,11 +337,9 @@ int insn_get_modrm(struct insn *insn)
if (modrm->got) if (modrm->got)
return 0; return 0;
if (!insn->opcode.got) { ret = insn_get_opcode(insn);
ret = insn_get_opcode(insn); if (ret)
if (ret) return ret;
return ret;
}
if (inat_has_modrm(insn->attr)) { if (inat_has_modrm(insn->attr)) {
mod = get_next(insn_byte_t, insn); mod = get_next(insn_byte_t, insn);
...@@ -386,11 +382,9 @@ int insn_rip_relative(struct insn *insn) ...@@ -386,11 +382,9 @@ int insn_rip_relative(struct insn *insn)
if (!insn->x86_64) if (!insn->x86_64)
return 0; return 0;
if (!modrm->got) { ret = insn_get_modrm(insn);
ret = insn_get_modrm(insn); if (ret)
if (ret) return 0;
return 0;
}
/* /*
* For rip-relative instructions, the mod field (top 2 bits) * For rip-relative instructions, the mod field (top 2 bits)
* is zero and the r/m field (bottom 3 bits) is 0x5. * is zero and the r/m field (bottom 3 bits) is 0x5.
...@@ -417,11 +411,9 @@ int insn_get_sib(struct insn *insn) ...@@ -417,11 +411,9 @@ int insn_get_sib(struct insn *insn)
if (insn->sib.got) if (insn->sib.got)
return 0; return 0;
if (!insn->modrm.got) { ret = insn_get_modrm(insn);
ret = insn_get_modrm(insn); if (ret)
if (ret) return ret;
return ret;
}
if (insn->modrm.nbytes) { if (insn->modrm.nbytes) {
modrm = insn->modrm.bytes[0]; modrm = insn->modrm.bytes[0];
...@@ -460,11 +452,9 @@ int insn_get_displacement(struct insn *insn) ...@@ -460,11 +452,9 @@ int insn_get_displacement(struct insn *insn)
if (insn->displacement.got) if (insn->displacement.got)
return 0; return 0;
if (!insn->sib.got) { ret = insn_get_sib(insn);
ret = insn_get_sib(insn); if (ret)
if (ret) return ret;
return ret;
}
if (insn->modrm.nbytes) { if (insn->modrm.nbytes) {
/* /*
...@@ -628,11 +618,9 @@ int insn_get_immediate(struct insn *insn) ...@@ -628,11 +618,9 @@ int insn_get_immediate(struct insn *insn)
if (insn->immediate.got) if (insn->immediate.got)
return 0; return 0;
if (!insn->displacement.got) { ret = insn_get_displacement(insn);
ret = insn_get_displacement(insn); if (ret)
if (ret) return ret;
return ret;
}
if (inat_has_moffset(insn->attr)) { if (inat_has_moffset(insn->attr)) {
if (!__get_moffset(insn)) if (!__get_moffset(insn))
...@@ -703,11 +691,9 @@ int insn_get_length(struct insn *insn) ...@@ -703,11 +691,9 @@ int insn_get_length(struct insn *insn)
if (insn->length) if (insn->length)
return 0; return 0;
if (!insn->immediate.got) { ret = insn_get_immediate(insn);
ret = insn_get_immediate(insn); if (ret)
if (ret) return ret;
return ret;
}
insn->length = (unsigned char)((unsigned long)insn->next_byte insn->length = (unsigned char)((unsigned long)insn->next_byte
- (unsigned long)insn->kaddr); - (unsigned long)insn->kaddr);
......
...@@ -71,7 +71,7 @@ void insn_init(struct insn *insn, const void *kaddr, int buf_len, int x86_64) ...@@ -71,7 +71,7 @@ void insn_init(struct insn *insn, const void *kaddr, int buf_len, int x86_64)
insn->kaddr = kaddr; insn->kaddr = kaddr;
insn->end_kaddr = kaddr + buf_len; insn->end_kaddr = kaddr + buf_len;
insn->next_byte = kaddr; insn->next_byte = kaddr;
insn->x86_64 = x86_64 ? 1 : 0; insn->x86_64 = x86_64;
insn->opnd_bytes = 4; insn->opnd_bytes = 4;
if (x86_64) if (x86_64)
insn->addr_bytes = 8; insn->addr_bytes = 8;
...@@ -268,11 +268,9 @@ int insn_get_opcode(struct insn *insn) ...@@ -268,11 +268,9 @@ int insn_get_opcode(struct insn *insn)
if (opcode->got) if (opcode->got)
return 0; return 0;
if (!insn->prefixes.got) { ret = insn_get_prefixes(insn);
ret = insn_get_prefixes(insn); if (ret)
if (ret) return ret;
return ret;
}
/* Get first opcode */ /* Get first opcode */
op = get_next(insn_byte_t, insn); op = get_next(insn_byte_t, insn);
...@@ -339,11 +337,9 @@ int insn_get_modrm(struct insn *insn) ...@@ -339,11 +337,9 @@ int insn_get_modrm(struct insn *insn)
if (modrm->got) if (modrm->got)
return 0; return 0;
if (!insn->opcode.got) { ret = insn_get_opcode(insn);
ret = insn_get_opcode(insn); if (ret)
if (ret) return ret;
return ret;
}
if (inat_has_modrm(insn->attr)) { if (inat_has_modrm(insn->attr)) {
mod = get_next(insn_byte_t, insn); mod = get_next(insn_byte_t, insn);
...@@ -386,11 +382,9 @@ int insn_rip_relative(struct insn *insn) ...@@ -386,11 +382,9 @@ int insn_rip_relative(struct insn *insn)
if (!insn->x86_64) if (!insn->x86_64)
return 0; return 0;
if (!modrm->got) { ret = insn_get_modrm(insn);
ret = insn_get_modrm(insn); if (ret)
if (ret) return 0;
return 0;
}
/* /*
* For rip-relative instructions, the mod field (top 2 bits) * For rip-relative instructions, the mod field (top 2 bits)
* is zero and the r/m field (bottom 3 bits) is 0x5. * is zero and the r/m field (bottom 3 bits) is 0x5.
...@@ -417,11 +411,9 @@ int insn_get_sib(struct insn *insn) ...@@ -417,11 +411,9 @@ int insn_get_sib(struct insn *insn)
if (insn->sib.got) if (insn->sib.got)
return 0; return 0;
if (!insn->modrm.got) { ret = insn_get_modrm(insn);
ret = insn_get_modrm(insn); if (ret)
if (ret) return ret;
return ret;
}
if (insn->modrm.nbytes) { if (insn->modrm.nbytes) {
modrm = insn->modrm.bytes[0]; modrm = insn->modrm.bytes[0];
...@@ -460,11 +452,9 @@ int insn_get_displacement(struct insn *insn) ...@@ -460,11 +452,9 @@ int insn_get_displacement(struct insn *insn)
if (insn->displacement.got) if (insn->displacement.got)
return 0; return 0;
if (!insn->sib.got) { ret = insn_get_sib(insn);
ret = insn_get_sib(insn); if (ret)
if (ret) return ret;
return ret;
}
if (insn->modrm.nbytes) { if (insn->modrm.nbytes) {
/* /*
...@@ -628,11 +618,9 @@ int insn_get_immediate(struct insn *insn) ...@@ -628,11 +618,9 @@ int insn_get_immediate(struct insn *insn)
if (insn->immediate.got) if (insn->immediate.got)
return 0; return 0;
if (!insn->displacement.got) { ret = insn_get_displacement(insn);
ret = insn_get_displacement(insn); if (ret)
if (ret) return ret;
return ret;
}
if (inat_has_moffset(insn->attr)) { if (inat_has_moffset(insn->attr)) {
if (!__get_moffset(insn)) if (!__get_moffset(insn))
...@@ -703,11 +691,9 @@ int insn_get_length(struct insn *insn) ...@@ -703,11 +691,9 @@ int insn_get_length(struct insn *insn)
if (insn->length) if (insn->length)
return 0; return 0;
if (!insn->immediate.got) { ret = insn_get_immediate(insn);
ret = insn_get_immediate(insn); if (ret)
if (ret) return ret;
return ret;
}
insn->length = (unsigned char)((unsigned long)insn->next_byte insn->length = (unsigned char)((unsigned long)insn->next_byte
- (unsigned long)insn->kaddr); - (unsigned long)insn->kaddr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment