From: Johannes Berg <johannes.b...@intel.com>

Use just a single vmalloc() with struct_size() instead of
a separate kmalloc() for the iter struct.

Signed-off-by: Johannes Berg <johannes.b...@intel.com>
---
 kernel/gcov/fs.c | 24 +++++++++---------------
 1 file changed, 9 insertions(+), 15 deletions(-)

diff --git a/kernel/gcov/fs.c b/kernel/gcov/fs.c
index 2d29e1d1225d..40ea81c0475b 100644
--- a/kernel/gcov/fs.c
+++ b/kernel/gcov/fs.c
@@ -97,9 +97,9 @@ __setup("gcov_persist=", gcov_persist_setup);
  */
 struct gcov_iterator {
        struct gcov_info *info;
-       void *buffer;
        size_t size;
        loff_t pos;
+       char buffer[];
 };
 
 /**
@@ -111,25 +111,20 @@ struct gcov_iterator {
 static struct gcov_iterator *gcov_iter_new(struct gcov_info *info)
 {
        struct gcov_iterator *iter;
+       size_t size;
+
+       /* Dry-run to get the actual buffer size. */
+       size = convert_to_gcda(NULL, info);
 
-       iter = kzalloc(sizeof(struct gcov_iterator), GFP_KERNEL);
+       iter = vmalloc(struct_size(iter, buffer, size));
        if (!iter)
-               goto err_free;
+               return NULL;
 
        iter->info = info;
-       /* Dry-run to get the actual buffer size. */
-       iter->size = convert_to_gcda(NULL, info);
-       iter->buffer = vmalloc(iter->size);
-       if (!iter->buffer)
-               goto err_free;
-
+       iter->size = size;
        convert_to_gcda(iter->buffer, info);
 
        return iter;
-
-err_free:
-       kfree(iter);
-       return NULL;
 }
 
 
@@ -139,8 +134,7 @@ static struct gcov_iterator *gcov_iter_new(struct gcov_info 
*info)
  */
 static void gcov_iter_free(struct gcov_iterator *iter)
 {
-       vfree(iter->buffer);
-       kfree(iter);
+       vfree(iter);
 }
 
 /**
-- 
2.30.2

Reply via email to