Driver core: fix driver_register() return value
commitb4e01e264884a0acbb11c85e3e6d22d23b3f8194
authorStas Sergeev <stsp@aknet.ru>
Sat, 17 Oct 2009 20:31:38 +0000 (18 00:31 +0400)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 10 Nov 2009 00:22:16 +0000 (9 16:22 -0800)
treee1918ce5523c0daa28906d6548bd92ba27e02958
parent6acffd270b393f4f81e2eebe9aaf5d6837afb07e
Driver core: fix driver_register() return value

commit 39acbc12affcaa23ef1d887ba3d197baca8e6e47 upstream.

In this patch:
http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commitdiff;h=16dc42e018c2868211b4928f20a957c0c216126c
the check was added for another driver to already claim the same device
on the same bus. But the returned error code was wrong: to modprobe, the
-EEXIST means that _this_ driver is already installed. It therefore
doesn't produce the needed error message when _another_ driver is trying
to register for the same device.  Returning -EBUSY fixes the problem.

Signed-off-by: Stas Sergeev <stsp@aknet.ru>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/base/driver.c