[Patch] kexec: fix several issues in get_crash_notes()
Simon Horman
horms at verge.net.au
Thu Nov 17 21:11:56 EST 2011
On Wed, Nov 16, 2011 at 09:09:26PM +0800, WANG Cong wrote:
> a) We don't need 'crash_notes' array at all, save some bytes on stack.
> b) We forgot to fclose 'fp' before return.
>
> Signed-off-by: WANG Cong <xiyou.wangcong at gmail.com>
>
> ---
> diff --git a/kexec/arch/i386/crashdump-x86.c b/kexec/arch/i386/crashdump-x86.c
> index 98cda72..333f6ba 100644
> --- a/kexec/arch/i386/crashdump-x86.c
> +++ b/kexec/arch/i386/crashdump-x86.c
> @@ -589,20 +589,18 @@ static int cmdline_add_elfcorehdr(char *cmdline, unsigned long addr)
> */
> static int get_crash_notes(int cpu, uint64_t *addr, uint64_t *len)
> {
> - char crash_notes[PATH_MAX];
I wonder if the following might reduce memory usage:
const char *crash_notes = "/sys/kernel/crash_notes";
> char line[MAX_LINE];
> FILE *fp;
> unsigned long vaddr;
> int count;
>
> - sprintf(crash_notes, "/sys/kernel/crash_notes");
> - fp = fopen(crash_notes, "r");
> + fp = fopen("/sys/kernel/crash_notes", "r");
> if (fp) {
> if (fgets(line, sizeof(line), fp) != 0) {
> count = sscanf(line, "%lx", &vaddr);
> if (count != 1)
> - die("Cannot parse %s: %s\n", crash_notes,
> - strerror(errno));
> + die("Cannot parse /sys/kernel/crash_notes:"
> + " %s\n", strerror(errno));
> }
>
> *addr = x86__pa(vaddr + (cpu * MAX_NOTE_BYTES));
> @@ -610,6 +608,7 @@ static int get_crash_notes(int cpu, uint64_t *addr, uint64_t *len)
> #ifdef DEBUG
> printf("crash_notes addr = %Lx\n", *addr);
> #endif
> + fclose(fp);
> return 0;
> } else
> return get_crash_notes_per_cpu(cpu, addr, len);
>
> _______________________________________________
> kexec mailing list
> kexec at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/kexec
>
More information about the kexec
mailing list