diff options
Diffstat (limited to 'sys/kern/imgact_elf.c')
| -rw-r--r-- | sys/kern/imgact_elf.c | 40 | 
1 files changed, 20 insertions, 20 deletions
| diff --git a/sys/kern/imgact_elf.c b/sys/kern/imgact_elf.c index 1bc2491a1a12..779158b41221 100644 --- a/sys/kern/imgact_elf.c +++ b/sys/kern/imgact_elf.c @@ -92,7 +92,7 @@  #define	ELF_ABI_ID	__CONCAT(elf, __ELF_WORD_SIZE)  static int __elfN(check_header)(const Elf_Ehdr *hdr); -static Elf_Brandinfo *__elfN(get_brandinfo)(struct image_params *imgp, +static const Elf_Brandinfo *__elfN(get_brandinfo)(struct image_params *imgp,      const char *interp, int32_t *osrel, uint32_t *fctl0);  static int __elfN(load_file)(struct proc *p, const char *file, u_long *addr,      u_long *entry); @@ -104,7 +104,7 @@ static bool __elfN(freebsd_trans_osrel)(const Elf_Note *note,      int32_t *osrel);  static bool kfreebsd_trans_osrel(const Elf_Note *note, int32_t *osrel);  static bool __elfN(check_note)(struct image_params *imgp, -    Elf_Brandnote *checknote, int32_t *osrel, bool *has_fctl0, +    const Elf_Brandnote *checknote, int32_t *osrel, bool *has_fctl0,      uint32_t *fctl0);  static vm_prot_t __elfN(trans_prot)(Elf_Word);  static Elf_Word __elfN(untrans_prot)(vm_prot_t); @@ -227,11 +227,11 @@ SYSCTL_BOOL(ELF_NODE_OID, OID_AUTO, allow_wx,      CTLFLAG_RWTUN, &__elfN(allow_wx), 0,      "Allow pages to be mapped simultaneously writable and executable"); -static Elf_Brandinfo *elf_brand_list[MAX_BRANDS]; +static const Elf_Brandinfo *elf_brand_list[MAX_BRANDS];  #define	aligned(a, t)	(rounddown2((u_long)(a), sizeof(t)) == (u_long)(a)) -Elf_Brandnote __elfN(freebsd_brandnote) = { +const Elf_Brandnote __elfN(freebsd_brandnote) = {  	.hdr.n_namesz	= sizeof(FREEBSD_ABI_VENDOR),  	.hdr.n_descsz	= sizeof(int32_t),  	.hdr.n_type	= NT_FREEBSD_ABI_TAG, @@ -254,7 +254,7 @@ __elfN(freebsd_trans_osrel)(const Elf_Note *note, int32_t *osrel)  static int GNU_KFREEBSD_ABI_DESC = 3; -Elf_Brandnote __elfN(kfreebsd_brandnote) = { +const Elf_Brandnote __elfN(kfreebsd_brandnote) = {  	.hdr.n_namesz	= sizeof(GNU_ABI_VENDOR),  	.hdr.n_descsz	= 16,	/* XXX at least 16 */  	.hdr.n_type	= 1, @@ -286,7 +286,7 @@ kfreebsd_trans_osrel(const Elf_Note *note, int32_t *osrel)  }  int -__elfN(insert_brand_entry)(Elf_Brandinfo *entry) +__elfN(insert_brand_entry)(const Elf_Brandinfo *entry)  {  	int i; @@ -305,7 +305,7 @@ __elfN(insert_brand_entry)(Elf_Brandinfo *entry)  }  int -__elfN(remove_brand_entry)(Elf_Brandinfo *entry) +__elfN(remove_brand_entry)(const Elf_Brandinfo *entry)  {  	int i; @@ -321,7 +321,7 @@ __elfN(remove_brand_entry)(Elf_Brandinfo *entry)  }  bool -__elfN(brand_inuse)(Elf_Brandinfo *entry) +__elfN(brand_inuse)(const Elf_Brandinfo *entry)  {  	struct proc *p;  	bool rval = false; @@ -338,12 +338,12 @@ __elfN(brand_inuse)(Elf_Brandinfo *entry)  	return (rval);  } -static Elf_Brandinfo * +static const Elf_Brandinfo *  __elfN(get_brandinfo)(struct image_params *imgp, const char *interp,      int32_t *osrel, uint32_t *fctl0)  {  	const Elf_Ehdr *hdr = (const Elf_Ehdr *)imgp->image_header; -	Elf_Brandinfo *bi, *bi_m; +	const Elf_Brandinfo *bi, *bi_m;  	bool ret, has_fctl0;  	int i, interp_name_len; @@ -492,7 +492,7 @@ __elfN(phdr_in_zero_page)(const Elf_Ehdr *hdr)  static int  __elfN(check_header)(const Elf_Ehdr *hdr)  { -	Elf_Brandinfo *bi; +	const Elf_Brandinfo *bi;  	int i;  	if (!IS_ELF(*hdr) || @@ -1109,7 +1109,7 @@ __CONCAT(exec_, __elfN(imgact))(struct image_params *imgp)  	struct vmspace *vmspace;  	vm_map_t map;  	char *interp; -	Elf_Brandinfo *brand_info; +	const Elf_Brandinfo *brand_info;  	struct sysentvec *sv;  	u_long addr, baddr, entry, proghdr;  	u_long maxalign, maxsalign, mapsz, maxv, maxv1, anon_loc; @@ -1925,7 +1925,7 @@ __elfN(puthdr)(struct thread *td, void *hdr, size_t hdrsize, int numsegs,  	Elf_Phdr *phdr;  	Elf_Shdr *shdr;  	struct phdr_closure phc; -	Elf_Brandinfo *bi; +	const Elf_Brandinfo *bi;  	ehdr = (Elf_Ehdr *)hdr;  	bi = td->td_proc->p_elf_brandinfo; @@ -2831,7 +2831,7 @@ __elfN(parse_notes)(const struct image_params *imgp, const Elf_Note *checknote,  		}  		if ((const char *)note_end - (const char *)note <  		    sizeof(Elf_Note)) { -			uprintf("ELF note to short\n"); +			uprintf("ELF note too short\n");  			goto retf;  		}  		if (note->n_namesz != checknote->n_namesz || @@ -2839,9 +2839,9 @@ __elfN(parse_notes)(const struct image_params *imgp, const Elf_Note *checknote,  		    note->n_type != checknote->n_type)  			goto nextnote;  		note_name = (const char *)(note + 1); -		if (note_name + checknote->n_namesz >= -		    (const char *)note_end || strncmp(note_vendor, -		    note_name, checknote->n_namesz) != 0) +		if (note_name + roundup2(note->n_namesz, ELF_NOTE_ROUNDSIZE) + +		    note->n_descsz >= (const char *)note_end || +		    strncmp(note_vendor, note_name, checknote->n_namesz) != 0)  			goto nextnote;  		if (cb(note, cb_arg, &res)) @@ -2861,7 +2861,7 @@ ret:  }  struct brandnote_cb_arg { -	Elf_Brandnote *brandnote; +	const Elf_Brandnote *brandnote;  	int32_t *osrel;  }; @@ -2883,7 +2883,7 @@ brandnote_cb(const Elf_Note *note, void *arg0, bool *res)  	return (true);  } -static Elf_Note fctl_note = { +static const Elf_Note fctl_note = {  	.n_namesz = sizeof(FREEBSD_ABI_VENDOR),  	.n_descsz = sizeof(uint32_t),  	.n_type = NT_FREEBSD_FEATURE_CTL, @@ -2918,7 +2918,7 @@ note_fctl_cb(const Elf_Note *note, void *arg0, bool *res)   * as for headers.   */  static bool -__elfN(check_note)(struct image_params *imgp, Elf_Brandnote *brandnote, +__elfN(check_note)(struct image_params *imgp, const Elf_Brandnote *brandnote,      int32_t *osrel, bool *has_fctl0, uint32_t *fctl0)  {  	const Elf_Phdr *phdr; | 
