Blame kpatch-build/lookup.c

Packit Service ac8aad
/*
Packit Service ac8aad
 * lookup.c
Packit Service ac8aad
 *
Packit Service ac8aad
 * This file contains functions that assist in the reading and searching
Packit Service ac8aad
 * the symbol table of an ELF object.
Packit Service ac8aad
 *
Packit Service ac8aad
 * Copyright (C) 2014 Seth Jennings <sjenning@redhat.com>
Packit Service ac8aad
 * Copyright (C) 2014 Josh Poimboeuf <jpoimboe@redhat.com>
Packit Service ac8aad
 *
Packit Service ac8aad
 * This program is free software; you can redistribute it and/or
Packit Service ac8aad
 * modify it under the terms of the GNU General Public License
Packit Service ac8aad
 * as published by the Free Software Foundation; either version 2
Packit Service ac8aad
 * of the License, or (at your option) any later version.
Packit Service ac8aad
 *
Packit Service ac8aad
 * This program is distributed in the hope that it will be useful,
Packit Service ac8aad
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service ac8aad
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service ac8aad
 * GNU General Public License for more details.
Packit Service ac8aad
 *
Packit Service ac8aad
 * You should have received a copy of the GNU General Public License
Packit Service ac8aad
 * along with this program; if not, write to the Free Software
Packit Service ac8aad
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA,
Packit Service ac8aad
 * 02110-1301, USA.
Packit Service ac8aad
 */
Packit Service ac8aad
Packit Service ac8aad
#include <sys/types.h>
Packit Service ac8aad
#include <sys/stat.h>
Packit Service ac8aad
#include <sys/mman.h>
Packit Service ac8aad
#include <ctype.h>
Packit Service ac8aad
#include <fcntl.h>
Packit Service ac8aad
#include <stdlib.h>
Packit Service ac8aad
#include <stdio.h>
Packit Service ac8aad
#include <string.h>
Packit Service ac8aad
#include <error.h>
Packit Service ac8aad
#include <gelf.h>
Packit Service ac8aad
#include <unistd.h>
Packit Service ac8aad
#include <libgen.h>
Packit Service ac8aad
Packit Service ac8aad
#include "lookup.h"
Packit Service ac8aad
#include "log.h"
Packit Service ac8aad
Packit Service ac8aad
struct object_symbol {
Packit Service ac8aad
	unsigned long value;
Packit Service ac8aad
	unsigned long size;
Packit Service ac8aad
	char *name;
Packit Service ac8aad
	int type, bind;
Packit Service ac8aad
};
Packit Service ac8aad
Packit Service ac8aad
struct export_symbol {
Packit Service ac8aad
	char *name;
Packit Service ac8aad
	char *objname;
Packit Service ac8aad
};
Packit Service ac8aad
Packit Service ac8aad
struct lookup_table {
Packit Service ac8aad
	int obj_nr, exp_nr;
Packit Service ac8aad
	struct object_symbol *obj_syms;
Packit Service ac8aad
	struct export_symbol *exp_syms;
Packit Service ac8aad
	struct object_symbol *local_syms;
Packit Service ac8aad
};
Packit Service ac8aad
Packit Service ac8aad
#define for_each_obj_symbol(ndx, iter, table) \
Packit Service ac8aad
	for (ndx = 0, iter = table->obj_syms; ndx < table->obj_nr; ndx++, iter++)
Packit Service ac8aad
Packit Service ac8aad
#define for_each_obj_symbol_continue(ndx, iter, table) \
Packit Service ac8aad
	for (iter = table->obj_syms + ndx; ndx < table->obj_nr; ndx++, iter++)
Packit Service ac8aad
Packit Service ac8aad
#define for_each_exp_symbol(ndx, iter, table) \
Packit Service ac8aad
	for (ndx = 0, iter = table->exp_syms; ndx < table->exp_nr; ndx++, iter++)
Packit Service ac8aad
Packit Service ac8aad
static int maybe_discarded_sym(const char *name)
Packit Service ac8aad
{
Packit Service ac8aad
	if (!name)
Packit Service ac8aad
		return 0;
Packit Service ac8aad
Packit Service ac8aad
	/*
Packit Service ac8aad
	 * Sometimes these symbols are discarded during linking, and sometimes
Packit Service ac8aad
	 * they're not, depending on whether the parent object is vmlinux or a
Packit Service ac8aad
	 * module, and also depending on the kernel version.  For simplicity,
Packit Service ac8aad
	 * we just always skip them when comparing object symbol tables.
Packit Service ac8aad
	 */
Packit Service ac8aad
	if (!strncmp(name, "__exitcall_", 11) ||
Packit Service ac8aad
	    !strncmp(name, "__brk_reservation_fn_", 21) ||
Packit Service ac8aad
	    !strncmp(name, "__func_stack_frame_non_standard_", 32))
Packit Service ac8aad
		return 1;
Packit Service ac8aad
Packit Service ac8aad
	return 0;
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
static int locals_match(struct lookup_table *table, int idx,
Packit Service ac8aad
			struct sym_compare_type *child_locals)
Packit Service ac8aad
{
Packit Service ac8aad
	struct sym_compare_type *child;
Packit Service ac8aad
	struct object_symbol *sym;
Packit Service ac8aad
	int i, found;
Packit Service ac8aad
Packit Service ac8aad
	i = idx + 1;
Packit Service ac8aad
	for_each_obj_symbol_continue(i, sym, table) {
Packit Service ac8aad
		if (sym->type == STT_FILE)
Packit Service ac8aad
			break;
Packit Service ac8aad
		if (sym->bind != STB_LOCAL)
Packit Service ac8aad
			continue;
Packit Service ac8aad
		if (sym->type != STT_FUNC && sym->type != STT_OBJECT)
Packit Service ac8aad
			continue;
Packit Service ac8aad
Packit Service ac8aad
		found = 0;
Packit Service ac8aad
		for (child = child_locals; child->name; child++) {
Packit Service ac8aad
			if (child->type == sym->type &&
Packit Service ac8aad
			    !strcmp(child->name, sym->name)) {
Packit Service ac8aad
				found = 1;
Packit Service ac8aad
				break;
Packit Service ac8aad
			}
Packit Service ac8aad
		}
Packit Service ac8aad
Packit Service ac8aad
		if (!found)
Packit Service ac8aad
			return 0;
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	for (child = child_locals; child->name; child++) {
Packit Service ac8aad
		/*
Packit Service ac8aad
		 * Symbols which get discarded at link time are missing from
Packit Service ac8aad
		 * the lookup table, so skip them.
Packit Service ac8aad
		 */
Packit Service ac8aad
		if (maybe_discarded_sym(child->name))
Packit Service ac8aad
			continue;
Packit Service ac8aad
Packit Service ac8aad
		found = 0;
Packit Service ac8aad
		i = idx + 1;
Packit Service ac8aad
		for_each_obj_symbol_continue(i, sym, table) {
Packit Service ac8aad
			if (sym->type == STT_FILE)
Packit Service ac8aad
				break;
Packit Service ac8aad
			if (sym->bind != STB_LOCAL)
Packit Service ac8aad
				continue;
Packit Service ac8aad
			if (sym->type != STT_FUNC && sym->type != STT_OBJECT)
Packit Service ac8aad
				continue;
Packit Service ac8aad
			if (maybe_discarded_sym(sym->name))
Packit Service ac8aad
				continue;
Packit Service ac8aad
Packit Service ac8aad
			if (!strcmp(child->name, sym->name)) {
Packit Service ac8aad
				found = 1;
Packit Service ac8aad
				break;
Packit Service ac8aad
			}
Packit Service ac8aad
		}
Packit Service ac8aad
Packit Service ac8aad
		if (!found)
Packit Service ac8aad
			return 0;
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	return 1;
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
static void find_local_syms(struct lookup_table *table, char *hint,
Packit Service ac8aad
			    struct sym_compare_type *child_locals)
Packit Service ac8aad
{
Packit Service ac8aad
	struct object_symbol *sym;
Packit Service ac8aad
	int i;
Packit Service ac8aad
Packit Service ac8aad
	if (!child_locals)
Packit Service ac8aad
		return;
Packit Service ac8aad
Packit Service ac8aad
	for_each_obj_symbol(i, sym, table) {
Packit Service ac8aad
		if (sym->type != STT_FILE)
Packit Service ac8aad
			continue;
Packit Service ac8aad
		if (strcmp(hint, sym->name))
Packit Service ac8aad
			continue;
Packit Service ac8aad
		if (!locals_match(table, i, child_locals))
Packit Service ac8aad
			continue;
Packit Service ac8aad
		if (table->local_syms)
Packit Service ac8aad
			ERROR("find_local_syms for %s: found_dup", hint);
Packit Service ac8aad
Packit Service ac8aad
		table->local_syms = sym;
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	if (!table->local_syms)
Packit Service ac8aad
		ERROR("find_local_syms for %s: couldn't find in vmlinux symbol table", hint);
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
/* Strip the path and replace '-' with '_' */
Packit Service ac8aad
static char *make_modname(char *modname)
Packit Service ac8aad
{
Packit Service ac8aad
	char *cur;
Packit Service ac8aad
Packit Service ac8aad
	if (!modname)
Packit Service ac8aad
		return NULL;
Packit Service ac8aad
Packit Service ac8aad
	cur = modname;
Packit Service ac8aad
	while (*cur != '\0') {
Packit Service ac8aad
		if (*cur == '-')
Packit Service ac8aad
			*cur = '_';
Packit Service ac8aad
		cur++;
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	return basename(modname);
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
static void symtab_read(struct lookup_table *table, char *path)
Packit Service ac8aad
{
Packit Service ac8aad
	FILE *file;
Packit Service ac8aad
	long unsigned int value, size;
Packit Service ac8aad
	unsigned int i = 0;
Packit Service ac8aad
	char line[256], name[256], type[16], bind[16], ndx[16];
Packit Service ac8aad
Packit Service ac8aad
	if ((file = fopen(path, "r")) == NULL)
Packit Service ac8aad
		ERROR("fopen");
Packit Service ac8aad
Packit Service ac8aad
	while (fgets(line, 256, file)) {
Packit Service ac8aad
		if (sscanf(line, "%*s %lx %lu %s %s %*s %s %s\n",
Packit Service ac8aad
			   &value, &size, type, bind, ndx, name) != 6 ||
Packit Service ac8aad
		    !strcmp(ndx, "UNDEF") ||
Packit Service ac8aad
		    !strcmp(bind, "SECTION"))
Packit Service ac8aad
			continue;
Packit Service ac8aad
Packit Service ac8aad
		table->obj_nr++;
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	table->obj_syms = malloc(table->obj_nr * sizeof(*table->obj_syms));
Packit Service ac8aad
	if (!table->obj_syms)
Packit Service ac8aad
		ERROR("malloc table.obj_syms");
Packit Service ac8aad
	memset(table->obj_syms, 0, table->obj_nr * sizeof(*table->obj_syms));
Packit Service ac8aad
Packit Service ac8aad
	rewind(file);
Packit Service ac8aad
Packit Service ac8aad
	while (fgets(line, 256, file)) {
Packit Service ac8aad
		if (sscanf(line, "%*s %lx %lu %s %s %*s %s %s\n",
Packit Service ac8aad
			   &value, &size, type, bind, ndx, name) != 6 ||
Packit Service ac8aad
		    !strcmp(ndx, "UNDEF") ||
Packit Service ac8aad
		    !strcmp(bind, "SECTION"))
Packit Service ac8aad
			continue;
Packit Service ac8aad
Packit Service ac8aad
		table->obj_syms[i].value = value;
Packit Service ac8aad
		table->obj_syms[i].size = size;
Packit Service ac8aad
		table->obj_syms[i].name = strdup(name);
Packit Service ac8aad
Packit Service ac8aad
		if (!strcmp(bind, "LOCAL")) {
Packit Service ac8aad
			table->obj_syms[i].bind = STB_LOCAL;
Packit Service ac8aad
		} else if (!strcmp(bind, "GLOBAL")) {
Packit Service ac8aad
			table->obj_syms[i].bind = STB_GLOBAL;
Packit Service ac8aad
		} else if (!strcmp(bind, "WEAK")) {
Packit Service ac8aad
			table->obj_syms[i].bind = STB_WEAK;
Packit Service ac8aad
		} else {
Packit Service ac8aad
			ERROR("unknown symbol bind %s", bind);
Packit Service ac8aad
		}
Packit Service ac8aad
Packit Service ac8aad
		if (!strcmp(type, "NOTYPE")) {
Packit Service ac8aad
			table->obj_syms[i].type = STT_NOTYPE;
Packit Service ac8aad
		} else if (!strcmp(type, "OBJECT")) {
Packit Service ac8aad
			table->obj_syms[i].type = STT_OBJECT;
Packit Service ac8aad
		} else if (!strcmp(type, "FUNC")) {
Packit Service ac8aad
			table->obj_syms[i].type = STT_FUNC;
Packit Service ac8aad
		} else if (!strcmp(type, "FILE")) {
Packit Service ac8aad
			table->obj_syms[i].type = STT_FILE;
Packit Service ac8aad
		} else {
Packit Service ac8aad
			ERROR("unknown symbol type %s", type);
Packit Service ac8aad
		}
Packit Service ac8aad
Packit Service ac8aad
		table->obj_syms[i].name = strdup(name);
Packit Service ac8aad
		if (!table->obj_syms[i].name)
Packit Service ac8aad
			ERROR("strdup");
Packit Service ac8aad
		i++;
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	fclose(file);
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
static void symvers_read(struct lookup_table *table, char *path)
Packit Service ac8aad
{
Packit Service ac8aad
	FILE *file;
Packit Service ac8aad
	unsigned int crc, i = 0;
Packit Service ac8aad
	char name[256], mod[256], export[256];
Packit Service ac8aad
	char *objname, *symname;
Packit Service ac8aad
Packit Service ac8aad
	if ((file = fopen(path, "r")) == NULL)
Packit Service ac8aad
		ERROR("fopen");
Packit Service ac8aad
Packit Service ac8aad
	while (fscanf(file, "%x %s %s %s\n",
Packit Service ac8aad
		      &crc, name, mod, export) != EOF)
Packit Service ac8aad
		table->exp_nr++;
Packit Service ac8aad
Packit Service ac8aad
	table->exp_syms = malloc(table->exp_nr * sizeof(*table->exp_syms));
Packit Service ac8aad
	if (!table->exp_syms)
Packit Service ac8aad
		ERROR("malloc table.exp_syms");
Packit Service ac8aad
	memset(table->exp_syms, 0,
Packit Service ac8aad
	       table->exp_nr * sizeof(*table->exp_syms));
Packit Service ac8aad
Packit Service ac8aad
	rewind(file);
Packit Service ac8aad
Packit Service ac8aad
	while (fscanf(file, "%x %s %s %s\n",
Packit Service ac8aad
		      &crc, name, mod, export) != EOF) {
Packit Service ac8aad
		symname = strdup(name);
Packit Service ac8aad
		if (!symname)
Packit Service ac8aad
			perror("strdup");
Packit Service ac8aad
Packit Service ac8aad
		objname = strdup(mod);
Packit Service ac8aad
		if (!objname)
Packit Service ac8aad
			perror("strdup");
Packit Service ac8aad
		/* Modifies objname in-place */
Packit Service ac8aad
		objname = make_modname(objname);
Packit Service ac8aad
Packit Service ac8aad
		table->exp_syms[i].name = symname;
Packit Service ac8aad
		table->exp_syms[i].objname = objname;
Packit Service ac8aad
		i++;
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	fclose(file);
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
struct lookup_table *lookup_open(char *symtab_path, char *symvers_path,
Packit Service ac8aad
				 char *hint, struct sym_compare_type *locals)
Packit Service ac8aad
{
Packit Service ac8aad
	struct lookup_table *table;
Packit Service ac8aad
Packit Service ac8aad
	table = malloc(sizeof(*table));
Packit Service ac8aad
	if (!table)
Packit Service ac8aad
		ERROR("malloc table");
Packit Service ac8aad
	memset(table, 0, sizeof(*table));
Packit Service ac8aad
Packit Service ac8aad
	symtab_read(table, symtab_path);
Packit Service ac8aad
	symvers_read(table, symvers_path);
Packit Service ac8aad
	find_local_syms(table, hint, locals);
Packit Service ac8aad
Packit Service ac8aad
	return table;
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
void lookup_close(struct lookup_table *table)
Packit Service ac8aad
{
Packit Service ac8aad
	free(table->obj_syms);
Packit Service ac8aad
	free(table->exp_syms);
Packit Service ac8aad
	free(table);
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
int lookup_local_symbol(struct lookup_table *table, char *name,
Packit Service ac8aad
                        struct lookup_result *result)
Packit Service ac8aad
{
Packit Service ac8aad
	struct object_symbol *sym;
Packit Service ac8aad
	unsigned long pos = 0;
Packit Service ac8aad
	int i, match = 0, in_file = 0;
Packit Service ac8aad
Packit Service ac8aad
	if (!table->local_syms)
Packit Service ac8aad
		return 1;
Packit Service ac8aad
Packit Service ac8aad
	memset(result, 0, sizeof(*result));
Packit Service ac8aad
	for_each_obj_symbol(i, sym, table) {
Packit Service ac8aad
		if (sym->bind == STB_LOCAL && !strcmp(sym->name, name))
Packit Service ac8aad
			pos++;
Packit Service ac8aad
Packit Service ac8aad
		if (table->local_syms == sym) {
Packit Service ac8aad
			in_file = 1;
Packit Service ac8aad
			continue;
Packit Service ac8aad
		}
Packit Service ac8aad
Packit Service ac8aad
		if (!in_file)
Packit Service ac8aad
			continue;
Packit Service ac8aad
Packit Service ac8aad
		if (sym->type == STT_FILE)
Packit Service ac8aad
			break;
Packit Service ac8aad
Packit Service ac8aad
		if (sym->bind == STB_LOCAL && !strcmp(sym->name, name)) {
Packit Service ac8aad
			match = 1;
Packit Service ac8aad
			break;
Packit Service ac8aad
		}
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	if (!match)
Packit Service ac8aad
		return 1;
Packit Service ac8aad
Packit Service ac8aad
	result->pos = pos;
Packit Service ac8aad
	result->value = sym->value;
Packit Service ac8aad
	result->size = sym->size;
Packit Service ac8aad
	return 0;
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
int lookup_global_symbol(struct lookup_table *table, char *name,
Packit Service ac8aad
                         struct lookup_result *result)
Packit Service ac8aad
{
Packit Service ac8aad
	struct object_symbol *sym;
Packit Service ac8aad
	int i;
Packit Service ac8aad
Packit Service ac8aad
	memset(result, 0, sizeof(*result));
Packit Service ac8aad
	for_each_obj_symbol(i, sym, table) {
Packit Service ac8aad
		if ((sym->bind == STB_GLOBAL || sym->bind == STB_WEAK) &&
Packit Service ac8aad
		    !strcmp(sym->name, name)) {
Packit Service ac8aad
			result->value = sym->value;
Packit Service ac8aad
			result->size = sym->size;
Packit Service ac8aad
			result->pos = 0; /* always 0 for global symbols */
Packit Service ac8aad
			return 0;
Packit Service ac8aad
		}
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	return 1;
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
int lookup_is_exported_symbol(struct lookup_table *table, char *name)
Packit Service ac8aad
{
Packit Service ac8aad
	struct export_symbol *sym, *match = NULL;
Packit Service ac8aad
	int i;
Packit Service ac8aad
Packit Service ac8aad
	for_each_exp_symbol(i, sym, table) {
Packit Service ac8aad
		if (!strcmp(sym->name, name)) {
Packit Service ac8aad
			if (match)
Packit Service ac8aad
				ERROR("duplicate exported symbol found for %s", name);
Packit Service ac8aad
			match = sym;
Packit Service ac8aad
		}
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	return !!match;
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
/*
Packit Service ac8aad
 * lookup_exported_symbol_objname - find the object/module an exported
Packit Service ac8aad
 * symbol belongs to.
Packit Service ac8aad
 */
Packit Service ac8aad
char *lookup_exported_symbol_objname(struct lookup_table *table, char *name)
Packit Service ac8aad
{
Packit Service ac8aad
	struct export_symbol *sym, *match = NULL;
Packit Service ac8aad
	int i;
Packit Service ac8aad
Packit Service ac8aad
	for_each_exp_symbol(i, sym, table) {
Packit Service ac8aad
		if (!strcmp(sym->name, name)) {
Packit Service ac8aad
			if (match)
Packit Service ac8aad
				ERROR("duplicate exported symbol found for %s", name);
Packit Service ac8aad
			match = sym;
Packit Service ac8aad
		}
Packit Service ac8aad
	}
Packit Service ac8aad
Packit Service ac8aad
	if (match)
Packit Service ac8aad
		return match->objname;
Packit Service ac8aad
Packit Service ac8aad
	return NULL;
Packit Service ac8aad
 }
Packit Service ac8aad
Packit Service ac8aad
#if 0 /* for local testing */
Packit Service ac8aad
static void find_this(struct lookup_table *table, char *sym, char *hint)
Packit Service ac8aad
{
Packit Service ac8aad
	struct lookup_result result;
Packit Service ac8aad
Packit Service ac8aad
	if (hint)
Packit Service ac8aad
		lookup_local_symbol(table, sym, hint, &result);
Packit Service ac8aad
	else
Packit Service ac8aad
		lookup_global_symbol(table, sym, &result);
Packit Service ac8aad
Packit Service ac8aad
	printf("%s %s w/ %s hint at 0x%016lx len %lu pos %lu\n",
Packit Service ac8aad
	       hint ? "local" : "global", sym, hint ? hint : "no",
Packit Service ac8aad
	       result.value, result.size, result.pos);
Packit Service ac8aad
}
Packit Service ac8aad
Packit Service ac8aad
int main(int argc, char **argv)
Packit Service ac8aad
{
Packit Service ac8aad
	struct lookup_table *vmlinux;
Packit Service ac8aad
Packit Service ac8aad
	if (argc != 2)
Packit Service ac8aad
		return 1;
Packit Service ac8aad
Packit Service ac8aad
	vmlinux = lookup_open(argv[1]);
Packit Service ac8aad
Packit Service ac8aad
	printf("printk is%s exported\n",
Packit Service ac8aad
		lookup_is_exported_symbol(vmlinux, "__fentry__") ? "" : " not");
Packit Service ac8aad
	printf("meminfo_proc_show is%s exported\n",
Packit Service ac8aad
		lookup_is_exported_symbol(vmlinux, "meminfo_proc_show") ? "" : " not");
Packit Service ac8aad
Packit Service ac8aad
	find_this(vmlinux, "printk", NULL);
Packit Service ac8aad
	find_this(vmlinux, "pages_to_scan_show", "ksm.c");
Packit Service ac8aad
	find_this(vmlinux, "pages_to_scan_show", "huge_memory.c");
Packit Service ac8aad
	find_this(vmlinux, "pages_to_scan_show", NULL); /* should fail */
Packit Service ac8aad
Packit Service ac8aad
	lookup_close(vmlinux);
Packit Service ac8aad
Packit Service ac8aad
	return 0;
Packit Service ac8aad
}
Packit Service ac8aad
#endif