Lines Matching refs:zdev
99 static void clp_store_query_pci_fngrp(struct zpci_dev *zdev, in clp_store_query_pci_fngrp() argument
102 zdev->tlb_refresh = response->refresh; in clp_store_query_pci_fngrp()
103 zdev->dma_mask = response->dasm; in clp_store_query_pci_fngrp()
104 zdev->msi_addr = response->msia; in clp_store_query_pci_fngrp()
105 zdev->max_msi = response->noi; in clp_store_query_pci_fngrp()
106 zdev->fmb_update = response->mui; in clp_store_query_pci_fngrp()
107 zdev->version = response->version; in clp_store_query_pci_fngrp()
111 zdev->max_bus_speed = PCIE_SPEED_5_0GT; in clp_store_query_pci_fngrp()
114 zdev->max_bus_speed = PCI_SPEED_UNKNOWN; in clp_store_query_pci_fngrp()
119 static int clp_query_pci_fngrp(struct zpci_dev *zdev, u8 pfgid) in clp_query_pci_fngrp() argument
136 clp_store_query_pci_fngrp(zdev, &rrb->response); in clp_query_pci_fngrp()
146 static int clp_store_query_pci_fn(struct zpci_dev *zdev, in clp_store_query_pci_fn() argument
152 zdev->bars[i].val = le32_to_cpu(response->bar[i]); in clp_store_query_pci_fn()
153 zdev->bars[i].size = response->bar_size[i]; in clp_store_query_pci_fn()
155 zdev->start_dma = response->sdma; in clp_store_query_pci_fn()
156 zdev->end_dma = response->edma; in clp_store_query_pci_fn()
157 zdev->pchid = response->pchid; in clp_store_query_pci_fn()
158 zdev->pfgid = response->pfgid; in clp_store_query_pci_fn()
159 zdev->pft = response->pft; in clp_store_query_pci_fn()
160 zdev->vfn = response->vfn; in clp_store_query_pci_fn()
161 zdev->port = response->port; in clp_store_query_pci_fn()
162 zdev->uid = response->uid; in clp_store_query_pci_fn()
163 zdev->fmb_length = sizeof(u32) * response->fmb_len; in clp_store_query_pci_fn()
164 zdev->rid_available = response->rid_avail; in clp_store_query_pci_fn()
165 zdev->is_physfn = response->is_physfn; in clp_store_query_pci_fn()
166 if (!s390_pci_no_rid && zdev->rid_available) in clp_store_query_pci_fn()
167 zdev->devfn = response->rid & ZPCI_RID_MASK_DEVFN; in clp_store_query_pci_fn()
169 memcpy(zdev->pfip, response->pfip, sizeof(zdev->pfip)); in clp_store_query_pci_fn()
171 memcpy(zdev->util_str, response->util_str, in clp_store_query_pci_fn()
172 sizeof(zdev->util_str)); in clp_store_query_pci_fn()
173 zdev->util_str_avail = 1; in clp_store_query_pci_fn()
175 zdev->mio_capable = response->mio_addr_avail; in clp_store_query_pci_fn()
180 zdev->bars[i].mio_wb = (void __iomem *) response->mio.addr[i].wb; in clp_store_query_pci_fn()
181 zdev->bars[i].mio_wt = (void __iomem *) response->mio.addr[i].wt; in clp_store_query_pci_fn()
186 int clp_query_pci_fn(struct zpci_dev *zdev) in clp_query_pci_fn() argument
199 rrb->request.fh = zdev->fh; in clp_query_pci_fn()
203 rc = clp_store_query_pci_fn(zdev, &rrb->response); in clp_query_pci_fn()
206 rc = clp_query_pci_fngrp(zdev, rrb->response.pfgid); in clp_query_pci_fn()
227 static int clp_set_pci_fn(struct zpci_dev *zdev, u8 nr_dma_as, u8 command) in clp_set_pci_fn() argument
241 rrb->request.fh = zdev->fh; in clp_set_pci_fn()
255 zdev->fh = rrb->response.fh; in clp_set_pci_fn()
258 rc = clp_refresh_fh(zdev->fid); in clp_set_pci_fn()
303 int clp_enable_fh(struct zpci_dev *zdev, u8 nr_dma_as) in clp_enable_fh() argument
307 rc = clp_set_pci_fn(zdev, nr_dma_as, CLP_SET_ENABLE_PCI_FN); in clp_enable_fh()
308 zpci_dbg(3, "ena fid:%x, fh:%x, rc:%d\n", zdev->fid, zdev->fh, rc); in clp_enable_fh()
309 if (!rc && zpci_use_mio(zdev)) { in clp_enable_fh()
310 rc = clp_set_pci_fn(zdev, nr_dma_as, CLP_SET_ENABLE_MIO); in clp_enable_fh()
312 zdev->fid, zdev->fh, rc); in clp_enable_fh()
314 clp_disable_fh(zdev); in clp_enable_fh()
319 int clp_disable_fh(struct zpci_dev *zdev) in clp_disable_fh() argument
323 if (!zdev_enabled(zdev)) in clp_disable_fh()
326 rc = clp_set_pci_fn(zdev, 0, CLP_SET_DISABLE_PCI_FN); in clp_disable_fh()
327 zpci_dbg(3, "dis fid:%x, fh:%x, rc:%d\n", zdev->fid, zdev->fh, rc); in clp_disable_fh()
371 struct zpci_dev *zdev; in __clp_add() local
376 zdev = get_zdev_by_fid(entry->fid); in __clp_add()
377 if (zdev) { in __clp_add()
378 zpci_zdev_put(zdev); in __clp_add()
401 struct zpci_dev *zdev; in __clp_refresh_fh() local
407 zdev = get_zdev_by_fid(fid); in __clp_refresh_fh()
408 if (!zdev) in __clp_refresh_fh()
411 zdev->fh = entry->fh; in __clp_refresh_fh()