Integrated: 8293618: x86: Wrong code generation in class Assembler

Quan Anh Mai duke at openjdk.org
Fri Sep 23 17:17:00 UTC 2022


On Mon, 12 Sep 2022 15:30:01 GMT, Quan Anh Mai <duke at openjdk.org> wrote:

> Hi,
> 
> This patch fixes some issues in the code generation of x86 assembler:
> 
> - `Assembler::testl` misses `prefix(dst)`
> - `Assembler::addw` misses the 0x66 prefix
> - `Assembler::emit_operand` needs the length of the instruction from the address operand, this is often forgotten, making this parameter explicit to prevent potential issues
> - The assembler should not do optimisations that change the actual emitted instructions, these should be moved to `MacroAssembler` instead
> 
> AFAICT there is no failure due to these mistakes. Please take a look and give reviews.
> Thanks you very much.

This pull request has now been integrated.

Changeset: e2f82514
Author:    Quan Anh Mai <anhmdq99 at gmail.com>
Committer: Vladimir Kozlov <kvn at openjdk.org>
URL:       https://git.openjdk.org/jdk/commit/e2f82514906d483b6e46ff06d8673b77c9f89f08
Stats:     540 lines in 5 files changed: 62 ins; 25 del; 453 mod

8293618: x86: Wrong code generation in class Assembler

Reviewed-by: kvn, thartmann

-------------

PR: https://git.openjdk.org/jdk/pull/10240


More information about the hotspot-dev mailing list