Commit 03b56329 authored by Jan Moskyto Matejka's avatar Jan Moskyto Matejka Committed by Greg Kroah-Hartman

Modpost: fixed USB alias generation for ranges including 0x9 and 0xA

Commit afe2dab4 ("USB: add hex/bcd detection to usb modalias generation")
changed the routine that generates alias ranges. Before that change, only
digits 0-9 were supported; the commit tried to fix the case when the range
includes higher values than 0x9.

Unfortunately, the commit didn't fix the case when the range includes both
0x9 and 0xA, meaning that the final range must look like [x-9A-y] where
x <= 0x9 and y >= 0xA -- instead the [x-9A-x] range was produced.

Modprobe doesn't complain as it sees no difference between no-match and
bad-pattern results of fnmatch().

Fixing this simple bug to fix the aliases.
Also changing the hardcoded beginning of the range to uppercase as all the
other letters are also uppercase in the device version numbers.

Fortunately, this affects only the dvb-usb-dib0700 module, AFAIK.
Signed-off-by: default avatarJan Moskyto Matejka <mq@suse.cz>
Cc: stable <stable@vger.kernel.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 7f196caf
...@@ -210,8 +210,8 @@ static void do_usb_entry(void *symval, ...@@ -210,8 +210,8 @@ static void do_usb_entry(void *symval,
range_lo < 0x9 ? "[%X-9" : "[%X", range_lo < 0x9 ? "[%X-9" : "[%X",
range_lo); range_lo);
sprintf(alias + strlen(alias), sprintf(alias + strlen(alias),
range_hi > 0xA ? "a-%X]" : "%X]", range_hi > 0xA ? "A-%X]" : "%X]",
range_lo); range_hi);
} }
} }
if (bcdDevice_initial_digits < (sizeof(bcdDevice_lo) * 2 - 1)) if (bcdDevice_initial_digits < (sizeof(bcdDevice_lo) * 2 - 1))
......
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