⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dl-startup.h

📁 Axis 221 camera embedded programing interface
💻 H
字号:
/* * Architecture specific code used by dl-startup.c *//* This code fixes the stack pointer so that the dynamic linker * can find argc, argv and auxvt (Auxillary Vector Table).  */#ifdef __arch_v32asm(""                          \"	.text\n"                    \"	.globl _dl_boot\n"          \"	.type _dl_boot,@function\n" \"_dl_boot:\n"                   \"	move.d $sp,$r10\n"          \"	lapc _dl_boot2,$r9\n"       \"	jsr $r9\n"                  \"	nop\n"                      \);#elseasm(""					        \"	.text\n"			        \"	.globl _dl_boot\n"		    \"	.type _dl_boot,@function\n"	\"_dl_boot:\n"				    \"	move.d $sp,$r10\n"		    \"	move.d $pc,$r9\n"		    \"	add.d _dl_boot2 - ., $r9\n"	\"	jsr $r9\n"			        \);#endif /* __arch_v32 */#define DL_BOOT(X) static void __attribute_used__ _dl_boot2 (X)/* Get a pointer to the argv array.  On many platforms this can be just * the address if the first argument, on other platforms we need to * do something a little more subtle here.  */#define GET_ARGV(ARGVP, ARGS) ARGVP = ((unsigned long *) ARGS)/* Handle relocation of the symbols in the dynamic loader. */static inlinevoid PERFORM_BOOTSTRAP_RELOC(ELF_RELOC *rpnt, unsigned long *reloc_addr,	unsigned long symbol_addr, unsigned long load_addr, Elf32_Sym *symtab){	switch (ELF32_R_TYPE(rpnt->r_info)) {		case R_CRIS_GLOB_DAT:		case R_CRIS_JUMP_SLOT:		case R_CRIS_32:			*reloc_addr = symbol_addr;			break;		case R_CRIS_16_PCREL:			*(short *) *reloc_addr = symbol_addr + rpnt->r_addend - *reloc_addr - 2;			break;		case R_CRIS_32_PCREL:			*reloc_addr = symbol_addr + rpnt->r_addend - *reloc_addr - 4;			break;		case R_CRIS_NONE:			break;		case R_CRIS_RELATIVE:			*reloc_addr = load_addr + rpnt->r_addend;			break;		default:			_dl_exit(1);			break;	}}/* Transfer control to the user's application, once the dynamic loader is * done.  This routine has to exit the current function, then call the * _dl_elf_main function.  */#ifdef __arch_v32#define START() __asm__ volatile ("moveq 0,$r8\n\t"   \                                  "move $r8,$srp\n\t" \                                  "jump %0\n\t"       \                                  "move.d %1,$sp\n\t" \                                  : : "r" (_dl_elf_main), "r" (args))#else#define START() __asm__ volatile ("moveq 0,$r8\n\t"   \                                  "move $r8,$srp\n\t" \                                  "move.d %1,$sp\n\t" \                                  "jump %0\n\t"       \                                  : : "r" (_dl_elf_main), "r" (args))#endif /* __arch_v32 */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -