Commit 32737e43 authored by Anton Blanchard's avatar Anton Blanchard

Merge samba.org:/scratch/anton/junk/foo

into samba.org:/scratch/anton/linux-2.5_ppc64
parents fac4e0cb 021baa0c
...@@ -36,18 +36,6 @@ ...@@ -36,18 +36,6 @@
#include <asm/tlb.h> #include <asm/tlb.h>
#include <asm/hvcall.h> #include <asm/hvcall.h>
long plpar_pte_enter(unsigned long flags,
unsigned long ptex,
unsigned long new_pteh, unsigned long new_ptel,
unsigned long *old_pteh_ret, unsigned long *old_ptel_ret)
{
unsigned long dummy, ret;
ret = plpar_hcall(H_ENTER, flags, ptex, new_pteh, new_ptel,
old_pteh_ret, old_ptel_ret, &dummy);
return(ret);
}
long plpar_pte_remove(unsigned long flags, long plpar_pte_remove(unsigned long flags,
unsigned long ptex, unsigned long ptex,
unsigned long avpn, unsigned long avpn,
...@@ -83,7 +71,6 @@ long plpar_tce_get(unsigned long liobn, ...@@ -83,7 +71,6 @@ long plpar_tce_get(unsigned long liobn,
tce_ret, &dummy, &dummy); tce_ret, &dummy, &dummy);
} }
long plpar_tce_put(unsigned long liobn, long plpar_tce_put(unsigned long liobn,
unsigned long ioba, unsigned long ioba,
unsigned long tceval) unsigned long tceval)
...@@ -104,10 +91,9 @@ long plpar_put_term_char(unsigned long termno, ...@@ -104,10 +91,9 @@ long plpar_put_term_char(unsigned long termno,
unsigned long len, unsigned long len,
const char *buffer) const char *buffer)
{ {
unsigned long dummy;
unsigned long *lbuf = (unsigned long *)buffer; /* ToDo: alignment? */ unsigned long *lbuf = (unsigned long *)buffer; /* ToDo: alignment? */
return plpar_hcall(H_PUT_TERM_CHAR, termno, len, return plpar_hcall_norets(H_PUT_TERM_CHAR, termno, len, lbuf[0],
lbuf[0], lbuf[1], &dummy, &dummy, &dummy); lbuf[1]);
} }
static void tce_build_pSeriesLP(struct TceTable *tbl, long tcenum, static void tce_build_pSeriesLP(struct TceTable *tbl, long tcenum,
...@@ -287,12 +273,11 @@ int hvc_get_chars(int index, char *buf, int count) ...@@ -287,12 +273,11 @@ int hvc_get_chars(int index, char *buf, int count)
int hvc_put_chars(int index, const char *buf, int count) int hvc_put_chars(int index, const char *buf, int count)
{ {
unsigned long dummy;
unsigned long *lbuf = (unsigned long *) buf; unsigned long *lbuf = (unsigned long *) buf;
long ret; long ret;
ret = plpar_hcall(H_PUT_TERM_CHAR, index, count, lbuf[0], lbuf[1], ret = plpar_hcall_norets(H_PUT_TERM_CHAR, index, count, lbuf[0],
&dummy, &dummy, &dummy); lbuf[1]);
if (ret == H_Success) if (ret == H_Success)
return count; return count;
if (ret == H_Busy) if (ret == H_Busy)
...@@ -318,7 +303,6 @@ int hvc_count(int *start_termno) ...@@ -318,7 +303,6 @@ int hvc_count(int *start_termno)
long pSeries_lpar_hpte_insert(unsigned long hpte_group, long pSeries_lpar_hpte_insert(unsigned long hpte_group,
unsigned long va, unsigned long prpn, unsigned long va, unsigned long prpn,
int secondary, unsigned long hpteflags, int secondary, unsigned long hpteflags,
...@@ -329,6 +313,7 @@ long pSeries_lpar_hpte_insert(unsigned long hpte_group, ...@@ -329,6 +313,7 @@ long pSeries_lpar_hpte_insert(unsigned long hpte_group,
unsigned long flags; unsigned long flags;
unsigned long slot; unsigned long slot;
HPTE lhpte; HPTE lhpte;
unsigned long dummy0, dummy1;
/* Fill in the local HPTE with absolute rpn, avpn and flags */ /* Fill in the local HPTE with absolute rpn, avpn and flags */
lhpte.dw1.dword1 = 0; lhpte.dw1.dword1 = 0;
...@@ -348,7 +333,6 @@ long pSeries_lpar_hpte_insert(unsigned long hpte_group, ...@@ -348,7 +333,6 @@ long pSeries_lpar_hpte_insert(unsigned long hpte_group,
/* Now fill in the actual HPTE */ /* Now fill in the actual HPTE */
/* Set CEC cookie to 0 */ /* Set CEC cookie to 0 */
/* Large page = 0 */
/* Zero page = 0 */ /* Zero page = 0 */
/* I-cache Invalidate = 0 */ /* I-cache Invalidate = 0 */
/* I-cache synchronize = 0 */ /* I-cache synchronize = 0 */
...@@ -359,19 +343,8 @@ long pSeries_lpar_hpte_insert(unsigned long hpte_group, ...@@ -359,19 +343,8 @@ long pSeries_lpar_hpte_insert(unsigned long hpte_group,
if (hpteflags & (_PAGE_GUARDED|_PAGE_NO_CACHE)) if (hpteflags & (_PAGE_GUARDED|_PAGE_NO_CACHE))
lhpte.dw1.flags.flags &= ~_PAGE_COHERENT; lhpte.dw1.flags.flags &= ~_PAGE_COHERENT;
__asm__ __volatile__ ( lpar_rc = plpar_hcall(H_ENTER, flags, hpte_group, lhpte.dw0.dword0,
H_ENTER_r3 lhpte.dw1.dword1, &slot, &dummy0, &dummy1);
"mr 4, %2\n"
"mr 5, %3\n"
"mr 6, %4\n"
"mr 7, %5\n"
HSC
"mr %0, 3\n"
"mr %1, 4\n"
: "=r" (lpar_rc), "=r" (slot)
: "r" (flags), "r" (hpte_group), "r" (lhpte.dw0.dword0),
"r" (lhpte.dw1.dword1)
: "r3", "r4", "r5", "r6", "r7", "cc");
if (lpar_rc == H_PTEG_Full) if (lpar_rc == H_PTEG_Full)
return -1; return -1;
......
This diff is collapsed.
...@@ -59,9 +59,6 @@ ...@@ -59,9 +59,6 @@
#define H_XIRR 0x74 #define H_XIRR 0x74
#define H_PERFMON 0x7c #define H_PERFMON 0x7c
#define HSC ".long 0x44000022\n"
#define H_ENTER_r3 "li 3, 0x08\n"
/* plpar_hcall() -- Generic call interface using above opcodes /* plpar_hcall() -- Generic call interface using above opcodes
* *
* The actual call interface is a hypervisor call instruction with * The actual call interface is a hypervisor call instruction with
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment