[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-devel] [PATCH v2 1/4] makedumpfile/xen: Add cache_init() call to initial_xen()



Commit 92563d7a7a5175ef78c4a94ee269b1b455331b4c (cache: Allocate buffers
at initialization to detect malloc() failure) split cache_alloc() to
cache_init() and cache_alloc(). cache_init() is called in initial().
However, sadly initial_xen() is called before cache_init() and it uses
cache_alloc() indirectly which refers to uninitialized structures.
Hence, makedumfile run on Xen crash dumps finally fails. This patch adds
cache_init() call to initial_xen() and fixes above mentioned issue.
cache_init() is called in initial() if crash dump is not Xen one.

Signed-off-by: Daniel Kiper <daniel.kiper@xxxxxxxxxx>
---
 makedumpfile.c |   21 +++++++++++++++------
 1 file changed, 15 insertions(+), 6 deletions(-)

diff --git a/makedumpfile.c b/makedumpfile.c
index 0c68f32..55e53b7 100644
--- a/makedumpfile.c
+++ b/makedumpfile.c
@@ -3117,7 +3117,7 @@ out:
                DEBUG_MSG("Buffer size for the cyclic mode: %ld\n", 
info->bufsize_cyclic);
        }
 
-       if (!cache_init())
+       if (!is_xen_memory() && !cache_init())
                return FALSE;
 
        if (debug_info) {
@@ -7622,6 +7622,7 @@ exclude_xen_user_domain(void)
 int
 initial_xen(void)
 {
+       int xen_info_required = TRUE;
        off_t offset;
        unsigned long size;
 
@@ -7673,8 +7674,10 @@ initial_xen(void)
                 * and get both the offset and the size.
                 */
                if (!has_vmcoreinfo_xen()){
-                       if (!info->flag_exclude_xen_dom)
+                       if (!info->flag_exclude_xen_dom) {
+                               xen_info_required = FALSE;
                                goto out;
+                       }
 
                        MSG("%s doesn't contain a vmcoreinfo for Xen.\n",
                            info->name_memory);
@@ -7691,6 +7694,7 @@ initial_xen(void)
                        return FALSE;
        }
 
+out:
        if (!info->page_size) {
                /*
                 * If we cannot get page_size from a vmcoreinfo file,
@@ -7700,12 +7704,17 @@ initial_xen(void)
                        return FALSE;
        }
 
-       if (!get_xen_info())
+       if (!cache_init())
                return FALSE;
 
-       if (message_level & ML_PRINT_DEBUG_MSG)
-               show_data_xen();
-out:
+       if (xen_info_required == TRUE) {
+               if (!get_xen_info())
+                       return FALSE;
+
+               if (message_level & ML_PRINT_DEBUG_MSG)
+                       show_data_xen();
+       }
+
        if (!get_max_mapnr())
                return FALSE;
 
-- 
1.7.10.4


_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.