git: 40ad9aaa880c - main - xen/intr: stop passing shared_info_t to xen_intr_active_ports()
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Wed, 29 Mar 2023 07:52:32 UTC
The branch main has been updated by royger: URL: https://cgit.FreeBSD.org/src/commit/?id=40ad9aaa880c7eefa3c16786beb19320afdc8903 commit 40ad9aaa880c7eefa3c16786beb19320afdc8903 Author: Elliott Mitchell <ehem+freebsd@m5p.com> AuthorDate: 2022-02-23 16:47:18 +0000 Commit: Roger Pau Monné <royger@FreeBSD.org> CommitDate: 2023-03-29 07:51:43 +0000 xen/intr: stop passing shared_info_t to xen_intr_active_ports() There is only a single global HYPERVISOR_shared_info pointer, so directly use the global pointer. Reviewed by: royger MFC after: 1 week --- sys/x86/xen/xen_intr.c | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/sys/x86/xen/xen_intr.c b/sys/x86/xen/xen_intr.c index 8d5562e21018..129252044da9 100644 --- a/sys/x86/xen/xen_intr.c +++ b/sys/x86/xen/xen_intr.c @@ -485,9 +485,10 @@ xen_intr_bind_isrc(struct xenisrc **isrcp, evtchn_port_t local_port, * events. */ static inline u_long -xen_intr_active_ports(struct xen_intr_pcpu_data *pcpu, shared_info_t *sh, - u_int idx) +xen_intr_active_ports(const struct xen_intr_pcpu_data *const pcpu, + const u_int idx) { + volatile const shared_info_t *const sh = HYPERVISOR_shared_info; CTASSERT(sizeof(sh->evtchn_mask[0]) == sizeof(sh->evtchn_pending[0])); CTASSERT(sizeof(sh->evtchn_mask[0]) == sizeof(pcpu->evtchn_enabled[0])); @@ -509,7 +510,6 @@ xen_intr_handle_upcall(struct trapframe *trap_frame) u_int l1i, l2i, port, cpu __diagused; u_long masked_l1, masked_l2; struct xenisrc *isrc; - shared_info_t *s; vcpu_info_t *v; struct xen_intr_pcpu_data *pc; u_long l1, l2; @@ -522,7 +522,6 @@ xen_intr_handle_upcall(struct trapframe *trap_frame) cpu = PCPU_GET(cpuid); pc = DPCPU_PTR(xen_intr_pcpu); - s = HYPERVISOR_shared_info; v = DPCPU_GET(vcpu_info); if (!xen_has_percpu_evtchn()) { @@ -560,7 +559,7 @@ xen_intr_handle_upcall(struct trapframe *trap_frame) l1i = ffsl(masked_l1) - 1; do { - l2 = xen_intr_active_ports(pc, s, l1i); + l2 = xen_intr_active_ports(pc, l1i); l2i = (l2i + 1) % LONG_BIT; masked_l2 = l2 & ((~0UL) << l2i); @@ -596,7 +595,7 @@ xen_intr_handle_upcall(struct trapframe *trap_frame) } while (l2i != LONG_BIT - 1); - l2 = xen_intr_active_ports(pc, s, l1i); + l2 = xen_intr_active_ports(pc, l1i); if (l2 == 0) { /* * We handled all ports, so we can clear the