root/arch/loongarch/kernel/vmlinux.lds.S
/* SPDX-License-Identifier: GPL-2.0 */
#include <linux/sizes.h>
#include <asm/asm-offsets.h>
#include <asm/thread_info.h>
#include <asm/orc_lookup.h>

#define PAGE_SIZE _PAGE_SIZE
#define RO_EXCEPTION_TABLE_ALIGN        4
#define PHYSADDR_MASK                   0xffffffffffff /* 48-bit */

/*
 * Put .bss..swapper_pg_dir as the first thing in .bss. This will
 * ensure that it has .bss alignment (64K).
 */
#define BSS_FIRST_SECTIONS *(.bss..swapper_pg_dir)

#include <asm-generic/vmlinux.lds.h>
#include "image-vars.h"

/*
 * Max avaliable Page Size is 64K, so we set SectionAlignment
 * field of EFI application to 64K.
 */
PECOFF_FILE_ALIGN = 0x200;
PECOFF_SEGMENT_ALIGN = 0x10000;

OUTPUT_ARCH(loongarch)
ENTRY(kernel_entry)
PHDRS {
        text PT_LOAD FLAGS(7);  /* RWX */
        note PT_NOTE FLAGS(4);  /* R__ */
}

jiffies  = jiffies_64;

SECTIONS
{
        . = VMLINUX_LOAD_ADDRESS;

        _text = .;
        HEAD_TEXT_SECTION

        . = ALIGN(PECOFF_SEGMENT_ALIGN);
        _stext = .;
        .text : {
                TEXT_TEXT
                SCHED_TEXT
                LOCK_TEXT
                KPROBES_TEXT
                IRQENTRY_TEXT
                SOFTIRQENTRY_TEXT
                *(.fixup)
                *(.gnu.warning)
        } :text = 0
        . = ALIGN(PECOFF_SEGMENT_ALIGN);
        _etext = .;

        . = ALIGN(PECOFF_SEGMENT_ALIGN);
        __init_begin = .;
        __inittext_begin = .;

        INIT_TEXT_SECTION(PAGE_SIZE)
        .exit.text : {
                EXIT_TEXT
        }

        . = ALIGN(PECOFF_SEGMENT_ALIGN);
        __inittext_end = .;

        __initdata_begin = .;

        /*
         * struct alt_inst entries. From the header (alternative.h):
         * "Alternative instructions for different CPU types or capabilities"
         * Think locking instructions on spinlocks.
         */
        . = ALIGN(4);
        .altinstructions : AT(ADDR(.altinstructions) - LOAD_OFFSET) {
                __alt_instructions = .;
                *(.altinstructions)
                __alt_instructions_end = .;
        }

        INIT_DATA_SECTION(16)
        .exit.data : {
                EXIT_DATA
        }

#ifdef CONFIG_SMP
        PERCPU_SECTION(1 << CONFIG_L1_CACHE_SHIFT)
#endif

        .init.bss : {
                *(.init.bss)
        }
        . = ALIGN(PECOFF_SEGMENT_ALIGN);
        __initdata_end = .;

        __init_end = .;

        _sdata = .;
        RO_DATA(4096)

        .got : ALIGN(16) { *(.got) }
        .plt : ALIGN(16) { *(.plt) }
        .got.plt : ALIGN(16) { *(.got.plt) }

        RW_DATA(1 << CONFIG_L1_CACHE_SHIFT, PAGE_SIZE, THREAD_SIZE)

        .rela.dyn : ALIGN(8) {
                __rela_dyn_begin = .;
                 *(.rela.dyn) *(.rela*)
                __rela_dyn_end = .;
        }

#ifdef CONFIG_RELR
        .relr.dyn : ALIGN(8) {
                __relr_dyn_begin = .;
                 *(.relr.dyn)
                __relr_dyn_end = .;
        }
#endif

        .data.rel : { *(.data.rel*) }

#ifdef CONFIG_RELOCATABLE
        . = ALIGN(8);
        .la_abs : AT(ADDR(.la_abs) - LOAD_OFFSET) {
                __la_abs_begin = .;
                *(.la_abs)
                __la_abs_end = .;
        }
#endif

        ORC_UNWIND_TABLE

        .sdata : {
                *(.sdata)
        }
        .edata_padding : { BYTE(0); . = ALIGN(PECOFF_FILE_ALIGN); }
        _edata =  .;

        BSS_SECTION(0, SZ_64K, 8)
        . = ALIGN(PECOFF_SEGMENT_ALIGN);

        _end = .;

        STABS_DEBUG
        DWARF_DEBUG
        MODINFO
        ELF_DETAILS

#ifdef CONFIG_EFI_STUB
        /* header symbols */
        _kernel_entry = ABSOLUTE(kernel_entry & PHYSADDR_MASK);
        _kernel_asize = ABSOLUTE(_end - _text);
        _kernel_fsize = ABSOLUTE(_edata - _text);
        _kernel_vsize = ABSOLUTE(_end - __initdata_begin);
        _kernel_rsize = ABSOLUTE(_edata - __initdata_begin);
#endif

        .gptab.sdata : {
                *(.gptab.data)
                *(.gptab.sdata)
        }
        .gptab.sbss : {
                *(.gptab.bss)
                *(.gptab.sbss)
        }

        DISCARDS
        /DISCARD/ : {
                *(.dynamic .dynsym .dynstr .hash .gnu.hash)
                *(.gnu.attributes)
                *(.options)
                *(.eh_frame)
        }
}