return plpar_hcall_norets(H_IPI, servernum, mfrr);
 }
 
-static inline long plpar_xirr(unsigned long *xirr_ret)
+static inline long plpar_xirr(unsigned long *xirr_ret, unsigned char cppr)
 {
        long rc;
        unsigned long retbuf[PLPAR_HCALL_BUFSIZE];
 
-       rc = plpar_hcall(H_XIRR, retbuf);
+       rc = plpar_hcall(H_XIRR, retbuf, cppr);
 
        *xirr_ret = retbuf[0];
 
 
 
 /* LPAR low level accessors */
 
-static inline unsigned int lpar_xirr_info_get(void)
+static inline unsigned int lpar_xirr_info_get(unsigned char cppr)
 {
        unsigned long lpar_rc;
        unsigned long return_value;
 
-       lpar_rc = plpar_xirr(&return_value);
+       lpar_rc = plpar_xirr(&return_value, cppr);
        if (lpar_rc != H_SUCCESS)
                panic(" bad return code xirr - rc = %lx\n", lpar_rc);
        return (unsigned int)return_value;
 
 static unsigned int xics_get_irq_lpar(void)
 {
-       unsigned int xirr = lpar_xirr_info_get();
+       struct xics_cppr *os_cppr = &__get_cpu_var(xics_cppr);
+       unsigned int xirr = lpar_xirr_info_get(os_cppr->stack[os_cppr->index]);
        unsigned int vec = xics_xirr_vector(xirr);
        unsigned int irq;