X86 platform drivers
 help / color / mirror / Atom feed
* [platform-drivers-x86:testing 4/7] drivers/platform/x86/surface3-wmi.c:81:2-8: preceding lock on line 68
@ 2016-12-19 10:35 Julia Lawall
  2016-12-19 12:22 ` Andy Shevchenko
  0 siblings, 1 reply; 2+ messages in thread
From: Julia Lawall @ 2016-12-19 10:35 UTC (permalink / raw)
  To: Benjamin Tissoires
  Cc: Andy Shevchenko, Darren Hart, platform-driver-x86, kbuild-all

It looks like an unlock may be missing before the returnon line 81.

julia


tree:   git://git.infradead.org/users/dvhart/linux-platform-drivers-x86.git testing
head:   9b0d7c8018708b798c0bd6d4fe9512754c1e8c18
commit: d183a21a0df57d187dbccd710ebb5a5e457251f4 [4/7] platform/x86: Add custom surface3 platform device for controlling LID
:::::: branch date: 84 minutes ago
:::::: commit date: 2 hours ago

>> drivers/platform/x86/surface3-wmi.c:81:2-8: preceding lock on line 68

git remote add platform-drivers-x86 git://git.infradead.org/users/dvhart/linux-platform-drivers-x86.git
git remote update platform-drivers-x86
git checkout d183a21a0df57d187dbccd710ebb5a5e457251f4
vim +81 drivers/platform/x86/surface3-wmi.c

d183a21a Benjamin Tissoires 2016-11-25  62  {
d183a21a Benjamin Tissoires 2016-11-25  63  	acpi_status status;
d183a21a Benjamin Tissoires 2016-11-25  64  	union acpi_object *obj;
d183a21a Benjamin Tissoires 2016-11-25  65
d183a21a Benjamin Tissoires 2016-11-25  66  	struct acpi_buffer output = { ACPI_ALLOCATE_BUFFER, NULL };
d183a21a Benjamin Tissoires 2016-11-25  67
d183a21a Benjamin Tissoires 2016-11-25 @68  	mutex_lock(&s3_wmi_lock);
d183a21a Benjamin Tissoires 2016-11-25  69  	status = wmi_query_block(guid, instance, &output);
d183a21a Benjamin Tissoires 2016-11-25  70
d183a21a Benjamin Tissoires 2016-11-25  71  	obj = output.pointer;
d183a21a Benjamin Tissoires 2016-11-25  72
d183a21a Benjamin Tissoires 2016-11-25  73  	if (!obj || obj->type != ACPI_TYPE_INTEGER) {
d183a21a Benjamin Tissoires 2016-11-25  74  		if (obj) {
d183a21a Benjamin Tissoires 2016-11-25  75  			pr_err("query block returned object type: %d - buffer length:%d\n",
d183a21a Benjamin Tissoires 2016-11-25  76  			       obj->type,
d183a21a Benjamin Tissoires 2016-11-25  77  			       obj->type == ACPI_TYPE_BUFFER ?
d183a21a Benjamin Tissoires 2016-11-25  78  						obj->buffer.length : 0);
d183a21a Benjamin Tissoires 2016-11-25  79  		}
d183a21a Benjamin Tissoires 2016-11-25  80  		kfree(obj);
d183a21a Benjamin Tissoires 2016-11-25 @81  		return -EINVAL;
d183a21a Benjamin Tissoires 2016-11-25  82  	}
d183a21a Benjamin Tissoires 2016-11-25  83  	*ret = obj->integer.value;
d183a21a Benjamin Tissoires 2016-11-25  84  	kfree(obj);

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation

^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [platform-drivers-x86:testing 4/7] drivers/platform/x86/surface3-wmi.c:81:2-8: preceding lock on line 68
  2016-12-19 10:35 [platform-drivers-x86:testing 4/7] drivers/platform/x86/surface3-wmi.c:81:2-8: preceding lock on line 68 Julia Lawall
@ 2016-12-19 12:22 ` Andy Shevchenko
  0 siblings, 0 replies; 2+ messages in thread
From: Andy Shevchenko @ 2016-12-19 12:22 UTC (permalink / raw)
  To: Julia Lawall, Benjamin Tissoires
  Cc: Darren Hart, platform-driver-x86, kbuild-all

On Mon, 2016-12-19 at 11:35 +0100, Julia Lawall wrote:
> It looks like an unlock may be missing before the returnon line 81.
> 
> julia

There is a patch already in the tree to fix that.
Thanks!

> 
> 
> tree:   git://git.infradead.org/users/dvhart/linux-platform-drivers-
> x86.git testing
> head:   9b0d7c8018708b798c0bd6d4fe9512754c1e8c18
> commit: d183a21a0df57d187dbccd710ebb5a5e457251f4 [4/7] platform/x86:
> Add custom surface3 platform device for controlling LID
> :::::: branch date: 84 minutes ago
> :::::: commit date: 2 hours ago
> 
> >> drivers/platform/x86/surface3-wmi.c:81:2-8: preceding lock on line
> 68
> 
> git remote add platform-drivers-x86
> git://git.infradead.org/users/dvhart/linux-platform-drivers-x86.git
> git remote update platform-drivers-x86
> git checkout d183a21a0df57d187dbccd710ebb5a5e457251f4
> vim +81 drivers/platform/x86/surface3-wmi.c
> 
> d183a21a Benjamin Tissoires 2016-11-25  62  {
> d183a21a Benjamin Tissoires 2016-11-25  63      acpi_status status;
> d183a21a Benjamin Tissoires 2016-11-25  64      union acpi_object
> *obj;
> d183a21a Benjamin Tissoires 2016-11-25  65
> d183a21a Benjamin Tissoires 2016-11-25  66      struct acpi_buffer
> output = { ACPI_ALLOCATE_BUFFER, NULL };
> d183a21a Benjamin Tissoires 2016-11-25  67
> d183a21a Benjamin Tissoires 2016-11-25
> @68      mutex_lock(&s3_wmi_lock);
> d183a21a Benjamin Tissoires 2016-11-25  69      status =
> wmi_query_block(guid, instance, &output);
> d183a21a Benjamin Tissoires 2016-11-25  70
> d183a21a Benjamin Tissoires 2016-11-25  71      obj = output.pointer;
> d183a21a Benjamin Tissoires 2016-11-25  72
> d183a21a Benjamin Tissoires 2016-11-25  73      if (!obj || obj->type
> != ACPI_TYPE_INTEGER) {
> d183a21a Benjamin Tissoires 2016-11-25  74              if (obj) {
> d183a21a Benjamin Tissoires 2016-11-25 
> 75                      pr_err("query block returned object type: %d -
> buffer length:%d\n",
> d183a21a Benjamin Tissoires 2016-11-25  76                            
> obj->type,
> d183a21a Benjamin Tissoires 2016-11-25  77                            
> obj->type == ACPI_TYPE_BUFFER ?
> d183a21a Benjamin Tissoires 2016-11-25 
> 78                                              obj->buffer.length :
> 0);
> d183a21a Benjamin Tissoires 2016-11-25  79              }
> d183a21a Benjamin Tissoires 2016-11-25  80              kfree(obj);
> d183a21a Benjamin Tissoires 2016-11-25 @81              return
> -EINVAL;
> d183a21a Benjamin Tissoires 2016-11-25  82      }
> d183a21a Benjamin Tissoires 2016-11-25  83      *ret = obj-
> >integer.value;
> d183a21a Benjamin Tissoires 2016-11-25  84      kfree(obj);
> 
> ---
> 0-DAY kernel test infrastructure                Open Source Technology
> Center
> https://lists.01.org/pipermail/kbuild-all                   Intel
> Corporation

-- 
Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Intel Finland Oy

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2016-12-19 12:22 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-12-19 10:35 [platform-drivers-x86:testing 4/7] drivers/platform/x86/surface3-wmi.c:81:2-8: preceding lock on line 68 Julia Lawall
2016-12-19 12:22 ` Andy Shevchenko

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox