Browse Source

HID: Move dereferences below a NULL test

If the NULL test is necessary, then the dereferences should be moved below
the NULL test.

The semantic patch that makes this change is as follows:
(http://www.emn.fr/x-info/coccinelle/)

// <smpl>
@@
type T;
expression E,E1;
identifier i,fld;
statement S;
@@

- T i = E->fld;
+ T i;
  ... when != E=E1
      when != i
  if (E == NULL||...) S
+ i = E->fld;
// </smpl>

Signed-off-by: Julia Lawall <julia@diku.dk>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
Julia Lawall 16 years ago
parent
commit
76c317d6e5
1 changed files with 4 additions and 2 deletions
  1. 4 2
      drivers/hid/hid-core.c

+ 4 - 2
drivers/hid/hid-core.c

@@ -1075,14 +1075,16 @@ EXPORT_SYMBOL_GPL(hid_report_raw_event);
  */
  */
 int hid_input_report(struct hid_device *hid, int type, u8 *data, int size, int interrupt)
 int hid_input_report(struct hid_device *hid, int type, u8 *data, int size, int interrupt)
 {
 {
-	struct hid_report_enum *report_enum = hid->report_enum + type;
-	struct hid_driver *hdrv = hid->driver;
+	struct hid_report_enum *report_enum;
+	struct hid_driver *hdrv;
 	struct hid_report *report;
 	struct hid_report *report;
 	unsigned int i;
 	unsigned int i;
 	int ret;
 	int ret;
 
 
 	if (!hid || !hid->driver)
 	if (!hid || !hid->driver)
 		return -ENODEV;
 		return -ENODEV;
+	report_enum = hid->report_enum + type;
+	hdrv = hid->driver;
 
 
 	if (!size) {
 	if (!size) {
 		dbg_hid("empty report\n");
 		dbg_hid("empty report\n");