/*1* This supplies .note.* sections to go into the PT_NOTE inside the vDSO text.2* Here we can supply some information useful to userland.3*/45#include <linux/version.h>6#include <linux/elfnote.h>78/* Ideally this would use UTS_NAME, but using a quoted string here9doesn't work. Remember to change this when changing the10kernel's name. */11ELFNOTE_START(Linux, 0, "a")12.long LINUX_VERSION_CODE13ELFNOTE_END1415#ifdef CONFIG_XEN16/*17* Add a special note telling glibc's dynamic linker a fake hardware18* flavor that it will use to choose the search path for libraries in the19* same way it uses real hardware capabilities like "mmx".20* We supply "nosegneg" as the fake capability, to indicate that we21* do not like negative offsets in instructions using segment overrides,22* since we implement those inefficiently. This makes it possible to23* install libraries optimized to avoid those access patterns in someplace24* like /lib/i686/tls/nosegneg. Note that an /etc/ld.so.conf.d/file25* corresponding to the bits here is needed to make ldconfig work right.26* It should contain:27* hwcap 1 nosegneg28* to match the mapping of bit to name that we give here.29*30* At runtime, the fake hardware feature will be considered to be present31* if its bit is set in the mask word. So, we start with the mask 0, and32* at boot time we set VDSO_NOTE_NONEGSEG_BIT if running under Xen.33*/3435#include "../../xen/vdso.h" /* Defines VDSO_NOTE_NONEGSEG_BIT. */3637ELFNOTE_START(GNU, 2, "a")38.long 1 /* ncaps */39VDSO32_NOTE_MASK: /* Symbol used by arch/x86/xen/setup.c */40.long 0 /* mask */41.byte VDSO_NOTE_NONEGSEG_BIT; .asciz "nosegneg" /* bit, name */42ELFNOTE_END43#endif444546