|
@@ -196,15 +196,16 @@ enum {
|
|
|
static const struct {
|
|
|
const char *fmt;
|
|
|
int (*decompress)(const char *input, int output);
|
|
|
+ bool (*is_compressed)(const char *input);
|
|
|
} compressions[] = {
|
|
|
[COMP_ID__NONE] = { .fmt = NULL, },
|
|
|
#ifdef HAVE_ZLIB_SUPPORT
|
|
|
- { "gz", gzip_decompress_to_file },
|
|
|
+ { "gz", gzip_decompress_to_file, gzip_is_compressed },
|
|
|
#endif
|
|
|
#ifdef HAVE_LZMA_SUPPORT
|
|
|
- { "xz", lzma_decompress_to_file },
|
|
|
+ { "xz", lzma_decompress_to_file, lzma_is_compressed },
|
|
|
#endif
|
|
|
- { NULL, NULL },
|
|
|
+ { NULL, NULL, NULL },
|
|
|
};
|
|
|
|
|
|
static int is_supported_compression(const char *ext)
|
|
@@ -262,6 +263,22 @@ static int decompress_kmodule(struct dso *dso, const char *name,
|
|
|
if (dso->comp == COMP_ID__NONE)
|
|
|
return -1;
|
|
|
|
|
|
+ /*
|
|
|
+ * We have proper compression id for DSO and yet the file
|
|
|
+ * behind the 'name' can still be plain uncompressed object.
|
|
|
+ *
|
|
|
+ * The reason is behind the logic we open the DSO object files,
|
|
|
+ * when we try all possible 'debug' objects until we find the
|
|
|
+ * data. So even if the DSO is represented by 'krava.xz' module,
|
|
|
+ * we can end up here opening ~/.debug/....23432432/debug' file
|
|
|
+ * which is not compressed.
|
|
|
+ *
|
|
|
+ * To keep this transparent, we detect this and return the file
|
|
|
+ * descriptor to the uncompressed file.
|
|
|
+ */
|
|
|
+ if (!compressions[dso->comp].is_compressed(name))
|
|
|
+ return open(name, O_RDONLY);
|
|
|
+
|
|
|
fd = mkstemp(tmpbuf);
|
|
|
if (fd < 0) {
|
|
|
dso->load_errno = errno;
|