Commit ddcb2885 authored by Harvey Harrison's avatar Harvey Harrison Committed by Avi Kivity

KVM: x86 emulator: add ad_mask static inline

Replaces open-coded mask calculation in macros.
Signed-off-by: default avatarHarvey Harrison <harvey.harrison@gmail.com>
Signed-off-by: default avatarAvi Kivity <avi@qumranet.com>
parent 790c73f6
...@@ -480,10 +480,15 @@ static u16 group2_table[] = { ...@@ -480,10 +480,15 @@ static u16 group2_table[] = {
(_type)_x; \ (_type)_x; \
}) })
static inline unsigned long ad_mask(struct decode_cache *c)
{
return (1UL << (c->ad_bytes << 3)) - 1;
}
/* Access/update address held in a register, based on addressing mode. */ /* Access/update address held in a register, based on addressing mode. */
#define address_mask(reg) \ #define address_mask(reg) \
((c->ad_bytes == sizeof(unsigned long)) ? \ ((c->ad_bytes == sizeof(unsigned long)) ? \
(reg) : ((reg) & ((1UL << (c->ad_bytes << 3)) - 1))) (reg) : ((reg) & ad_mask(c)))
#define register_address(base, reg) \ #define register_address(base, reg) \
((base) + address_mask(reg)) ((base) + address_mask(reg))
#define register_address_increment(reg, inc) \ #define register_address_increment(reg, inc) \
...@@ -494,9 +499,9 @@ static u16 group2_table[] = { ...@@ -494,9 +499,9 @@ static u16 group2_table[] = {
(reg) += _inc; \ (reg) += _inc; \
else \ else \
(reg) = ((reg) & \ (reg) = ((reg) & \
~((1UL << (c->ad_bytes << 3)) - 1)) | \ ~ad_mask(c)) | \
(((reg) + _inc) & \ (((reg) + _inc) & \
((1UL << (c->ad_bytes << 3)) - 1)); \ ad_mask(c)); \
} while (0) } while (0)
#define JMP_REL(rel) \ #define JMP_REL(rel) \
......
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