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()
205 struct vbg_dev *gdev = input_get_drvdata(input); in vbg_input_open() local
208 return vbg_core_set_mouse_status(gdev, feat); in vbg_input_open()
218 struct vbg_dev *gdev = input_get_drvdata(input); in vbg_input_close() local
220 vbg_core_set_mouse_status(gdev, 0); in vbg_input_close()
228 static int vbg_create_input_device(struct vbg_dev *gdev) in vbg_create_input_device() argument
232 input = devm_input_allocate_device(gdev->dev); in vbg_create_input_device()
241 input->dev.parent = gdev->dev; in vbg_create_input_device()
249 input_set_drvdata(input, gdev); in vbg_create_input_device()
251 gdev->input = input; in vbg_create_input_device()
253 return input_register_device(gdev->input); in vbg_create_input_device()
259 struct vbg_dev *gdev = dev_get_drvdata(dev); in host_version_show() local
261 return sprintf(buf, "%s\n", gdev->host_version); in host_version_show()
267 struct vbg_dev *gdev = dev_get_drvdata(dev); in host_features_show() local
269 return sprintf(buf, "%#x\n", gdev->host_features); in host_features_show()
292 struct vbg_dev *gdev; in vbg_pci_probe() local
295 gdev = devm_kzalloc(dev, sizeof(*gdev), GFP_KERNEL); in vbg_pci_probe()
296 if (!gdev) in vbg_pci_probe()
348 gdev->io_port = io; in vbg_pci_probe()
349 gdev->mmio = vmmdev; in vbg_pci_probe()
350 gdev->dev = dev; in vbg_pci_probe()
351 gdev->misc_device.minor = MISC_DYNAMIC_MINOR; in vbg_pci_probe()
352 gdev->misc_device.name = DEVICE_NAME; in vbg_pci_probe()
353 gdev->misc_device.fops = &vbg_misc_device_fops; in vbg_pci_probe()
354 gdev->misc_device_user.minor = MISC_DYNAMIC_MINOR; in vbg_pci_probe()
355 gdev->misc_device_user.name = DEVICE_NAME_USER; in vbg_pci_probe()
356 gdev->misc_device_user.fops = &vbg_misc_device_user_fops; in vbg_pci_probe()
358 ret = vbg_core_init(gdev, VMMDEV_EVENT_MOUSE_POSITION_CHANGED); in vbg_pci_probe()
362 ret = vbg_create_input_device(gdev); in vbg_pci_probe()
369 gdev); in vbg_pci_probe()
375 ret = misc_register(&gdev->misc_device); in vbg_pci_probe()
382 ret = misc_register(&gdev->misc_device_user); in vbg_pci_probe()
391 vbg_gdev = gdev; in vbg_pci_probe()
401 pci_set_drvdata(pci, gdev); in vbg_pci_probe()
406 misc_deregister(&gdev->misc_device_user); in vbg_pci_probe()
408 misc_deregister(&gdev->misc_device); in vbg_pci_probe()
410 free_irq(pci->irq, gdev); in vbg_pci_probe()
412 vbg_core_exit(gdev); in vbg_pci_probe()
421 struct vbg_dev *gdev = pci_get_drvdata(pci); in vbg_pci_remove() local
427 free_irq(pci->irq, gdev); in vbg_pci_remove()
428 misc_deregister(&gdev->misc_device_user); in vbg_pci_remove()
429 misc_deregister(&gdev->misc_device); in vbg_pci_remove()
430 vbg_core_exit(gdev); in vbg_pci_remove()
451 void vbg_put_gdev(struct vbg_dev *gdev) in vbg_put_gdev() argument
453 WARN_ON(gdev != vbg_gdev); in vbg_put_gdev()
466 void vbg_linux_mouse_event(struct vbg_dev *gdev) in vbg_linux_mouse_event() argument
471 gdev->mouse_status_req->mouse_features = 0; in vbg_linux_mouse_event()
472 gdev->mouse_status_req->pointer_pos_x = 0; in vbg_linux_mouse_event()
473 gdev->mouse_status_req->pointer_pos_y = 0; in vbg_linux_mouse_event()
474 rc = vbg_req_perform(gdev, gdev->mouse_status_req); in vbg_linux_mouse_event()
476 input_report_abs(gdev->input, ABS_X, in vbg_linux_mouse_event()
477 gdev->mouse_status_req->pointer_pos_x); in vbg_linux_mouse_event()
478 input_report_abs(gdev->input, ABS_Y, in vbg_linux_mouse_event()
479 gdev->mouse_status_req->pointer_pos_y); in vbg_linux_mouse_event()
480 input_sync(gdev->input); in vbg_linux_mouse_event()