|
[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 |