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 >