Lines Matching refs:gdev
52 struct vbg_dev *gdev; in vbg_misc_device_open() local
55 gdev = container_of(filp->private_data, struct vbg_dev, misc_device); in vbg_misc_device_open()
57 session = vbg_core_open_session(gdev, vbg_misc_device_requestor(inode)); in vbg_misc_device_open()
68 struct vbg_dev *gdev; in vbg_misc_device_user_open() local
71 gdev = container_of(filp->private_data, struct vbg_dev, in vbg_misc_device_user_open()
74 session = vbg_core_open_session(gdev, vbg_misc_device_requestor(inode) | in vbg_misc_device_user_open()
203 struct vbg_dev *gdev = input_get_drvdata(input); in vbg_input_open() local
206 return vbg_core_set_mouse_status(gdev, feat); in vbg_input_open()
216 struct vbg_dev *gdev = input_get_drvdata(input); in vbg_input_close() local
218 vbg_core_set_mouse_status(gdev, 0); in vbg_input_close()
226 static int vbg_create_input_device(struct vbg_dev *gdev) in vbg_create_input_device() argument
230 input = devm_input_allocate_device(gdev->dev); in vbg_create_input_device()
239 input->dev.parent = gdev->dev; in vbg_create_input_device()
247 input_set_drvdata(input, gdev); in vbg_create_input_device()
249 gdev->input = input; in vbg_create_input_device()
251 return input_register_device(gdev->input); in vbg_create_input_device()
257 struct vbg_dev *gdev = dev_get_drvdata(dev); in host_version_show() local
259 return sprintf(buf, "%s\n", gdev->host_version); in host_version_show()
265 struct vbg_dev *gdev = dev_get_drvdata(dev); in host_features_show() local
267 return sprintf(buf, "%#x\n", gdev->host_features); in host_features_show()
290 struct vbg_dev *gdev; in vbg_pci_probe() local
293 gdev = devm_kzalloc(dev, sizeof(*gdev), GFP_KERNEL); in vbg_pci_probe()
294 if (!gdev) in vbg_pci_probe()
346 gdev->io_port = io; in vbg_pci_probe()
347 gdev->mmio = vmmdev; in vbg_pci_probe()
348 gdev->dev = dev; in vbg_pci_probe()
349 gdev->misc_device.minor = MISC_DYNAMIC_MINOR; in vbg_pci_probe()
350 gdev->misc_device.name = DEVICE_NAME; in vbg_pci_probe()
351 gdev->misc_device.fops = &vbg_misc_device_fops; in vbg_pci_probe()
352 gdev->misc_device_user.minor = MISC_DYNAMIC_MINOR; in vbg_pci_probe()
353 gdev->misc_device_user.name = DEVICE_NAME_USER; in vbg_pci_probe()
354 gdev->misc_device_user.fops = &vbg_misc_device_user_fops; in vbg_pci_probe()
356 ret = vbg_core_init(gdev, VMMDEV_EVENT_MOUSE_POSITION_CHANGED); in vbg_pci_probe()
360 ret = vbg_create_input_device(gdev); in vbg_pci_probe()
367 gdev); in vbg_pci_probe()
373 ret = misc_register(&gdev->misc_device); in vbg_pci_probe()
380 ret = misc_register(&gdev->misc_device_user); in vbg_pci_probe()
389 vbg_gdev = gdev; in vbg_pci_probe()
399 pci_set_drvdata(pci, gdev); in vbg_pci_probe()
404 misc_deregister(&gdev->misc_device_user); in vbg_pci_probe()
406 misc_deregister(&gdev->misc_device); in vbg_pci_probe()
408 free_irq(pci->irq, gdev); in vbg_pci_probe()
410 vbg_core_exit(gdev); in vbg_pci_probe()
419 struct vbg_dev *gdev = pci_get_drvdata(pci); in vbg_pci_remove() local
425 free_irq(pci->irq, gdev); in vbg_pci_remove()
426 misc_deregister(&gdev->misc_device_user); in vbg_pci_remove()
427 misc_deregister(&gdev->misc_device); in vbg_pci_remove()
428 vbg_core_exit(gdev); in vbg_pci_remove()
449 void vbg_put_gdev(struct vbg_dev *gdev) in vbg_put_gdev() argument
451 WARN_ON(gdev != vbg_gdev); in vbg_put_gdev()
464 void vbg_linux_mouse_event(struct vbg_dev *gdev) in vbg_linux_mouse_event() argument
469 gdev->mouse_status_req->mouse_features = 0; in vbg_linux_mouse_event()
470 gdev->mouse_status_req->pointer_pos_x = 0; in vbg_linux_mouse_event()
471 gdev->mouse_status_req->pointer_pos_y = 0; in vbg_linux_mouse_event()
472 rc = vbg_req_perform(gdev, gdev->mouse_status_req); in vbg_linux_mouse_event()
474 input_report_abs(gdev->input, ABS_X, in vbg_linux_mouse_event()
475 gdev->mouse_status_req->pointer_pos_x); in vbg_linux_mouse_event()
476 input_report_abs(gdev->input, ABS_Y, in vbg_linux_mouse_event()
477 gdev->mouse_status_req->pointer_pos_y); in vbg_linux_mouse_event()
478 input_sync(gdev->input); in vbg_linux_mouse_event()