Commit 34f16cd8 authored by Anton Blanchard's avatar Anton Blanchard

ppc64: pci_dma updates - remove excess syncs and general cleanup, from

Mike Corrigan
parent 5b78e64f
...@@ -219,7 +219,7 @@ long plpar_xirr(unsigned long *xirr_ret) ...@@ -219,7 +219,7 @@ long plpar_xirr(unsigned long *xirr_ret)
static void tce_build_pSeriesLP(struct TceTable *tbl, long tcenum, static void tce_build_pSeriesLP(struct TceTable *tbl, long tcenum,
unsigned long uaddr, int direction ) unsigned long uaddr, int direction )
{ {
u64 setTceRc; u64 set_tce_rc;
union Tce tce; union Tce tce;
PPCDBG(PPCDBG_TCE, "build_tce: uaddr = 0x%lx\n", uaddr); PPCDBG(PPCDBG_TCE, "build_tce: uaddr = 0x%lx\n", uaddr);
...@@ -232,90 +232,35 @@ static void tce_build_pSeriesLP(struct TceTable *tbl, long tcenum, ...@@ -232,90 +232,35 @@ static void tce_build_pSeriesLP(struct TceTable *tbl, long tcenum,
tce.tceBits.readWrite = 1; tce.tceBits.readWrite = 1;
if ( direction != PCI_DMA_TODEVICE ) tce.tceBits.pciWrite = 1; if ( direction != PCI_DMA_TODEVICE ) tce.tceBits.pciWrite = 1;
setTceRc = plpar_tce_put((u64)tbl->index, set_tce_rc = plpar_tce_put((u64)tbl->index,
(u64)tcenum << 12, (u64)tcenum << 12,
tce.wholeTce ); tce.wholeTce );
/* Make sure the update is visible to hardware.
* ToDo: sync after setting *all* the tce's.
*/
__asm__ __volatile__ ("sync" : : : "memory");
if(setTceRc) { if(set_tce_rc) {
PPCDBG(PPCDBG_TCE, "setTce failed. rc=%ld\n", setTceRc); printk("tce_build_pSeriesLP: plpar_tce_put failed. rc=%ld\n", set_tce_rc);
PPCDBG(PPCDBG_TCE, "\tindex = 0x%lx\n", (u64)tbl->index); printk("\tindex = 0x%lx\n", (u64)tbl->index);
PPCDBG(PPCDBG_TCE, "\ttcenum = 0x%lx\n", (u64)tcenum); printk("\ttcenum = 0x%lx\n", (u64)tcenum);
PPCDBG(PPCDBG_TCE, "\ttce val = 0x%lx\n", tce.wholeTce ); printk("\ttce val = 0x%lx\n", tce.wholeTce );
} }
} }
static inline void free_tce_range(struct TceTable *tbl, static void tce_free_one_pSeriesLP(struct TceTable *tbl, long tcenum)
long tcenum, unsigned order )
{
unsigned long flags;
/* Lock the tce allocation bitmap */
spin_lock_irqsave( &(tbl->lock), flags );
/* Do the actual work */
free_tce_range_nolock( tbl, tcenum, order );
/* Unlock the tce allocation bitmap */
spin_unlock_irqrestore( &(tbl->lock), flags );
}
static void tce_free_pSeriesLP(struct TceTable *tbl, dma_addr_t dma_addr,
unsigned order, unsigned numPages)
{ {
u64 setTceRc; u64 set_tce_rc;
long tcenum, freeTce, maxTcenum;
unsigned i;
union Tce tce; union Tce tce;
maxTcenum = (tbl->size * (PAGE_SIZE / sizeof(union Tce))) - 1;
tcenum = dma_addr >> PAGE_SHIFT;
freeTce = tcenum - tbl->startOffset;
if ( freeTce > maxTcenum ) {
printk("free_tces: tcenum > maxTcenum\n");
printk("\ttcenum = 0x%lx\n", tcenum);
printk("\tfreeTce = 0x%lx\n", freeTce);
printk("\tmaxTcenum = 0x%lx\n", maxTcenum);
printk("\tTCE Table = 0x%lx\n", (u64)tbl);
printk("\tbus# = 0x%lx\n",
(u64)tbl->busNumber );
printk("\tsize = 0x%lx\n", (u64)tbl->size);
printk("\tstartOff = 0x%lx\n",
(u64)tbl->startOffset );
printk("\tindex = 0x%lx\n", (u64)tbl->index);
return;
}
for (i=0; i<numPages; ++i) {
tce.wholeTce = 0; tce.wholeTce = 0;
setTceRc = plpar_tce_put((u64)tbl->index, set_tce_rc = plpar_tce_put((u64)tbl->index,
(u64)tcenum << 12, /* note: not freeTce */ (u64)tcenum << 12,
tce.wholeTce ); tce.wholeTce );
if ( setTceRc ) { if ( set_tce_rc ) {
printk("tce_free: setTce failed\n"); printk("tce_free_one_pSeriesLP: plpar_tce_put failed\n");
printk("\trc = %ld\n", setTceRc); printk("\trc = %ld\n", set_tce_rc);
printk("\tindex = 0x%lx\n", printk("\tindex = 0x%lx\n", (u64)tbl->index);
(u64)tbl->index);
printk("\ttcenum = 0x%lx\n", (u64)tcenum); printk("\ttcenum = 0x%lx\n", (u64)tcenum);
printk("\tfreeTce = 0x%lx\n", (u64)freeTce); printk("\ttce val = 0x%lx\n", tce.wholeTce );
printk("\ttce val = 0x%lx\n",
tce.wholeTce );
} }
++tcenum;
}
/* Make sure the update is visible to hardware. */
__asm__ __volatile__ ("sync" : : : "memory");
free_tce_range( tbl, freeTce, order );
} }
/* PowerPC Interrupts for lpar. */ /* PowerPC Interrupts for lpar. */
...@@ -446,7 +391,7 @@ void pSeriesLP_init_early(void) ...@@ -446,7 +391,7 @@ void pSeriesLP_init_early(void)
pSeries_lpar_mm_init(); pSeries_lpar_mm_init();
ppc_md.tce_build = tce_build_pSeriesLP; ppc_md.tce_build = tce_build_pSeriesLP;
ppc_md.tce_free = tce_free_pSeriesLP; ppc_md.tce_free_one = tce_free_one_pSeriesLP;
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
smp_init_pSeries(); smp_init_pSeries();
......
...@@ -63,6 +63,8 @@ int pci_assign_all_busses = 0; ...@@ -63,6 +63,8 @@ int pci_assign_all_busses = 0;
struct pci_controller* hose_head; struct pci_controller* hose_head;
struct pci_controller** hose_tail = &hose_head; struct pci_controller** hose_tail = &hose_head;
LIST_HEAD(iSeries_Global_Device_List);
/******************************************************************* /*******************************************************************
* Counters and control flags. * Counters and control flags.
*******************************************************************/ *******************************************************************/
......
This diff is collapsed.
...@@ -55,10 +55,8 @@ struct machdep_calls { ...@@ -55,10 +55,8 @@ struct machdep_calls {
long tcenum, long tcenum,
unsigned long uaddr, unsigned long uaddr,
int direction); int direction);
void (*tce_free)(struct TceTable *tbl, void (*tce_free_one)(struct TceTable *tbl,
dma_addr_t dma_addr, long tcenum);
unsigned order,
unsigned numPages);
void (*smp_message_pass)(int target, void (*smp_message_pass)(int target,
int msg, int msg,
......
...@@ -85,12 +85,14 @@ struct TceTableManagerCB { ...@@ -85,12 +85,14 @@ struct TceTableManagerCB {
u64 index; /* Index of this tce table (token?) */ u64 index; /* Index of this tce table (token?) */
u16 maxTceTableIndex; /* Max num of tables for partition */ u16 maxTceTableIndex; /* Max num of tables for partition */
u8 virtualBusFlag; /* Flag to indicate virtual bus */ u8 virtualBusFlag; /* Flag to indicate virtual bus */
u8 rsvd[5]; u8 logicalSlot; /* IOA Tce Slot Index */
u8 rsvd[4];
}; };
extern struct TceTable virtBusTceTable; /* Tce table for virtual bus */ extern struct TceTable virtBusTceTable; /* Tce table for virtual bus */
extern void create_tce_tables(void); extern void create_tce_tables(void);
extern void create_pci_bus_tce_table(unsigned long);
void tce_init_pSeries(void); void tce_init_pSeries(void);
void tce_init_iSeries(void); void tce_init_iSeries(void);
......
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