diff options
author | Joao Martins <joao.m.martins@oracle.com> | 2019-09-07 19:45:23 -0400 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2019-09-11 11:36:30 -0400 |
commit | 5cc59f597c0666c6a7e1c67aac9063895949fd56 (patch) | |
tree | d1acceb96df708a0935b4a8a33b52b843b41c1d5 /drivers/cpuidle | |
parent | 7321440829a27d58c88b7fcfcbbc37487b5e39a5 (diff) |
cpuidle-haltpoll: return -ENODEV on modinit failure
When a user loads cpuidle-haltpoll on a non KVM guest the module will
successfully load, even though idle driver registration didn't take
place.
We should instead return -ENODEV signaling the user that the driver can't
be loaded, like other error paths in haltpoll_init(). An example of such
error paths is when we return -EBUSY when attempting to register an idle
driver when it had one already (e.g. intel_idle loads at boot and then we
attempt to insert module cpuidle-haltpoll).
Fixes: fa86ee90eb11 ("add cpuidle-haltpoll driver")
Signed-off-by: Joao Martins <joao.m.martins@oracle.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'drivers/cpuidle')
-rw-r--r-- | drivers/cpuidle/cpuidle-haltpoll.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/cpuidle/cpuidle-haltpoll.c b/drivers/cpuidle/cpuidle-haltpoll.c index 519e90d125cf..7a0239ef717e 100644 --- a/drivers/cpuidle/cpuidle-haltpoll.c +++ b/drivers/cpuidle/cpuidle-haltpoll.c | |||
@@ -99,7 +99,7 @@ static int __init haltpoll_init(void) | |||
99 | cpuidle_poll_state_init(drv); | 99 | cpuidle_poll_state_init(drv); |
100 | 100 | ||
101 | if (!kvm_para_available()) | 101 | if (!kvm_para_available()) |
102 | return 0; | 102 | return -ENODEV; |
103 | 103 | ||
104 | ret = cpuidle_register_driver(drv); | 104 | ret = cpuidle_register_driver(drv); |
105 | if (ret < 0) | 105 | if (ret < 0) |