staging: unisys: visorbus: remove character device interface
authorSameer Wadgaonkar <sameer.wadgaonkar@unisys.com>
Tue, 21 Feb 2017 17:53:30 +0000 (12:53 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 6 Mar 2017 08:16:58 +0000 (09:16 +0100)
Removed the character device interface from visorchipset and
removed the major and minor numbers.

Reported-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Sameer Wadgaonkar <sameer.wadgaonkar@unisys.com>
Signed-off-by: David Kershner <david.kershner@unisys.com>
Reviewed-by: Tim Sell <timothy.sell@unisys.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/unisys/visorbus/visorchipset.c

index b3c3cddceb12e39f823c2fee3fd8db324c8b4103..c120c466ecee50adabedfb78c88af2bd0d1e5d0a 100644 (file)
@@ -15,7 +15,6 @@
  */
 
 #include <linux/acpi.h>
-#include <linux/cdev.h>
 #include <linux/ctype.h>
 #include <linux/fs.h>
 #include <linux/mm.h>
@@ -36,8 +35,6 @@
 
 #define MAX_CONTROLVM_PAYLOAD_BYTES (1024 * 128)
 
-#define VISORCHIPSET_MMAP_CONTROLCHANOFFSET    0x00000000
-
 #define UNISYS_SPAR_LEAF_ID 0x40000000
 
 /* The s-Par leaf ID returns "UnisysSpar64" encoded across ebx, ecx, edx */
 #define UNISYS_SPAR_ID_ECX 0x70537379
 #define UNISYS_SPAR_ID_EDX 0x34367261
 
-/*
- * Module parameters
- */
-static int visorchipset_major;
-
-static int
-visorchipset_open(struct inode *inode, struct file *file)
-{
-       unsigned int minor_number = iminor(inode);
-
-       if (minor_number)
-               return -ENODEV;
-       return 0;
-}
-
-static int
-visorchipset_release(struct inode *inode, struct file *file)
-{
-       return 0;
-}
-
 /*
  * When the controlvm channel is idle for at least MIN_IDLE_SECONDS,
  * we switch to slow polling mode. As soon as we get a controlvm
@@ -88,8 +64,6 @@ struct visorchipset_device {
        /* when we got our last controlvm message */
        unsigned long most_recent_message_jiffies;
        struct delayed_work periodic_controlvm_work;
-       struct cdev file_cdev;
-       struct visorchannel **file_controlvm_channel;
        struct visorchannel *controlvm_channel;
        unsigned long controlvm_payload_bytes_buffered;
        /*
@@ -112,9 +86,6 @@ struct parahotplug_request {
        struct controlvm_message msg;
 };
 
-/* info for /dev/visorchipset */
-static dev_t major_dev = -1; /*< indicates major num for device */
-
 /* prototypes for attributes */
 static ssize_t toolaction_show(struct device *dev,
                               struct device_attribute *attr,
@@ -1537,46 +1508,6 @@ device_resume_response(struct visor_device *dev_info, int response)
        dev_info->pending_msg_hdr = NULL;
 }
 
-static int
-visorchipset_mmap(struct file *file, struct vm_area_struct *vma)
-{
-       unsigned long physaddr = 0;
-       unsigned long offset = vma->vm_pgoff << PAGE_SHIFT;
-       u64 addr = 0;
-
-       /* sv_enable_dfp(); */
-       if (offset & (PAGE_SIZE - 1))
-               return -ENXIO;  /* need aligned offsets */
-
-       switch (offset) {
-       case VISORCHIPSET_MMAP_CONTROLCHANOFFSET:
-               vma->vm_flags |= VM_IO;
-               if (!*chipset_dev->file_controlvm_channel)
-                       return -ENXIO;
-
-               visorchannel_read
-                       (*chipset_dev->file_controlvm_channel,
-                        offsetof(struct spar_controlvm_channel_protocol,
-                                 gp_control_channel),
-                        &addr, sizeof(addr));
-               if (!addr)
-                       return -ENXIO;
-
-               physaddr = (unsigned long)addr;
-               if (remap_pfn_range(vma, vma->vm_start,
-                                   physaddr >> PAGE_SHIFT,
-                                   vma->vm_end - vma->vm_start,
-                                   /*pgprot_noncached */
-                                   (vma->vm_page_prot))) {
-                       return -EAGAIN;
-               }
-               break;
-       default:
-               return -ENXIO;
-       }
-       return 0;
-}
-
 static inline s64 issue_vmcall_query_guest_virtual_time_offset(void)
 {
        u64 result = VMCALL_SUCCESS;
@@ -1595,79 +1526,6 @@ static inline int issue_vmcall_update_physical_time(u64 adjustment)
        return result;
 }
 
-static long visorchipset_ioctl(struct file *file, unsigned int cmd,
-                              unsigned long arg)
-{
-       u64 adjustment;
-       s64 vrtc_offset;
-
-       switch (cmd) {
-       case VMCALL_QUERY_GUEST_VIRTUAL_TIME_OFFSET:
-               /* get the physical rtc offset */
-               vrtc_offset = issue_vmcall_query_guest_virtual_time_offset();
-               if (copy_to_user((void __user *)arg, &vrtc_offset,
-                                sizeof(vrtc_offset))) {
-                       return -EFAULT;
-               }
-               return 0;
-       case VMCALL_UPDATE_PHYSICAL_TIME:
-               if (copy_from_user(&adjustment, (void __user *)arg,
-                                  sizeof(adjustment))) {
-                       return -EFAULT;
-               }
-               return issue_vmcall_update_physical_time(adjustment);
-       default:
-               return -EFAULT;
-       }
-}
-
-static const struct file_operations visorchipset_fops = {
-       .owner = THIS_MODULE,
-       .open = visorchipset_open,
-       .read = NULL,
-       .write = NULL,
-       .unlocked_ioctl = visorchipset_ioctl,
-       .release = visorchipset_release,
-       .mmap = visorchipset_mmap,
-};
-
-static int
-visorchipset_file_init(dev_t major_dev, struct visorchannel **controlvm_channel)
-{
-       int rc = 0;
-
-       chipset_dev->file_controlvm_channel = controlvm_channel;
-       cdev_init(&chipset_dev->file_cdev, &visorchipset_fops);
-       chipset_dev->file_cdev.owner = THIS_MODULE;
-       if (MAJOR(major_dev) == 0) {
-               rc = alloc_chrdev_region(&major_dev, 0, 1, "visorchipset");
-               /* dynamic major device number registration required */
-               if (rc < 0)
-                       return rc;
-       } else {
-               /* static major device number registration required */
-               rc = register_chrdev_region(major_dev, 1, "visorchipset");
-               if (rc < 0)
-                       return rc;
-       }
-       rc = cdev_add(&chipset_dev->file_cdev,
-                     MKDEV(MAJOR(major_dev), 0), 1);
-       if (rc < 0) {
-               unregister_chrdev_region(major_dev, 1);
-               return rc;
-       }
-       return 0;
-}
-
-static void
-visorchipset_file_cleanup(dev_t major_dev)
-{
-       if (chipset_dev->file_cdev.ops)
-               cdev_del(&chipset_dev->file_cdev);
-       chipset_dev->file_cdev.ops = NULL;
-       unregister_chrdev_region(major_dev, 1);
-}
-
 static struct parser_context *
 parser_init_byte_stream(u64 addr, u32 bytes, bool local, bool *retry)
 {
@@ -1992,12 +1850,6 @@ visorchipset_init(struct acpi_device *acpi_device)
                                visorchannel_get_header(controlvm_channel)))
                goto error_destroy_channel;
 
-       major_dev = MKDEV(visorchipset_major, 0);
-       err = visorchipset_file_init(major_dev,
-                                    &chipset_dev->controlvm_channel);
-       if (err < 0)
-               goto error_destroy_channel;
-
        /* if booting in a crash kernel */
        if (is_kdump_kernel())
                INIT_DELAYED_WORK(&chipset_dev->periodic_controlvm_work,
@@ -2011,7 +1863,6 @@ visorchipset_init(struct acpi_device *acpi_device)
        schedule_delayed_work(&chipset_dev->periodic_controlvm_work,
                              chipset_dev->poll_jiffies);
 
-       visorchipset_platform_device.dev.devt = major_dev;
        if (platform_device_register(&visorchipset_platform_device) < 0) {
                POSTCODE_LINUX(DEVICE_REGISTER_FAILURE_PC, 0, 0,
                               DIAG_SEVERITY_ERR);
@@ -2031,7 +1882,6 @@ error_unregister:
 
 error_cancel_work:
        cancel_delayed_work_sync(&chipset_dev->periodic_controlvm_work);
-       visorchipset_file_cleanup(major_dev);
 
 error_destroy_channel:
        visorchannel_destroy(chipset_dev->controlvm_channel);
@@ -2050,12 +1900,8 @@ visorchipset_exit(struct acpi_device *acpi_device)
        POSTCODE_LINUX(DRIVER_EXIT_PC, 0, 0, DIAG_SEVERITY_PRINT);
 
        visorbus_exit();
-
        cancel_delayed_work_sync(&chipset_dev->periodic_controlvm_work);
-
        visorchannel_destroy(chipset_dev->controlvm_channel);
-
-       visorchipset_file_cleanup(visorchipset_platform_device.dev.devt);
        platform_device_unregister(&visorchipset_platform_device);
        kfree(chipset_dev);
 
@@ -2117,10 +1963,6 @@ static void exit_unisys(void)
        acpi_bus_unregister_driver(&unisys_acpi_driver);
 }
 
-module_param_named(major, visorchipset_major, int, 0444);
-MODULE_PARM_DESC(visorchipset_major,
-                "major device number to use for the device node");
-
 module_init(init_unisys);
 module_exit(exit_unisys);