diff options
-rw-r--r-- | fs/ubifs/lpt.c | 45 |
1 files changed, 38 insertions, 7 deletions
diff --git a/fs/ubifs/lpt.c b/fs/ubifs/lpt.c index cd11b23a187..db8bd0e518b 100644 --- a/fs/ubifs/lpt.c +++ b/fs/ubifs/lpt.c | |||
@@ -288,25 +288,56 @@ uint32_t ubifs_unpack_bits(uint8_t **addr, int *pos, int nrbits) | |||
288 | const int k = 32 - nrbits; | 288 | const int k = 32 - nrbits; |
289 | uint8_t *p = *addr; | 289 | uint8_t *p = *addr; |
290 | int b = *pos; | 290 | int b = *pos; |
291 | uint32_t val; | 291 | uint32_t uninitialized_var(val); |
292 | const int bytes = (nrbits + b + 7) >> 3; | ||
292 | 293 | ||
293 | ubifs_assert(nrbits > 0); | 294 | ubifs_assert(nrbits > 0); |
294 | ubifs_assert(nrbits <= 32); | 295 | ubifs_assert(nrbits <= 32); |
295 | ubifs_assert(*pos >= 0); | 296 | ubifs_assert(*pos >= 0); |
296 | ubifs_assert(*pos < 8); | 297 | ubifs_assert(*pos < 8); |
297 | if (b) { | 298 | if (b) { |
298 | val = p[1] | ((uint32_t)p[2] << 8) | ((uint32_t)p[3] << 16) | | 299 | switch (bytes) { |
299 | ((uint32_t)p[4] << 24); | 300 | case 2: |
301 | val = p[1]; | ||
302 | break; | ||
303 | case 3: | ||
304 | val = p[1] | ((uint32_t)p[2] << 8); | ||
305 | break; | ||
306 | case 4: | ||
307 | val = p[1] | ((uint32_t)p[2] << 8) | | ||
308 | ((uint32_t)p[3] << 16); | ||
309 | break; | ||
310 | case 5: | ||
311 | val = p[1] | ((uint32_t)p[2] << 8) | | ||
312 | ((uint32_t)p[3] << 16) | | ||
313 | ((uint32_t)p[4] << 24); | ||
314 | } | ||
300 | val <<= (8 - b); | 315 | val <<= (8 - b); |
301 | val |= *p >> b; | 316 | val |= *p >> b; |
302 | nrbits += b; | 317 | nrbits += b; |
303 | } else | 318 | } else { |
304 | val = p[0] | ((uint32_t)p[1] << 8) | ((uint32_t)p[2] << 16) | | 319 | switch (bytes) { |
305 | ((uint32_t)p[3] << 24); | 320 | case 1: |
321 | val = p[0]; | ||
322 | break; | ||
323 | case 2: | ||
324 | val = p[0] | ((uint32_t)p[1] << 8); | ||
325 | break; | ||
326 | case 3: | ||
327 | val = p[0] | ((uint32_t)p[1] << 8) | | ||
328 | ((uint32_t)p[2] << 16); | ||
329 | break; | ||
330 | case 4: | ||
331 | val = p[0] | ((uint32_t)p[1] << 8) | | ||
332 | ((uint32_t)p[2] << 16) | | ||
333 | ((uint32_t)p[3] << 24); | ||
334 | break; | ||
335 | } | ||
336 | } | ||
306 | val <<= k; | 337 | val <<= k; |
307 | val >>= k; | 338 | val >>= k; |
308 | b = nrbits & 7; | 339 | b = nrbits & 7; |
309 | p += nrbits / 8; | 340 | p += nrbits >> 3; |
310 | *addr = p; | 341 | *addr = p; |
311 | *pos = b; | 342 | *pos = b; |
312 | ubifs_assert((val >> nrbits) == 0 || nrbits - b == 32); | 343 | ubifs_assert((val >> nrbits) == 0 || nrbits - b == 32); |