Commit 440814ca authored by Srinivas Pandruvada's avatar Srinivas Pandruvada Committed by Hans de Goede

platform/x86: ISST: Simplify isst_misc_reg() and isst_misc_unreg()

After commit '1630dc62 ("platform/x86: ISST: Add model specific
loading for common module")' isst_misc_reg() and isst_misc_unreg() can be
simplified. Since these functions are only called during module_init()
and module_exit() respectively, there is no contention while calling
misc_register()/misc_deregister or isst_if_cpu_info_init()/
isst_if_cpu_info_exit().

Hence remove mutex and reference counting.
Signed-off-by: default avatarSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Reviewed-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Link: https://lore.kernel.org/r/20240731184256.1852840-1-srinivas.pandruvada@linux.intel.comReviewed-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
parent 523b1c03
...@@ -651,10 +651,6 @@ static long isst_if_def_ioctl(struct file *file, unsigned int cmd, ...@@ -651,10 +651,6 @@ static long isst_if_def_ioctl(struct file *file, unsigned int cmd,
/* Lock to prevent module registration when already opened by user space */ /* Lock to prevent module registration when already opened by user space */
static DEFINE_MUTEX(punit_misc_dev_open_lock); static DEFINE_MUTEX(punit_misc_dev_open_lock);
/* Lock to allow one shared misc device for all ISST interfaces */
static DEFINE_MUTEX(punit_misc_dev_reg_lock);
static int misc_usage_count;
static int misc_device_ret;
static int misc_device_open; static int misc_device_open;
static int isst_if_open(struct inode *inode, struct file *file) static int isst_if_open(struct inode *inode, struct file *file)
...@@ -720,39 +716,23 @@ static struct miscdevice isst_if_char_driver = { ...@@ -720,39 +716,23 @@ static struct miscdevice isst_if_char_driver = {
static int isst_misc_reg(void) static int isst_misc_reg(void)
{ {
mutex_lock(&punit_misc_dev_reg_lock); int ret;
if (misc_device_ret)
goto unlock_exit;
if (!misc_usage_count) { ret = isst_if_cpu_info_init();
misc_device_ret = isst_if_cpu_info_init(); if (ret)
if (misc_device_ret) return ret;
goto unlock_exit;
misc_device_ret = misc_register(&isst_if_char_driver); ret = misc_register(&isst_if_char_driver);
if (misc_device_ret) { if (ret)
isst_if_cpu_info_exit(); isst_if_cpu_info_exit();
goto unlock_exit;
}
}
misc_usage_count++;
unlock_exit:
mutex_unlock(&punit_misc_dev_reg_lock);
return misc_device_ret; return ret;
} }
static void isst_misc_unreg(void) static void isst_misc_unreg(void)
{ {
mutex_lock(&punit_misc_dev_reg_lock);
if (misc_usage_count)
misc_usage_count--;
if (!misc_usage_count && !misc_device_ret) {
misc_deregister(&isst_if_char_driver); misc_deregister(&isst_if_char_driver);
isst_if_cpu_info_exit(); isst_if_cpu_info_exit();
}
mutex_unlock(&punit_misc_dev_reg_lock);
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment