diff options
author | Scott Bauer <scott.bauer@intel.com> | 2017-02-22 10:15:08 -0700 |
---|---|---|
committer | Jens Axboe <axboe@fb.com> | 2017-02-23 11:55:44 -0700 |
commit | 2d19020b085eaf61d24377db27e8630cd9cff7ce (patch) | |
tree | 6423a5ec0b75faf1975bfbe13147c4f0defdacb8 /block | |
parent | e286bcfc59e01c2c57f2d79a46063c0bddb7a0d1 (diff) | |
download | lwn-2d19020b085eaf61d24377db27e8630cd9cff7ce.tar.gz lwn-2d19020b085eaf61d24377db27e8630cd9cff7ce.zip |
block/sed-opal: Propagate original error message to userland.
During an error on a comannd, ex: user provides wrong pw to unlock
range, we will gracefully terminate the opal session. We want to
propagate the original error to userland instead of the result of
the session termination, which is almost always a success.
Signed-off-by: Scott Bauer <scott.bauer@intel.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'block')
-rw-r--r-- | block/sed-opal.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/block/sed-opal.c b/block/sed-opal.c index 020bf3e28e38..1e18dca360fc 100644 --- a/block/sed-opal.c +++ b/block/sed-opal.c @@ -396,8 +396,11 @@ static int next(struct opal_dev *dev) * session. Therefore we shouldn't attempt to terminate * a session, as one has not yet been created. */ - if (state > 1) - return end_opal_session_error(dev); + if (state > 1) { + end_opal_session_error(dev); + return error; + } + } state++; } while (!error); |