• K
    xen/smp: Update pv_lock_ops functions before alternative code starts under PVHVM · 26a79995
    Konrad Rzeszutek Wilk 提交于
    Before this patch we would patch all of the pv_lock_ops sites
    using alternative assembler. Then later in the bootup cycle
    change the unlock_kick and lock_spinning to the Xen specific -
    without re patching.
    
    That meant that for the core of the kernel we would be running
    with the baremetal version of unlock_kick and lock_spinning while
    for modules we would have the proper Xen specific slowpaths.
    
    As most of the module uses some API from the core kernel that ended
    up with slowpath lockers waiting forever to be kicked (b/c they
    would be using the Xen specific slowpath logic). And the
    kick never came b/c the unlock path that was taken was the
    baremetal one.
    
    On PV we do not have the problem as we initialise before the
    alternative code kicks in.
    
    The fix is to make the updating of the pv_lock_ops function
    be done before the alternative code starts patching.
    
    Note that this patch fixes issues discovered by commit
    f10cd522.
    ("xen: disable PV spinlocks on HVM") wherein it mentioned
    
       PV spinlocks cannot possibly work with the current code because they are
       enabled after pvops patching has already been done, and because PV
       spinlocks use a different data structure than native spinlocks so we
       cannot switch between them dynamically.
    
    The first problem is solved by this patch.
    
    The second problem has been solved by commit
    816434ec
    (Merge branch 'x86-spinlocks-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip)
    
    P.S.
    There is still the commit 70dd4998
    (xen/spinlock: Disable IRQ spinlock (PV) allocation on PVHVM) to
    revert but that can be done later after all other bugs have been
    fixed.
    Signed-off-by: NKonrad Rzeszutek Wilk <konrad.wilk@oracle.com>
    Reviewed-by: NDavid Vrabel <david.vrabel@citrix.com>
    26a79995
smp.c 17.8 KB