aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2015-02-04 09:36:14 -0500
committerCorey Minyard <cminyard@mvista.com>2015-02-19 21:58:40 -0500
commit2d06a0c9b3756404e141cafcd62b29ce05238007 (patch)
treecd9e8476ce380098f8799b4c958f630f4f1c4186
parentbdf2829cb673afc3aeb4f04531546c7605e8d94e (diff)
ipmi: Use is_visible callback for conditional sysfs entries
Instead of manual calls of device_create_file() and device_remove_file(), implement the condition in is_visible callback for the attribute group and put these entries to the group, too. This simplifies the code and avoids the possible races. Signed-off-by: Takashi Iwai <tiwai@suse.de> Signed-off-by: Corey Minyard <cminyard@mvista.com>
-rw-r--r--drivers/char/ipmi/ipmi_msghandler.c60
1 files changed, 17 insertions, 43 deletions
diff --git a/drivers/char/ipmi/ipmi_msghandler.c b/drivers/char/ipmi/ipmi_msghandler.c
index 4891c39b3259..d5a2bd7230b2 100644
--- a/drivers/char/ipmi/ipmi_msghandler.c
+++ b/drivers/char/ipmi/ipmi_msghandler.c
@@ -2366,11 +2366,28 @@ static struct attribute *bmc_dev_attrs[] = {
2366 &dev_attr_additional_device_support.attr, 2366 &dev_attr_additional_device_support.attr,
2367 &dev_attr_manufacturer_id.attr, 2367 &dev_attr_manufacturer_id.attr,
2368 &dev_attr_product_id.attr, 2368 &dev_attr_product_id.attr,
2369 &dev_attr_aux_firmware_revision.attr,
2370 &dev_attr_guid.attr,
2369 NULL 2371 NULL
2370}; 2372};
2371 2373
2374static umode_t bmc_dev_attr_is_visible(struct kobject *kobj,
2375 struct attribute *attr, int idx)
2376{
2377 struct device *dev = kobj_to_dev(kobj);
2378 struct bmc_device *bmc = to_bmc_device(dev);
2379 umode_t mode = attr->mode;
2380
2381 if (attr == &dev_attr_aux_firmware_revision.attr)
2382 return bmc->id.aux_firmware_revision_set ? mode : 0;
2383 if (attr == &dev_attr_guid.attr)
2384 return bmc->guid_set ? mode : 0;
2385 return mode;
2386}
2387
2372static struct attribute_group bmc_dev_attr_group = { 2388static struct attribute_group bmc_dev_attr_group = {
2373 .attrs = bmc_dev_attrs, 2389 .attrs = bmc_dev_attrs,
2390 .is_visible = bmc_dev_attr_is_visible,
2374}; 2391};
2375 2392
2376static const struct attribute_group *bmc_dev_attr_groups[] = { 2393static const struct attribute_group *bmc_dev_attr_groups[] = {
@@ -2393,13 +2410,6 @@ cleanup_bmc_device(struct kref *ref)
2393{ 2410{
2394 struct bmc_device *bmc = container_of(ref, struct bmc_device, usecount); 2411 struct bmc_device *bmc = container_of(ref, struct bmc_device, usecount);
2395 2412
2396 if (bmc->id.aux_firmware_revision_set)
2397 device_remove_file(&bmc->pdev.dev,
2398 &dev_attr_aux_firmware_revision);
2399 if (bmc->guid_set)
2400 device_remove_file(&bmc->pdev.dev,
2401 &dev_attr_guid);
2402
2403 platform_device_unregister(&bmc->pdev); 2413 platform_device_unregister(&bmc->pdev);
2404} 2414}
2405 2415
@@ -2420,33 +2430,6 @@ static void ipmi_bmc_unregister(ipmi_smi_t intf)
2420 mutex_unlock(&ipmidriver_mutex); 2430 mutex_unlock(&ipmidriver_mutex);
2421} 2431}
2422 2432
2423static int create_bmc_files(struct bmc_device *bmc)
2424{
2425 int err;
2426
2427 if (bmc->id.aux_firmware_revision_set) {
2428 err = device_create_file(&bmc->pdev.dev,
2429 &dev_attr_aux_firmware_revision);
2430 if (err)
2431 goto out;
2432 }
2433 if (bmc->guid_set) {
2434 err = device_create_file(&bmc->pdev.dev,
2435 &dev_attr_guid);
2436 if (err)
2437 goto out_aux_firm;
2438 }
2439
2440 return 0;
2441
2442out_aux_firm:
2443 if (bmc->id.aux_firmware_revision_set)
2444 device_remove_file(&bmc->pdev.dev,
2445 &dev_attr_aux_firmware_revision);
2446out:
2447 return err;
2448}
2449
2450static int ipmi_bmc_register(ipmi_smi_t intf, int ifnum) 2433static int ipmi_bmc_register(ipmi_smi_t intf, int ifnum)
2451{ 2434{
2452 int rv; 2435 int rv;
@@ -2535,15 +2518,6 @@ static int ipmi_bmc_register(ipmi_smi_t intf, int ifnum)
2535 return rv; 2518 return rv;
2536 } 2519 }
2537 2520
2538 rv = create_bmc_files(bmc);
2539 if (rv) {
2540 mutex_lock(&ipmidriver_mutex);
2541 platform_device_unregister(&bmc->pdev);
2542 mutex_unlock(&ipmidriver_mutex);
2543
2544 return rv;
2545 }
2546
2547 dev_info(intf->si_dev, "Found new BMC (man_id: 0x%6.6x, " 2521 dev_info(intf->si_dev, "Found new BMC (man_id: 0x%6.6x, "
2548 "prod_id: 0x%4.4x, dev_id: 0x%2.2x)\n", 2522 "prod_id: 0x%4.4x, dev_id: 0x%2.2x)\n",
2549 bmc->id.manufacturer_id, 2523 bmc->id.manufacturer_id,