2006-02-10 06:05:54 +00:00
|
|
|
/* pci_sun4v_asm: Hypervisor calls for PCI support.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006 David S. Miller <davem@davemloft.net>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <asm/hypervisor.h>
|
|
|
|
|
|
|
|
/* %o0: devhandle
|
|
|
|
* %o1: devino
|
|
|
|
*
|
|
|
|
* returns %o0: sysino
|
|
|
|
*/
|
|
|
|
.globl pci_sun4v_devino_to_sysino
|
|
|
|
pci_sun4v_devino_to_sysino:
|
|
|
|
mov %o1, %o2
|
|
|
|
mov %o0, %o1
|
|
|
|
mov HV_FAST_INTR_DEVINO2SYSINO, %o0
|
|
|
|
ta HV_FAST_TRAP
|
|
|
|
retl
|
|
|
|
mov %o1, %o0
|
|
|
|
|
|
|
|
/* %o0: devhandle
|
|
|
|
* %o1: tsbid
|
|
|
|
* %o2: num ttes
|
|
|
|
* %o3: io_attributes
|
|
|
|
* %o4: io_page_list phys address
|
|
|
|
*
|
|
|
|
* returns %o0: num ttes mapped
|
|
|
|
*/
|
|
|
|
.globl pci_sun4v_iommu_map
|
|
|
|
pci_sun4v_iommu_map:
|
|
|
|
mov %o4, %o5
|
|
|
|
mov %o3, %o4
|
|
|
|
mov %o2, %o3
|
|
|
|
mov %o1, %o2
|
|
|
|
mov %o0, %o1
|
|
|
|
mov HV_FAST_PCI_IOMMU_MAP, %o0
|
|
|
|
ta HV_FAST_TRAP
|
|
|
|
retl
|
|
|
|
mov %o1, %o0
|
|
|
|
|
|
|
|
/* %o0: devhandle
|
|
|
|
* %o1: tsbid
|
|
|
|
* %o2: num ttes
|
|
|
|
*
|
|
|
|
* returns %o0: num ttes demapped
|
|
|
|
*/
|
|
|
|
.globl pci_sun4v_iommu_demap
|
|
|
|
pci_sun4v_iommu_demap:
|
|
|
|
mov %o2, %o3
|
|
|
|
mov %o1, %o2
|
|
|
|
mov %o0, %o1
|
|
|
|
mov HV_FAST_PCI_IOMMU_DEMAP, %o0
|
|
|
|
ta HV_FAST_TRAP
|
|
|
|
retl
|
|
|
|
mov %o1, %o0
|
2006-02-10 06:20:01 +00:00
|
|
|
|
|
|
|
/* %o0: devhandle
|
|
|
|
* %o1: pci_device
|
|
|
|
* %o2: pci_config_offset
|
|
|
|
* %o3: size
|
|
|
|
*
|
|
|
|
* returns %o0: data
|
|
|
|
*
|
|
|
|
* If there is an error, the data will be returned
|
|
|
|
* as all 1's.
|
|
|
|
*/
|
|
|
|
.globl pci_sun4v_config_get
|
|
|
|
pci_sun4v_config_get:
|
|
|
|
mov %o3, %o4
|
|
|
|
mov %o2, %o3
|
|
|
|
mov %o1, %o2
|
|
|
|
mov %o0, %o1
|
|
|
|
mov HV_FAST_PCI_CONFIG_GET, %o0
|
|
|
|
ta HV_FAST_TRAP
|
|
|
|
brnz,a,pn %o1, 1f
|
|
|
|
mov -1, %o2
|
|
|
|
1: retl
|
|
|
|
mov %o2, %o0
|
|
|
|
|
|
|
|
/* %o0: devhandle
|
|
|
|
* %o1: pci_device
|
|
|
|
* %o2: pci_config_offset
|
|
|
|
* %o3: size
|
|
|
|
* %o4: data
|
|
|
|
*
|
|
|
|
* returns %o0: status
|
|
|
|
*
|
|
|
|
* status will be zero if the operation completed
|
|
|
|
* successfully, else -1 if not
|
|
|
|
*/
|
|
|
|
.globl pci_sun4v_config_put
|
|
|
|
pci_sun4v_config_put:
|
|
|
|
mov %o3, %o4
|
|
|
|
mov %o2, %o3
|
|
|
|
mov %o1, %o2
|
|
|
|
mov %o0, %o1
|
|
|
|
mov HV_FAST_PCI_CONFIG_PUT, %o0
|
|
|
|
ta HV_FAST_TRAP
|
|
|
|
brnz,a,pn %o1, 1f
|
|
|
|
mov -1, %o1
|
|
|
|
1: retl
|
|
|
|
mov %o1, %o0
|
|
|
|
|