block/sed: Use ssize_t on atom parsers to return errors
authorJon Derrick <jonathan.derrick@intel.com>
Tue, 21 Feb 2017 18:59:13 +0000 (11:59 -0700)
committerJens Axboe <axboe@fb.com>
Wed, 22 Feb 2017 18:54:49 +0000 (11:54 -0700)
The short atom parser can return an errno from decoding but does not
currently return the error as a signed value. Convert all of the parsers
to ssize_t.

Signed-off-by: Jon Derrick <jonathan.derrick@intel.com>
Reviewed-by: Scott Bauer <scott.bauer@intel.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Jens Axboe <axboe@fb.com>
block/sed-opal.c

index d1c52ba4d62dcf7b7a34870ec6b3095eed8b5c15..4675fd8eed7bdc6be5e929edfec82de8a958ad61 100644 (file)
@@ -706,8 +706,8 @@ static enum opal_token response_get_token(const struct parsed_resp *resp,
        return tok->pos[0];
 }
 
-static size_t response_parse_tiny(struct opal_resp_tok *tok,
-                                 const u8 *pos)
+static ssize_t response_parse_tiny(struct opal_resp_tok *tok,
+                                  const u8 *pos)
 {
        tok->pos = pos;
        tok->len = 1;
@@ -723,8 +723,8 @@ static size_t response_parse_tiny(struct opal_resp_tok *tok,
        return tok->len;
 }
 
-static size_t response_parse_short(struct opal_resp_tok *tok,
-                                  const u8 *pos)
+static ssize_t response_parse_short(struct opal_resp_tok *tok,
+                                   const u8 *pos)
 {
        tok->pos = pos;
        tok->len = (pos[0] & SHORT_ATOM_LEN_MASK) + 1;
@@ -736,7 +736,7 @@ static size_t response_parse_short(struct opal_resp_tok *tok,
                tok->type = OPAL_DTA_TOKENID_SINT;
        } else {
                u64 u_integer = 0;
-               int i, b = 0;
+               ssize_t i, b = 0;
 
                tok->type = OPAL_DTA_TOKENID_UINT;
                if (tok->len > 9) {
@@ -753,8 +753,8 @@ static size_t response_parse_short(struct opal_resp_tok *tok,
        return tok->len;
 }
 
-static size_t response_parse_medium(struct opal_resp_tok *tok,
-                                   const u8 *pos)
+static ssize_t response_parse_medium(struct opal_resp_tok *tok,
+                                    const u8 *pos)
 {
        tok->pos = pos;
        tok->len = (((pos[0] & MEDIUM_ATOM_LEN_MASK) << 8) | pos[1]) + 2;
@@ -770,8 +770,8 @@ static size_t response_parse_medium(struct opal_resp_tok *tok,
        return tok->len;
 }
 
-static size_t response_parse_long(struct opal_resp_tok *tok,
-                                 const u8 *pos)
+static ssize_t response_parse_long(struct opal_resp_tok *tok,
+                                  const u8 *pos)
 {
        tok->pos = pos;
        tok->len = ((pos[1] << 16) | (pos[2] << 8) | pos[3]) + 4;
@@ -787,8 +787,8 @@ static size_t response_parse_long(struct opal_resp_tok *tok,
        return tok->len;
 }
 
-static size_t response_parse_token(struct opal_resp_tok *tok,
-                                  const u8 *pos)
+static ssize_t response_parse_token(struct opal_resp_tok *tok,
+                                   const u8 *pos)
 {
        tok->pos = pos;
        tok->len = 1;
@@ -805,7 +805,7 @@ static int response_parse(const u8 *buf, size_t length,
        struct opal_resp_tok *iter;
        int num_entries = 0;
        int total;
-       size_t token_length;
+       ssize_t token_length;
        const u8 *pos;
 
        if (!buf)
@@ -851,8 +851,8 @@ static int response_parse(const u8 *buf, size_t length,
                else /* TOKEN */
                        token_length = response_parse_token(iter, pos);
 
-               if (token_length == -EINVAL)
-                       return -EINVAL;
+               if (token_length < 0)
+                       return token_length;
 
                pos += token_length;
                total -= token_length;