Commit 1670b2b2 authored by Stephen Rothwell's avatar Stephen Rothwell Committed by Paul Mackerras

[POWERPC] Remove iSeries_vio_dev

It was only being used to carry around dma_iommu_ops and vio_iommu_table
which we can use directly instead.  This also means that vio_bus_device
doesn't need to refer to them either.
Signed-off-by: default avatarStephen Rothwell <sfr@canb.auug.org.au>
Acked-by: default avatarJens Axboe <jens.axboe@oracle.com>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent 73be7d52
...@@ -49,11 +49,8 @@ static struct vio_dev vio_bus_device = { /* fake "parent" device */ ...@@ -49,11 +49,8 @@ static struct vio_dev vio_bus_device = { /* fake "parent" device */
}; };
#ifdef CONFIG_PPC_ISERIES #ifdef CONFIG_PPC_ISERIES
struct device *iSeries_vio_dev = &vio_bus_device.dev;
EXPORT_SYMBOL(iSeries_vio_dev);
static struct iommu_table veth_iommu_table; static struct iommu_table veth_iommu_table;
static struct iommu_table vio_iommu_table; struct iommu_table vio_iommu_table;
static void __init iommu_vio_init(void) static void __init iommu_vio_init(void)
{ {
...@@ -66,8 +63,6 @@ static void __init iommu_vio_init(void) ...@@ -66,8 +63,6 @@ static void __init iommu_vio_init(void)
printk("Virtual Bus VETH TCE table failed.\n"); printk("Virtual Bus VETH TCE table failed.\n");
if (!iommu_init_table(&vio_iommu_table, -1)) if (!iommu_init_table(&vio_iommu_table, -1))
printk("Virtual Bus VIO TCE table failed.\n"); printk("Virtual Bus VIO TCE table failed.\n");
vio_bus_device.dev.archdata.dma_ops = &dma_iommu_ops;
vio_bus_device.dev.archdata.dma_data = &vio_iommu_table;
} }
#else #else
static void __init iommu_vio_init(void) static void __init iommu_vio_init(void)
......
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include <linux/dma-mapping.h> #include <linux/dma-mapping.h>
#include <linux/list.h> #include <linux/list.h>
#include <linux/pci.h> #include <linux/pci.h>
#include <linux/module.h>
#include <asm/iommu.h> #include <asm/iommu.h>
#include <asm/tce.h> #include <asm/tce.h>
...@@ -36,6 +37,7 @@ ...@@ -36,6 +37,7 @@
#include <asm/prom.h> #include <asm/prom.h>
#include <asm/pci-bridge.h> #include <asm/pci-bridge.h>
#include <asm/iseries/hv_call_xm.h> #include <asm/iseries/hv_call_xm.h>
#include <asm/iseries/hv_call_event.h>
#include <asm/iseries/iommu.h> #include <asm/iseries/iommu.h>
static void tce_build_iSeries(struct iommu_table *tbl, long index, long npages, static void tce_build_iSeries(struct iommu_table *tbl, long index, long npages,
...@@ -189,6 +191,34 @@ void iommu_devnode_init_iSeries(struct pci_dev *pdev, struct device_node *dn) ...@@ -189,6 +191,34 @@ void iommu_devnode_init_iSeries(struct pci_dev *pdev, struct device_node *dn)
} }
#endif #endif
extern struct iommu_table vio_iommu_table;
void *iseries_hv_alloc(size_t size, dma_addr_t *dma_handle, gfp_t flag)
{
return iommu_alloc_coherent(&vio_iommu_table, size, dma_handle,
DMA_32BIT_MASK, flag, -1);
}
EXPORT_SYMBOL_GPL(iseries_hv_alloc);
void iseries_hv_free(size_t size, void *vaddr, dma_addr_t dma_handle)
{
iommu_free_coherent(&vio_iommu_table, size, vaddr, dma_handle);
}
EXPORT_SYMBOL_GPL(iseries_hv_free);
dma_addr_t iseries_hv_map(void *vaddr, size_t size,
enum dma_data_direction direction)
{
return iommu_map_single(&vio_iommu_table, vaddr, size,
DMA_32BIT_MASK, direction);
}
void iseries_hv_unmap(dma_addr_t dma_handle, size_t size,
enum dma_data_direction direction)
{
iommu_unmap_single(&vio_iommu_table, dma_handle, size, direction);
}
void iommu_init_early_iSeries(void) void iommu_init_early_iSeries(void)
{ {
ppc_md.tce_build = tce_build_iSeries; ppc_md.tce_build = tce_build_iSeries;
......
...@@ -39,9 +39,9 @@ ...@@ -39,9 +39,9 @@
#include <asm/paca.h> #include <asm/paca.h>
#include <asm/abs_addr.h> #include <asm/abs_addr.h>
#include <asm/firmware.h> #include <asm/firmware.h>
#include <asm/iseries/vio.h>
#include <asm/iseries/mf.h> #include <asm/iseries/mf.h>
#include <asm/iseries/hv_lp_config.h> #include <asm/iseries/hv_lp_config.h>
#include <asm/iseries/hv_lp_event.h>
#include <asm/iseries/it_lp_queue.h> #include <asm/iseries/it_lp_queue.h>
#include "setup.h" #include "setup.h"
...@@ -870,8 +870,7 @@ static int proc_mf_dump_cmdline(char *page, char **start, off_t off, ...@@ -870,8 +870,7 @@ static int proc_mf_dump_cmdline(char *page, char **start, off_t off,
if ((off + count) > 256) if ((off + count) > 256)
count = 256 - off; count = 256 - off;
dma_addr = dma_map_single(iSeries_vio_dev, page, off + count, dma_addr = iseries_hv_map(page, off + count, DMA_FROM_DEVICE);
DMA_FROM_DEVICE);
if (dma_mapping_error(dma_addr)) if (dma_mapping_error(dma_addr))
return -ENOMEM; return -ENOMEM;
memset(page, 0, off + count); memset(page, 0, off + count);
...@@ -883,8 +882,7 @@ static int proc_mf_dump_cmdline(char *page, char **start, off_t off, ...@@ -883,8 +882,7 @@ static int proc_mf_dump_cmdline(char *page, char **start, off_t off,
vsp_cmd.sub_data.kern.length = off + count; vsp_cmd.sub_data.kern.length = off + count;
mb(); mb();
rc = signal_vsp_instruction(&vsp_cmd); rc = signal_vsp_instruction(&vsp_cmd);
dma_unmap_single(iSeries_vio_dev, dma_addr, off + count, iseries_hv_unmap(dma_addr, off + count, DMA_FROM_DEVICE);
DMA_FROM_DEVICE);
if (rc) if (rc)
return rc; return rc;
if (vsp_cmd.result_code != 0) if (vsp_cmd.result_code != 0)
...@@ -919,8 +917,7 @@ static int mf_getVmlinuxChunk(char *buffer, int *size, int offset, u64 side) ...@@ -919,8 +917,7 @@ static int mf_getVmlinuxChunk(char *buffer, int *size, int offset, u64 side)
int len = *size; int len = *size;
dma_addr_t dma_addr; dma_addr_t dma_addr;
dma_addr = dma_map_single(iSeries_vio_dev, buffer, len, dma_addr = iseries_hv_map(buffer, len, DMA_FROM_DEVICE);
DMA_FROM_DEVICE);
memset(buffer, 0, len); memset(buffer, 0, len);
memset(&vsp_cmd, 0, sizeof(vsp_cmd)); memset(&vsp_cmd, 0, sizeof(vsp_cmd));
vsp_cmd.cmd = 32; vsp_cmd.cmd = 32;
...@@ -938,7 +935,7 @@ static int mf_getVmlinuxChunk(char *buffer, int *size, int offset, u64 side) ...@@ -938,7 +935,7 @@ static int mf_getVmlinuxChunk(char *buffer, int *size, int offset, u64 side)
rc = -ENOMEM; rc = -ENOMEM;
} }
dma_unmap_single(iSeries_vio_dev, dma_addr, len, DMA_FROM_DEVICE); iseries_hv_unmap(dma_addr, len, DMA_FROM_DEVICE);
return rc; return rc;
} }
...@@ -1149,8 +1146,7 @@ static int proc_mf_change_cmdline(struct file *file, const char __user *buffer, ...@@ -1149,8 +1146,7 @@ static int proc_mf_change_cmdline(struct file *file, const char __user *buffer,
goto out; goto out;
dma_addr = 0; dma_addr = 0;
page = dma_alloc_coherent(iSeries_vio_dev, count, &dma_addr, page = iseries_hv_alloc(count, &dma_addr, GFP_ATOMIC);
GFP_ATOMIC);
ret = -ENOMEM; ret = -ENOMEM;
if (page == NULL) if (page == NULL)
goto out; goto out;
...@@ -1170,7 +1166,7 @@ static int proc_mf_change_cmdline(struct file *file, const char __user *buffer, ...@@ -1170,7 +1166,7 @@ static int proc_mf_change_cmdline(struct file *file, const char __user *buffer,
ret = count; ret = count;
out_free: out_free:
dma_free_coherent(iSeries_vio_dev, count, page, dma_addr); iseries_hv_free(count, page, dma_addr);
out: out:
return ret; return ret;
} }
...@@ -1190,8 +1186,7 @@ static ssize_t proc_mf_change_vmlinux(struct file *file, ...@@ -1190,8 +1186,7 @@ static ssize_t proc_mf_change_vmlinux(struct file *file,
goto out; goto out;
dma_addr = 0; dma_addr = 0;
page = dma_alloc_coherent(iSeries_vio_dev, count, &dma_addr, page = iseries_hv_alloc(count, &dma_addr, GFP_ATOMIC);
GFP_ATOMIC);
rc = -ENOMEM; rc = -ENOMEM;
if (page == NULL) { if (page == NULL) {
printk(KERN_ERR "mf.c: couldn't allocate memory to set vmlinux chunk\n"); printk(KERN_ERR "mf.c: couldn't allocate memory to set vmlinux chunk\n");
...@@ -1219,7 +1214,7 @@ static ssize_t proc_mf_change_vmlinux(struct file *file, ...@@ -1219,7 +1214,7 @@ static ssize_t proc_mf_change_vmlinux(struct file *file,
*ppos += count; *ppos += count;
rc = count; rc = count;
out_free: out_free:
dma_free_coherent(iSeries_vio_dev, count, page, dma_addr); iseries_hv_free(count, page, dma_addr);
out: out:
return rc; return rc;
} }
......
...@@ -124,8 +124,7 @@ static int proc_viopath_show(struct seq_file *m, void *v) ...@@ -124,8 +124,7 @@ static int proc_viopath_show(struct seq_file *m, void *v)
if (!buf) if (!buf)
return 0; return 0;
handle = dma_map_single(iSeries_vio_dev, buf, HW_PAGE_SIZE, handle = iseries_hv_map(buf, HW_PAGE_SIZE, DMA_FROM_DEVICE);
DMA_FROM_DEVICE);
hvrc = HvCallEvent_signalLpEventFast(viopath_hostLp, hvrc = HvCallEvent_signalLpEventFast(viopath_hostLp,
HvLpEvent_Type_VirtualIo, HvLpEvent_Type_VirtualIo,
...@@ -146,8 +145,7 @@ static int proc_viopath_show(struct seq_file *m, void *v) ...@@ -146,8 +145,7 @@ static int proc_viopath_show(struct seq_file *m, void *v)
buf[HW_PAGE_SIZE-1] = '\0'; buf[HW_PAGE_SIZE-1] = '\0';
seq_printf(m, "%s", buf); seq_printf(m, "%s", buf);
dma_unmap_single(iSeries_vio_dev, handle, HW_PAGE_SIZE, iseries_hv_unmap(handle, HW_PAGE_SIZE, DMA_FROM_DEVICE);
DMA_FROM_DEVICE);
kfree(buf); kfree(buf);
seq_printf(m, "AVAILABLE_VETH=%x\n", vlanMap); seq_printf(m, "AVAILABLE_VETH=%x\n", vlanMap);
......
...@@ -220,7 +220,7 @@ static void __init get_viocd_info(void) ...@@ -220,7 +220,7 @@ static void __init get_viocd_info(void)
struct cdrom_info *viocd_unitinfo; struct cdrom_info *viocd_unitinfo;
dma_addr_t unitinfo_dmaaddr; dma_addr_t unitinfo_dmaaddr;
viocd_unitinfo = dma_alloc_coherent(iSeries_vio_dev, viocd_unitinfo = iseries_hv_alloc(
sizeof(*viocd_unitinfo) * VIOCD_MAX_CD, sizeof(*viocd_unitinfo) * VIOCD_MAX_CD,
&unitinfo_dmaaddr, GFP_ATOMIC); &unitinfo_dmaaddr, GFP_ATOMIC);
if (viocd_unitinfo == NULL) { if (viocd_unitinfo == NULL) {
...@@ -262,8 +262,7 @@ static void __init get_viocd_info(void) ...@@ -262,8 +262,7 @@ static void __init get_viocd_info(void)
} }
error_ret: error_ret:
dma_free_coherent(iSeries_vio_dev, iseries_hv_free(sizeof(*viocd_unitinfo) * VIOCD_MAX_CD,
sizeof(*viocd_unitinfo) * VIOCD_MAX_CD,
viocd_unitinfo, unitinfo_dmaaddr); viocd_unitinfo, unitinfo_dmaaddr);
} }
......
...@@ -392,8 +392,8 @@ static int get_viotape_info(void) ...@@ -392,8 +392,8 @@ static int get_viotape_info(void)
if (op == NULL) if (op == NULL)
return -ENOMEM; return -ENOMEM;
viotape_unitinfo = dma_alloc_coherent(iSeries_vio_dev, len, viotape_unitinfo = iseries_hv_alloc(len, &viotape_unitinfo_token,
&viotape_unitinfo_token, GFP_ATOMIC); GFP_ATOMIC);
if (viotape_unitinfo == NULL) { if (viotape_unitinfo == NULL) {
free_op_struct(op); free_op_struct(op);
return -ENOMEM; return -ENOMEM;
...@@ -1103,8 +1103,7 @@ static void __exit viotap_exit(void) ...@@ -1103,8 +1103,7 @@ static void __exit viotap_exit(void)
class_destroy(tape_class); class_destroy(tape_class);
unregister_chrdev(VIOTAPE_MAJOR, "viotape"); unregister_chrdev(VIOTAPE_MAJOR, "viotape");
if (viotape_unitinfo) if (viotape_unitinfo)
dma_free_coherent(iSeries_vio_dev, iseries_hv_free(sizeof(viotape_unitinfo[0]) * VIOTAPE_MAX_TAPE,
sizeof(viotape_unitinfo[0]) * VIOTAPE_MAX_TAPE,
viotape_unitinfo, viotape_unitinfo_token); viotape_unitinfo, viotape_unitinfo_token);
viopath_close(viopath_hostLp, viomajorsubtype_tape, VIOTAPE_MAXREQ + 2); viopath_close(viopath_hostLp, viomajorsubtype_tape, VIOTAPE_MAXREQ + 2);
vio_clearHandler(viomajorsubtype_tape); vio_clearHandler(viomajorsubtype_tape);
......
...@@ -21,6 +21,9 @@ ...@@ -21,6 +21,9 @@
#ifndef _ASM_POWERPC_ISERIES_HV_CALL_EVENT_H #ifndef _ASM_POWERPC_ISERIES_HV_CALL_EVENT_H
#define _ASM_POWERPC_ISERIES_HV_CALL_EVENT_H #define _ASM_POWERPC_ISERIES_HV_CALL_EVENT_H
#include <linux/types.h>
#include <linux/dma-mapping.h>
#include <asm/iseries/hv_call_sc.h> #include <asm/iseries/hv_call_sc.h>
#include <asm/iseries/hv_types.h> #include <asm/iseries/hv_types.h>
#include <asm/abs_addr.h> #include <asm/abs_addr.h>
...@@ -113,6 +116,13 @@ static inline HvLpEvent_Rc HvCallEvent_signalLpEventFast(HvLpIndex targetLp, ...@@ -113,6 +116,13 @@ static inline HvLpEvent_Rc HvCallEvent_signalLpEventFast(HvLpIndex targetLp,
eventData3, eventData4, eventData5); eventData3, eventData4, eventData5);
} }
extern void *iseries_hv_alloc(size_t size, dma_addr_t *dma_handle, gfp_t flag);
extern void iseries_hv_free(size_t size, void *vaddr, dma_addr_t dma_handle);
extern dma_addr_t iseries_hv_map(void *vaddr, size_t size,
enum dma_data_direction direction);
extern void iseries_hv_unmap(dma_addr_t dma_handle, size_t size,
enum dma_data_direction direction);
static inline HvLpEvent_Rc HvCallEvent_ackLpEvent(struct HvLpEvent *event) static inline HvLpEvent_Rc HvCallEvent_ackLpEvent(struct HvLpEvent *event)
{ {
return HvCall1(HvCallEventAckLpEvent, virt_to_abs(event)); return HvCall1(HvCallEventAckLpEvent, virt_to_abs(event));
......
...@@ -150,8 +150,4 @@ enum viochar_rc { ...@@ -150,8 +150,4 @@ enum viochar_rc {
viochar_rc_ebusy = 1 viochar_rc_ebusy = 1
}; };
struct device;
extern struct device *iSeries_vio_dev;
#endif /* _ASM_POWERPC_ISERIES_VIO_H */ #endif /* _ASM_POWERPC_ISERIES_VIO_H */
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