diff options
author | Shawn Lin <shawn.lin@rock-chips.com> | 2016-08-21 03:57:33 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2016-08-24 10:20:58 -0400 |
commit | ffe67c2fabf128122b30fbf0ac498928e171b0b3 (patch) | |
tree | f0c0aa161d0b99b078817b3750f59df9d081f99c /tools/perf/util/lzma.c | |
parent | 04e11960aa9a5edbe612dd8623190e341aedab35 (diff) |
perf tools: Fix error handling of lzma decompression
lzma_decompress_to_file() never actually closes the file pointer, let's
fix it.
Signed-off-by: Shawn Lin <shawn.lin@rock-chips.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1471766253-1964-1-git-send-email-shawn.lin@rock-chips.com
[ Make err = -1, the common case, set it to 0 before the error label ]
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/lzma.c')
-rw-r--r-- | tools/perf/util/lzma.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/tools/perf/util/lzma.c b/tools/perf/util/lzma.c index 95a1acb61245..9ddea5cecd94 100644 --- a/tools/perf/util/lzma.c +++ b/tools/perf/util/lzma.c | |||
@@ -29,6 +29,7 @@ int lzma_decompress_to_file(const char *input, int output_fd) | |||
29 | lzma_action action = LZMA_RUN; | 29 | lzma_action action = LZMA_RUN; |
30 | lzma_stream strm = LZMA_STREAM_INIT; | 30 | lzma_stream strm = LZMA_STREAM_INIT; |
31 | lzma_ret ret; | 31 | lzma_ret ret; |
32 | int err = -1; | ||
32 | 33 | ||
33 | u8 buf_in[BUFSIZE]; | 34 | u8 buf_in[BUFSIZE]; |
34 | u8 buf_out[BUFSIZE]; | 35 | u8 buf_out[BUFSIZE]; |
@@ -45,7 +46,7 @@ int lzma_decompress_to_file(const char *input, int output_fd) | |||
45 | if (ret != LZMA_OK) { | 46 | if (ret != LZMA_OK) { |
46 | pr_err("lzma: lzma_stream_decoder failed %s (%d)\n", | 47 | pr_err("lzma: lzma_stream_decoder failed %s (%d)\n", |
47 | lzma_strerror(ret), ret); | 48 | lzma_strerror(ret), ret); |
48 | return -1; | 49 | goto err_fclose; |
49 | } | 50 | } |
50 | 51 | ||
51 | strm.next_in = NULL; | 52 | strm.next_in = NULL; |
@@ -60,7 +61,7 @@ int lzma_decompress_to_file(const char *input, int output_fd) | |||
60 | 61 | ||
61 | if (ferror(infile)) { | 62 | if (ferror(infile)) { |
62 | pr_err("lzma: read error: %s\n", strerror(errno)); | 63 | pr_err("lzma: read error: %s\n", strerror(errno)); |
63 | return -1; | 64 | goto err_fclose; |
64 | } | 65 | } |
65 | 66 | ||
66 | if (feof(infile)) | 67 | if (feof(infile)) |
@@ -74,7 +75,7 @@ int lzma_decompress_to_file(const char *input, int output_fd) | |||
74 | 75 | ||
75 | if (writen(output_fd, buf_out, write_size) != write_size) { | 76 | if (writen(output_fd, buf_out, write_size) != write_size) { |
76 | pr_err("lzma: write error: %s\n", strerror(errno)); | 77 | pr_err("lzma: write error: %s\n", strerror(errno)); |
77 | return -1; | 78 | goto err_fclose; |
78 | } | 79 | } |
79 | 80 | ||
80 | strm.next_out = buf_out; | 81 | strm.next_out = buf_out; |
@@ -83,13 +84,15 @@ int lzma_decompress_to_file(const char *input, int output_fd) | |||
83 | 84 | ||
84 | if (ret != LZMA_OK) { | 85 | if (ret != LZMA_OK) { |
85 | if (ret == LZMA_STREAM_END) | 86 | if (ret == LZMA_STREAM_END) |
86 | return 0; | 87 | break; |
87 | 88 | ||
88 | pr_err("lzma: failed %s\n", lzma_strerror(ret)); | 89 | pr_err("lzma: failed %s\n", lzma_strerror(ret)); |
89 | return -1; | 90 | goto err_fclose; |
90 | } | 91 | } |
91 | } | 92 | } |
92 | 93 | ||
94 | err = 0; | ||
95 | err_fclose: | ||
93 | fclose(infile); | 96 | fclose(infile); |
94 | return 0; | 97 | return err; |
95 | } | 98 | } |