kern.ldscript revision 1.16
11.16Smaxv/*	$NetBSD: kern.ldscript,v 1.16 2015/11/28 18:08:40 maxv Exp $	*/
21.1Sthorpej
31.15Suebayasi#include "assym.h"
41.15Suebayasi
51.1SthorpejENTRY(_start)
61.1SthorpejSECTIONS
71.1Sthorpej{
81.16Smaxv	/* Read-only sections, merged into text segment: */
91.16Smaxv	.text :
101.16Smaxv	{
111.16Smaxv		*(.text)
121.16Smaxv		*(.text.*)
131.16Smaxv		*(.stub)
141.16Smaxv	}
151.16Smaxv	_etext = . ;
161.16Smaxv	PROVIDE (etext = .) ;
171.16Smaxv
181.16Smaxv	.rodata :
191.16Smaxv	{
201.16Smaxv		*(.rodata)
211.16Smaxv		*(.rodata.*)
221.16Smaxv	}
231.16Smaxv
241.16Smaxv	/*
251.16Smaxv	 * Adjust the address for the data segment.  We want to adjust up to
261.16Smaxv	 * the same address within the page on the next page up.
271.16Smaxv	 */
281.16Smaxv	. = ALIGN(0x1000) + (. & (0x1000 - 1));
291.16Smaxv	__data_start = . ;
301.16Smaxv	.data :
311.16Smaxv	{
321.16Smaxv		*(.data)
331.16Smaxv	}
341.16Smaxv
351.16Smaxv	. = ALIGN(COHERENCY_UNIT);
361.16Smaxv	.data.cacheline_aligned :
371.16Smaxv	{
381.16Smaxv		*(.data.cacheline_aligned)
391.16Smaxv	}
401.16Smaxv	. = ALIGN(COHERENCY_UNIT);
411.16Smaxv	.data.read_mostly :
421.16Smaxv	{
431.16Smaxv		*(.data.read_mostly)
441.16Smaxv	}
451.16Smaxv	. = ALIGN(COHERENCY_UNIT);
461.16Smaxv	_edata = . ;
471.16Smaxv	PROVIDE (edata = .) ;
481.16Smaxv	__bss_start = . ;
491.16Smaxv	.bss :
501.16Smaxv	{
511.16Smaxv		*(.bss)
521.16Smaxv		*(.bss.*)
531.16Smaxv		*(COMMON)
541.16Smaxv	. = ALIGN(32 / 8);
551.16Smaxv	}
561.16Smaxv	. = ALIGN(32 / 8);
571.16Smaxv	_end = . ;
581.16Smaxv	PROVIDE (end = .) ;
591.16Smaxv	.note.netbsd.ident :
601.16Smaxv	{
611.16Smaxv		KEEP(*(.note.netbsd.ident));
621.16Smaxv	}
631.1Sthorpej}
641.16Smaxv
651.13SuebayasiSECTIONS
661.13Suebayasi{
671.16Smaxv	.text :
681.16Smaxv	AT (ADDR(.text) & 0x0fffffff)
691.16Smaxv	{
701.16Smaxv		*(.text)
711.16Smaxv	} = 0
721.13Suebayasi}
73