enable gcc warnings and fix all warnings

This commit is contained in:
Josh Poimboeuf 2014-03-05 09:24:29 -06:00
parent 81cc4a3542
commit 693426b5ef
4 changed files with 8 additions and 20 deletions

View File

@ -1,6 +1,6 @@
include ../Makefile.inc
CFLAGS += -I../kmod/core
CFLAGS += -I../kmod/core -Wall
LDFLAGS = -lelf
TARGETS = create-diff-object add-patches-section link-vmlinux-syms

View File

@ -141,7 +141,7 @@ static void find_section_by_name(struct elf *elf, char *name, struct section *se
GElf_Shdr sh;
char *secname;
while (scn = elf_nextscn(elf->elf, scn)) {
while ((scn = elf_nextscn(elf->elf, scn))) {
if (!gelf_getshdr(scn, &sh))
ERROR("gelf_getshdr");
@ -207,7 +207,6 @@ int main(int argc, char **argv)
struct symlist symlist, symlistv;
struct sym *cur, *vsym;
struct elf elf, elfv;
char name[255];
void *buf;
struct kpatch_patch *patches_data;
GElf_Rela *relas_data;
@ -252,7 +251,7 @@ int main(int argc, char **argv)
cur->vm_addr = vsym->sym.st_value;
cur->vm_len = vsym->sym.st_size;
cur->action = PATCH;
printf("original function at address %016lx (length %d)\n",
printf("original function at address %016lx (length %zu)\n",
cur->vm_addr, cur->vm_len);
patches_nr++;
}

View File

@ -428,7 +428,6 @@ struct kpatch_elf *kpatch_elf_open(const char *name)
void kpatch_compare_correlated_nonrela_section(struct section *sec)
{
struct section *sec1 = sec, *sec2 = sec->twin;
enum status status;
/* Compare section headers (must match or fatal) */
if (sec1->sh.sh_type != sec2->sh.sh_type ||
@ -666,8 +665,7 @@ void kpatch_correlate_elfs(struct kpatch_elf *kelf1, struct kpatch_elf *kelf2)
void kpatch_compare_correlated_elements(struct kpatch_elf *kelf)
{
struct section *sec;
struct rela *rela;
int i, j;
int i;
/* tables are already correlated at this point */
kpatch_compare_correlated_nonrela_sections(&kelf->sections);
@ -715,7 +713,7 @@ void kpatch_dump_kelf(struct kpatch_elf *kelf)
printf(", base-> %s\n", sec->base->name);
printf("rela section expansion\n");
for_each_rela(j, rela, &sec->relas) {
printf("sym %d, offset %d, type %d, %s %s %d %s\n",
printf("sym %lu, offset %d, type %d, %s %s %d %s\n",
GELF_R_SYM(rela->rela.r_info),
rela->offset, rela->type,
rela->sym->name,
@ -1158,7 +1156,7 @@ void kpatch_create_symtab(struct kpatch_elf *kelf)
void kpatch_write_output_elf(struct kpatch_elf *kelf, Elf *elf, char *outfile)
{
int fd, i, index = 0;
int fd, i;
struct section *sec;
Elf *elfout;
GElf_Ehdr eh, ehout;

View File

@ -138,7 +138,7 @@ static void find_section_by_name(struct elf *elf, char *name, struct section *se
GElf_Shdr sh;
char *secname;
while (scn = elf_nextscn(elf->elf, scn)) {
while ((scn = elf_nextscn(elf->elf, scn))) {
if (!gelf_getshdr(scn, &sh))
ERROR("gelf_getshdr");
@ -205,17 +205,9 @@ int main(int argc, char **argv)
struct sym *cur, *vsym;
struct elf elf, elfv;
char name[255];
void *buf;
struct kpatch_patch *patches_data;
GElf_Rela *relas_data;
int patches_nr = 0, i, patches_size, relas_size, len;
int patches_offset, relas_offset, patches_index, relas_index;
struct section symtab;
Elf_Scn *scn;
Elf_Data *data;
GElf_Shdr sh, *shp;
GElf_Ehdr eh;
GElf_Sym sym;
/* set elf version (required by libelf) */
if (elf_version(EV_CURRENT) == EV_NONE)
@ -280,7 +272,7 @@ int main(int argc, char **argv)
cur->vm_addr = vsym->sym.st_value;
cur->vm_len = vsym->sym.st_size;
cur->action = LINK;
printf("original symbol at address %016lx (length %d)\n",
printf("original symbol at address %016lx (length %zu)\n",
cur->vm_addr, cur->vm_len);
}
@ -360,7 +352,6 @@ int main(int argc, char **argv)
#endif
find_section_by_name(&elf, ".symtab", &symtab);
scn = symtab.scn;
shp = &symtab.sh;
data = elf_getdata(scn, NULL);
if (!data)