[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [xen master] x86/vPIC: register only one ELCR handler instance
commit 352c917acfe1dd6afc2eee44aa4ab7c50d4bc48a Author: Jan Beulich <jbeulich@xxxxxxxx> AuthorDate: Tue May 30 12:00:34 2023 +0200 Commit: Jan Beulich <jbeulich@xxxxxxxx> CommitDate: Tue May 30 12:00:34 2023 +0200 x86/vPIC: register only one ELCR handler instance There's no point consuming two port-I/O slots. Even less so considering that some real hardware permits both ports to be accessed in one go, emulating of which requires there to be only a single instance. Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> Reviewed-by: Roger Pau Monné <roger.pau@xxxxxxxxxx> --- xen/arch/x86/hvm/vpic.c | 42 +++++++++++++++++++++++++----------------- 1 file changed, 25 insertions(+), 17 deletions(-) diff --git a/xen/arch/x86/hvm/vpic.c b/xen/arch/x86/hvm/vpic.c index 17e15720f0..2be1cd5855 100644 --- a/xen/arch/x86/hvm/vpic.c +++ b/xen/arch/x86/hvm/vpic.c @@ -377,25 +377,34 @@ static int cf_check vpic_intercept_elcr_io( int dir, unsigned int port, unsigned int bytes, uint32_t *val) { struct hvm_hw_vpic *vpic; - uint32_t data; + unsigned int data, shift = 0; - BUG_ON(bytes != 1); + BUG_ON(bytes > 2 - (port & 1)); vpic = ¤t->domain->arch.hvm.vpic[port & 1]; - if ( dir == IOREQ_WRITE ) - { - /* Some IRs are always edge trig. Slave IR is always level trig. */ - data = *val & vpic_elcr_mask(vpic); - if ( vpic->is_master ) - data |= 1 << 2; - vpic->elcr = data; - } - else - { - /* Reader should not see hardcoded level-triggered slave IR. */ - *val = vpic->elcr & vpic_elcr_mask(vpic); - } + do { + if ( dir == IOREQ_WRITE ) + { + /* Some IRs are always edge trig. Slave IR is always level trig. */ + data = (*val >> shift) & vpic_elcr_mask(vpic); + if ( vpic->is_master ) + data |= 1 << 2; + vpic->elcr = data; + } + else + { + /* Reader should not see hardcoded level-triggered slave IR. */ + data = vpic->elcr & vpic_elcr_mask(vpic); + if ( !shift ) + *val = data; + else + *val |= data << shift; + } + + ++vpic; + shift += 8; + } while ( --bytes ); return X86EMUL_OKAY; } @@ -470,8 +479,7 @@ void vpic_init(struct domain *d) register_portio_handler(d, 0x20, 2, vpic_intercept_pic_io); register_portio_handler(d, 0xa0, 2, vpic_intercept_pic_io); - register_portio_handler(d, 0x4d0, 1, vpic_intercept_elcr_io); - register_portio_handler(d, 0x4d1, 1, vpic_intercept_elcr_io); + register_portio_handler(d, 0x4d0, 2, vpic_intercept_elcr_io); } void vpic_irq_positive_edge(struct domain *d, int irq) -- generated by git-patchbot for /home/xen/git/xen.git#master
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |