__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _ASM_GENERIC_SECTIONS_H_
#define _ASM_GENERIC_SECTIONS_H_

/* References to section boundaries */

#include <linux/compiler.h>
#include <linux/types.h>

/*
 * Usage guidelines:
 * _text, _data: architecture specific, don't use them in arch-independent code
 * [_stext, _etext]: contains .text.* sections, may also contain .rodata.*
 *                   and/or .init.* sections
 * [_sdata, _edata]: contains .data.* sections, may also contain .rodata.*
 *                   and/or .init.* sections.
 * [__start_rodata, __end_rodata]: contains .rodata.* sections
 * [__start_ro_after_init, __end_ro_after_init]:
 *		     contains .data..ro_after_init section
 * [__init_begin, __init_end]: contains .init.* sections, but .init.text.*
 *                   may be out of this range on some architectures.
 * [_sinittext, _einittext]: contains .init.text.* sections
 * [__bss_start, __bss_stop]: contains BSS sections
 *
 * Following global variables are optional and may be unavailable on some
 * architectures and/or kernel configurations.
 *	_text, _data
 *	__kprobes_text_start, __kprobes_text_end
 *	__entry_text_start, __entry_text_end
 *	__ctors_start, __ctors_end
 *	__irqentry_text_start, __irqentry_text_end
 *	__softirqentry_text_start, __softirqentry_text_end
 *	__start_opd, __end_opd
 */
extern char _text[], _stext[], _etext[];
extern char _data[], _sdata[], _edata[];
extern char __bss_start[], __bss_stop[];
extern char __init_begin[], __init_end[];
extern char _sinittext[], _einittext[];
extern char __start_ro_after_init[], __end_ro_after_init[];
extern char _end[];
extern char __per_cpu_load[], __per_cpu_start[], __per_cpu_end[];
extern char __kprobes_text_start[], __kprobes_text_end[];
extern char __entry_text_start[], __entry_text_end[];
extern char __start_rodata[], __end_rodata[];
extern char __irqentry_text_start[], __irqentry_text_end[];
extern char __softirqentry_text_start[], __softirqentry_text_end[];
extern char __start_once[], __end_once[];

/* Start and end of .ctors section - used for constructor calls. */
extern char __ctors_start[], __ctors_end[];

/* Start and end of .opd section - used for function descriptors. */
extern char __start_opd[], __end_opd[];

/* Start and end of instrumentation protected text section */
extern char __noinstr_text_start[], __noinstr_text_end[];

extern __visible const void __nosave_begin, __nosave_end;

/* Function descriptor handling (if any).  Override in asm/sections.h */
#ifdef CONFIG_HAVE_FUNCTION_DESCRIPTORS
void *dereference_function_descriptor(void *ptr);
void *dereference_kernel_function_descriptor(void *ptr);
#else
#define dereference_function_descriptor(p) ((void *)(p))
#define dereference_kernel_function_descriptor(p) ((void *)(p))

/* An address is simply the address of the function. */
typedef struct {
	unsigned long addr;
} func_desc_t;
#endif

static inline bool have_function_descriptors(void)
{
	return IS_ENABLED(CONFIG_HAVE_FUNCTION_DESCRIPTORS);
}

/**
 * memory_contains - checks if an object is contained within a memory region
 * @begin: virtual address of the beginning of the memory region
 * @end: virtual address of the end of the memory region
 * @virt: virtual address of the memory object
 * @size: size of the memory object
 *
 * Returns: true if the object specified by @virt and @size is entirely
 * contained within the memory region defined by @begin and @end, false
 * otherwise.
 */
static inline bool memory_contains(void *begin, void *end, void *virt,
				   size_t size)
{
	return virt >= begin && virt + size <= end;
}

/**
 * memory_intersects - checks if the region occupied by an object intersects
 *                     with another memory region
 * @begin: virtual address of the beginning of the memory region
 * @end: virtual address of the end of the memory region
 * @virt: virtual address of the memory object
 * @size: size of the memory object
 *
 * Returns: true if an object's memory region, specified by @virt and @size,
 * intersects with the region specified by @begin and @end, false otherwise.
 */
static inline bool memory_intersects(void *begin, void *end, void *virt,
				     size_t size)
{
	void *vend = virt + size;

	if (virt < end && vend > begin)
		return true;

	return false;
}

/**
 * init_section_contains - checks if an object is contained within the init
 *                         section
 * @virt: virtual address of the memory object
 * @size: size of the memory object
 *
 * Returns: true if the object specified by @virt and @size is entirely
 * contained within the init section, false otherwise.
 */
static inline bool init_section_contains(void *virt, size_t size)
{
	return memory_contains(__init_begin, __init_end, virt, size);
}

/**
 * init_section_intersects - checks if the region occupied by an object
 *                           intersects with the init section
 * @virt: virtual address of the memory object
 * @size: size of the memory object
 *
 * Returns: true if an object's memory region, specified by @virt and @size,
 * intersects with the init section, false otherwise.
 */
static inline bool init_section_intersects(void *virt, size_t size)
{
	return memory_intersects(__init_begin, __init_end, virt, size);
}

/**
 * is_kernel_core_data - checks if the pointer address is located in the
 *			 .data or .bss section
 *
 * @addr: address to check
 *
 * Returns: true if the address is located in .data or .bss, false otherwise.
 * Note: On some archs it may return true for core RODATA, and false
 *       for others. But will always be true for core RW data.
 */
static inline bool is_kernel_core_data(unsigned long addr)
{
	if (addr >= (unsigned long)_sdata && addr < (unsigned long)_edata)
		return true;

	if (addr >= (unsigned long)__bss_start &&
	    addr < (unsigned long)__bss_stop)
		return true;

	return false;
}

/**
 * is_kernel_rodata - checks if the pointer address is located in the
 *                    .rodata section
 *
 * @addr: address to check
 *
 * Returns: true if the address is located in .rodata, false otherwise.
 */
static inline bool is_kernel_rodata(unsigned long addr)
{
	return addr >= (unsigned long)__start_rodata &&
	       addr < (unsigned long)__end_rodata;
}

static inline bool is_kernel_ro_after_init(unsigned long addr)
{
	return addr >= (unsigned long)__start_ro_after_init &&
	       addr < (unsigned long)__end_ro_after_init;
}
/**
 * is_kernel_inittext - checks if the pointer address is located in the
 *                      .init.text section
 *
 * @addr: address to check
 *
 * Returns: true if the address is located in .init.text, false otherwise.
 */
static inline bool is_kernel_inittext(unsigned long addr)
{
	return addr >= (unsigned long)_sinittext &&
	       addr < (unsigned long)_einittext;
}

/**
 * __is_kernel_text - checks if the pointer address is located in the
 *                    .text section
 *
 * @addr: address to check
 *
 * Returns: true if the address is located in .text, false otherwise.
 * Note: an internal helper, only check the range of _stext to _etext.
 */
static inline bool __is_kernel_text(unsigned long addr)
{
	return addr >= (unsigned long)_stext &&
	       addr < (unsigned long)_etext;
}

/**
 * __is_kernel - checks if the pointer address is located in the kernel range
 *
 * @addr: address to check
 *
 * Returns: true if the address is located in the kernel range, false otherwise.
 * Note: an internal helper, check the range of _stext to _end,
 *       and range from __init_begin to __init_end, which can be outside
 *       of the _stext to _end range.
 */
static inline bool __is_kernel(unsigned long addr)
{
	return ((addr >= (unsigned long)_stext &&
	         addr < (unsigned long)_end) ||
		(addr >= (unsigned long)__init_begin &&
		 addr < (unsigned long)__init_end));
}

#endif /* _ASM_GENERIC_SECTIONS_H_ */

Filemanager

Name Type Size Permission Actions
bitops Folder 0755
vdso Folder 0755
Kbuild File 1.64 KB 0644
access_ok.h File 1.37 KB 0644
agp.h File 277 B 0644
archrandom.h File 342 B 0644
asm-offsets.h File 35 B 0644
asm-prototypes.h File 507 B 0644
atomic.h File 3.33 KB 0644
atomic64.h File 2.49 KB 0644
audit_change_attr.h File 584 B 0644
audit_dir_write.h File 528 B 0644
audit_read.h File 241 B 0644
audit_signal.h File 36 B 0644
audit_write.h File 461 B 0644
barrier.h File 7.37 KB 0644
bitops.h File 1.13 KB 0644
bitsperlong.h File 1.18 KB 0644
bug.h File 6.26 KB 0644
cache.h File 384 B 0644
cacheflush.h File 2.63 KB 0644
cfi.h File 129 B 0644
checksum.h File 1.58 KB 0644
cmpxchg-local.h File 1.49 KB 0644
cmpxchg.h File 2.42 KB 0644
codetag.lds.h File 946 B 0644
compat.h File 3.81 KB 0644
current.h File 284 B 0644
delay.h File 2.81 KB 0644
device.h File 245 B 0644
div64.h File 6.03 KB 0644
dma-mapping.h File 232 B 0644
dma.h File 553 B 0644
early_ioremap.h File 1.46 KB 0644
emergency-restart.h File 248 B 0644
error-injection.h File 1.25 KB 0644
exec.h File 460 B 0644
extable.h File 802 B 0644
fixmap.h File 2.77 KB 0644
flat.h File 610 B 0644
fprobe.h File 1.4 KB 0644
ftrace.h File 314 B 0644
futex.h File 2.59 KB 0644
getorder.h File 1.23 KB 0644
hardirq.h File 568 B 0644
hugetlb.h File 3.58 KB 0644
hw_irq.h File 270 B 0644
int-ll64.h File 863 B 0644
io.h File 27.85 KB 0644
ioctl.h File 506 B 0644
iomap.h File 3.9 KB 0644
irq.h File 403 B 0644
irq_regs.h File 773 B 0644
irq_work.h File 194 B 0644
irqflags.h File 1.51 KB 0644
kdebug.h File 182 B 0644
kmap_size.h File 263 B 0644
kprobes.h File 833 B 0644
kvm_para.h File 549 B 0644
kvm_types.h File 113 B 0644
linkage.h File 225 B 0644
local.h File 2.31 KB 0644
local64.h File 4.04 KB 0644
logic_io.h File 2.35 KB 0644
mcs_spinlock.h File 260 B 0644
memory_model.h File 2.03 KB 0644
mm_hooks.h File 641 B 0644
mmiowb.h File 1.72 KB 0644
mmiowb_types.h File 249 B 0644
mmu.h File 449 B 0644
mmu_context.h File 1.62 KB 0644
mmzone.h File 107 B 0644
module.h File 1.09 KB 0644
module.lds.h File 278 B 0644
mshyperv.h File 9.26 KB 0644
msi.h File 1.01 KB 0644
nommu_context.h File 420 B 0644
numa.h File 1.6 KB 0644
param.h File 367 B 0644
parport.h File 604 B 0644
pci.h File 655 B 0644
pci_iomap.h File 1.96 KB 0644
percpu.h File 15.2 KB 0644
pgalloc.h File 7.6 KB 0644
pgtable-nop4d.h File 1.72 KB 0644
pgtable-nopmd.h File 2.04 KB 0644
pgtable-nopud.h File 1.95 KB 0644
pgtable_uffd.h File 1.03 KB 0644
preempt.h File 2.38 KB 0644
qrwlock.h File 3.99 KB 0644
qrwlock_types.h File 683 B 0644
qspinlock.h File 4.71 KB 0644
qspinlock_types.h File 2.08 KB 0644
resource.h File 1.07 KB 0644
runtime-const.h File 414 B 0644
rwonce.h File 3.13 KB 0644
seccomp.h File 1.16 KB 0644
sections.h File 7.67 KB 0644
serial.h File 345 B 0644
set_memory.h File 362 B 0644
shmparam.h File 207 B 0644
signal.h File 282 B 0644
simd.h File 436 B 0644
softirq_stack.h File 281 B 0644
spinlock.h File 212 B 0644
spinlock_types.h File 244 B 0644
statfs.h File 169 B 0644
string.h File 281 B 0644
switch_to.h File 755 B 0644
syscall.h File 5.03 KB 0644
syscalls.h File 745 B 0644
text-patching.h File 156 B 0644
ticket_spinlock.h File 3.26 KB 0644
timex.h File 508 B 0644
tlb.h File 21.9 KB 0644
tlbflush.h File 485 B 0644
topology.h File 2.17 KB 0644
trace_clock.h File 391 B 0644
uaccess.h File 5.51 KB 0644
user.h File 242 B 0644
vermagic.h File 179 B 0644
vga.h File 128 B 0644
video.h File 2.86 KB 0644
vmlinux.lds.h File 33.55 KB 0644
word-at-a-time.h File 2.79 KB 0644
xor.h File 14.33 KB 0644
Filemanager