[PATCH] powerpc: kill union tce_entry
It's been long overdue to kill the union tce_entry in the pSeries/iSeries TCE code, especially since I asked the Summit guys to do it on the code they copied from us. Also, while I was at it, I cleaned up some whitespace. Built and booted on pSeries, built on iSeries. Signed-off-by: Olof Johansson <olof@lixom.net> Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
committed by
Paul Mackerras
parent
c7f0e8cb56
commit
bc97ce951c
@@ -4,6 +4,7 @@
|
||||
* Rewrite, cleanup:
|
||||
*
|
||||
* Copyright (C) 2004 Olof Johansson <olof@lixom.net>, IBM Corporation
|
||||
* Copyright (C) 2006 Olof Johansson <olof@lixom.net>
|
||||
*
|
||||
* Dynamic DMA mapping support, iSeries-specific parts.
|
||||
*
|
||||
@@ -42,30 +43,28 @@ static void tce_build_iSeries(struct iommu_table *tbl, long index, long npages,
|
||||
unsigned long uaddr, enum dma_data_direction direction)
|
||||
{
|
||||
u64 rc;
|
||||
union tce_entry tce;
|
||||
u64 tce, rpn;
|
||||
|
||||
index <<= TCE_PAGE_FACTOR;
|
||||
npages <<= TCE_PAGE_FACTOR;
|
||||
|
||||
while (npages--) {
|
||||
tce.te_word = 0;
|
||||
tce.te_bits.tb_rpn = virt_to_abs(uaddr) >> TCE_SHIFT;
|
||||
rpn = virt_to_abs(uaddr) >> TCE_SHIFT;
|
||||
tce = (rpn & TCE_RPN_MASK) << TCE_RPN_SHIFT;
|
||||
|
||||
if (tbl->it_type == TCE_VB) {
|
||||
/* Virtual Bus */
|
||||
tce.te_bits.tb_valid = 1;
|
||||
tce.te_bits.tb_allio = 1;
|
||||
tce |= TCE_VALID|TCE_ALLIO;
|
||||
if (direction != DMA_TO_DEVICE)
|
||||
tce.te_bits.tb_rdwr = 1;
|
||||
tce |= TCE_VB_WRITE;
|
||||
} else {
|
||||
/* PCI Bus */
|
||||
tce.te_bits.tb_rdwr = 1; /* Read allowed */
|
||||
tce |= TCE_PCI_READ; /* Read allowed */
|
||||
if (direction != DMA_TO_DEVICE)
|
||||
tce.te_bits.tb_pciwr = 1;
|
||||
tce |= TCE_PCI_WRITE;
|
||||
}
|
||||
|
||||
rc = HvCallXm_setTce((u64)tbl->it_index, (u64)index,
|
||||
tce.te_word);
|
||||
rc = HvCallXm_setTce((u64)tbl->it_index, (u64)index, tce);
|
||||
if (rc)
|
||||
panic("PCI_DMA: HvCallXm_setTce failed, Rc: 0x%lx\n",
|
||||
rc);
|
||||
@@ -123,7 +122,7 @@ void iommu_table_getparms_iSeries(unsigned long busno,
|
||||
|
||||
/* itc_size is in pages worth of table, it_size is in # of entries */
|
||||
tbl->it_size = ((parms->itc_size * TCE_PAGE_SIZE) /
|
||||
sizeof(union tce_entry)) >> TCE_PAGE_FACTOR;
|
||||
TCE_ENTRY_SIZE) >> TCE_PAGE_FACTOR;
|
||||
tbl->it_busno = parms->itc_busno;
|
||||
tbl->it_offset = parms->itc_offset >> TCE_PAGE_FACTOR;
|
||||
tbl->it_index = parms->itc_index;
|
||||
|
Reference in New Issue
Block a user