powerpc/pseries/vas: Save PID in pseries_vas_window struct
authorHaren Myneni <haren@linux.ibm.com>
Tue, 1 Mar 2022 01:12:04 +0000 (17:12 -0800)
committerMichael Ellerman <mpe@ellerman.id.au>
Mon, 7 Mar 2022 13:04:55 +0000 (00:04 +1100)
The kernel sets the VAS window with PID when it is opened in
the hypervisor. During DLPAR operation, windows can be closed and
reopened in the hypervisor when the credit is available. So saves
this PID in pseries_vas_window struct when the window is opened
initially and reuse it later during DLPAR operation.

Signed-off-by: Haren Myneni <haren@linux.ibm.com>
Reviewed-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/a57cbe6d292fe49ad55a0b49c5679d6a24d8fe73.camel@linux.ibm.com
arch/powerpc/platforms/pseries/vas.c
arch/powerpc/platforms/pseries/vas.h

index 18aae037ffe9f34a3f3d2a5bb0b7bfb63a44408b..1035446f985b287650725910e7ebb2a8fe14b987 100644 (file)
@@ -107,7 +107,6 @@ static int h_deallocate_vas_window(u64 winid)
 static int h_modify_vas_window(struct pseries_vas_window *win)
 {
        long rc;
-       u32 lpid = mfspr(SPRN_PID);
 
        /*
         * AMR value is not supported in Linux VAS implementation.
@@ -115,7 +114,7 @@ static int h_modify_vas_window(struct pseries_vas_window *win)
         */
        do {
                rc = plpar_hcall_norets(H_MODIFY_VAS_WINDOW,
-                                       win->vas_win.winid, lpid, 0,
+                                       win->vas_win.winid, win->pid, 0,
                                        VAS_MOD_WIN_FLAGS, 0);
 
                rc = hcall_return_busy_check(rc);
@@ -124,8 +123,8 @@ static int h_modify_vas_window(struct pseries_vas_window *win)
        if (rc == H_SUCCESS)
                return 0;
 
-       pr_err("H_MODIFY_VAS_WINDOW error: %ld, winid %u lpid %u\n",
-                       rc, win->vas_win.winid, lpid);
+       pr_err("H_MODIFY_VAS_WINDOW error: %ld, winid %u pid %u\n",
+                       rc, win->vas_win.winid, win->pid);
        return -EIO;
 }
 
@@ -338,6 +337,8 @@ static struct vas_window *vas_allocate_window(int vas_id, u64 flags,
                }
        }
 
+       txwin->pid = mfspr(SPRN_PID);
+
        /*
         * Allocate / Deallocate window hcalls and setup / free IRQs
         * have to be protected with mutex.
index d6ea8ab8b07ae4092bd2c85c0374752ad1a55a1f..2872532ed72a964d783624c40e7e7a0e30f2213b 100644 (file)
@@ -114,6 +114,7 @@ struct pseries_vas_window {
        u64 domain[6];          /* Associativity domain Ids */
                                /* this window is allocated */
        u64 util;
+       u32 pid;                /* PID associated with this window */
 
        /* List of windows opened which is used for LPM */
        struct list_head win_list;