source: trunk/packages/xen-3.1/xen-3.1/extras/mini-os/hypervisor.c @ 34

Last change on this file since 34 was 34, checked in by hartmans, 18 years ago

Add xen and xen-common

File size: 3.1 KB
Line 
1/******************************************************************************
2 * hypervisor.c
3 *
4 * Communication to/from hypervisor.
5 *
6 * Copyright (c) 2002-2003, K A Fraser
7 * Copyright (c) 2005, Grzegorz Milos, gm281@cam.ac.uk,Intel Research Cambridge
8 *
9 * Permission is hereby granted, free of charge, to any person obtaining a copy
10 * of this software and associated documentation files (the "Software"), to
11 * deal in the Software without restriction, including without limitation the
12 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
13 * sell copies of the Software, and to permit persons to whom the Software is
14 * furnished to do so, subject to the following conditions:
15 *
16 * The above copyright notice and this permission notice shall be included in
17 * all copies or substantial portions of the Software.
18 *
19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
24 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
25 * DEALINGS IN THE SOFTWARE.
26 */
27
28#include <os.h>
29#include <hypervisor.h>
30#include <events.h>
31
32#define active_evtchns(cpu,sh,idx)              \
33    ((sh)->evtchn_pending[idx] &                \
34     ~(sh)->evtchn_mask[idx])
35
36void do_hypervisor_callback(struct pt_regs *regs)
37{
38    unsigned long  l1, l2, l1i, l2i;
39    unsigned int   port;
40    int            cpu = 0;
41    shared_info_t *s = HYPERVISOR_shared_info;
42    vcpu_info_t   *vcpu_info = &s->vcpu_info[cpu];
43
44   
45    vcpu_info->evtchn_upcall_pending = 0;
46    /* NB. No need for a barrier here -- XCHG is a barrier on x86. */
47    l1 = xchg(&vcpu_info->evtchn_pending_sel, 0);
48    while ( l1 != 0 )
49    {
50        l1i = __ffs(l1);
51        l1 &= ~(1 << l1i);
52       
53        while ( (l2 = active_evtchns(cpu, s, l1i)) != 0 )
54        {
55            l2i = __ffs(l2);
56            l2 &= ~(1 << l2i);
57
58            port = (l1i << 5) + l2i;
59                        do_event(port, regs);
60        }
61    }
62}
63
64
65inline void mask_evtchn(u32 port)
66{
67    shared_info_t *s = HYPERVISOR_shared_info;
68    synch_set_bit(port, &s->evtchn_mask[0]);
69}
70
71inline void unmask_evtchn(u32 port)
72{
73    shared_info_t *s = HYPERVISOR_shared_info;
74    vcpu_info_t *vcpu_info = &s->vcpu_info[smp_processor_id()];
75
76    synch_clear_bit(port, &s->evtchn_mask[0]);
77
78    /*
79     * The following is basically the equivalent of 'hw_resend_irq'. Just like
80     * a real IO-APIC we 'lose the interrupt edge' if the channel is masked.
81     */
82    if (  synch_test_bit        (port,    &s->evtchn_pending[0]) && 
83         !synch_test_and_set_bit(port>>5, &vcpu_info->evtchn_pending_sel) )
84    {
85        vcpu_info->evtchn_upcall_pending = 1;
86        if ( !vcpu_info->evtchn_upcall_mask )
87            force_evtchn_callback();
88    }
89}
90
91inline void clear_evtchn(u32 port)
92{
93    shared_info_t *s = HYPERVISOR_shared_info;
94    synch_clear_bit(port, &s->evtchn_pending[0]);
95}
Note: See TracBrowser for help on using the repository browser.