- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从 nasm 编译共享文件,我正在使用以下命令:
nasm -f elf64 -o asm/asm.o asm/asm.asm
ld -shared -o asm/asm.so asm/asm.o -I/lib64/ld-linux-x86-64.so.2
ld: asm/asm.o: relocation R_X86_64_32S against `.bss' can not be used when making a shared object; recompile with -fPIC
ld: final link failed: Nonrepresentable section on output
DEFAULT rel
%include "asm/python.inc"
GLOBAL PyInit_asm:function
SECTION .rodata
l_dubois_name db "dubois", 0
l_module_name db "asm", 0
SECTION .bss
digitSpace resb 100
digitSpacePos resb 8
SECTION .data
l_asm_methods:
ISTRUC PyMethodDef
at PyMethodDef.ml_name , dq l_dubois_name
at PyMethodDef.ml_meth , dq asm_dubois
at PyMethodDef.ml_flags , dq METH_NOARGS
at PyMethodDef.ml_doc , dq l_sayit_doc
IEND
NullMethodDef
l_asm_module: ;; struct PyModuleDef *
ISTRUC PyModuleDef
at PyModuleDef.m_base , PyModuleDef_HEAD_INIT
at PyModuleDef.m_name , dq l_module_name
at PyModuleDef.m_doc , dq NULL
at PyModuleDef.m_size , dq -1
at PyModuleDef.m_methods , dq l_asm_methods
at PyModuleDef.m_slots , dq NULL
at PyModuleDef.m_traverse , dq NULL
at PyModuleDef.m_clear , dq 0
at PyModuleDef.m_free , dq NULL
IEND
SECTION .text
asm_dubois:
push rbp
mov rbp, rsp
mov rax, [rbp+62]
mov rsp, rbp
pop rbp
call _printRAX
mov rax, 60
mov rdi, 0
syscall
ret
_printRAX:
mov rcx, digitSpace
mov rbx, 10
mov [rcx], rbx
inc rcx
mov [digitSpacePos], rcx
_printRAXLoop:
mov rdx, 0
mov rbx, 10
div rbx
push rax
add rdx, 48
mov rcx, [digitSpacePos]
mov [rcx], dl
inc rcx
mov [digitSpacePos], rcx
pop rax
cmp rax, 0
jne _printRAXLoop
_printRAXLoop2:
mov rcx, [digitSpacePos]
mov rax, 1
mov rdi, 1
mov rsi, rcx
mov rdx, 1
syscall
mov rcx, [digitSpacePos]
dec rcx
mov [digitSpacePos], rcx
cmp rcx, digitSpace
jge _printRAXLoop2
ret
最佳答案
recompile with -fPIC
错误消息假设 asm/object 文件是由编译器创建的。 使用手写 asm,您就是编译器,必须编写与位置无关的代码 . (或者至少是低效使用 64 位绝对地址的代码,例如 mov rcx, digitSpace
;GNU/Linux 上的这些重定位支持运行时修复。)
使用lea r8, [digitSpace]
(或任何方便的reg,最好在循环之外)并与之进行比较。
cmp rcx, digitSpace
使用静态地址作为 32 位立即符号扩展为 64 位。 这将需要一个 R_X86_64_32S
重定位:编码为 32 位有符号值的 64 位地址。 (与 [digitSpace + rdx]
相同,例如,这是 PIC/PIE 代码中不能做的另一件事)
仅限 mov
允许 64 位立即数(当您编写 mov r64, symbol
时,NASM 默认使用它)。当然,最好使用像 lea rcx, [digitSpace]
这样的 RIP 相关 LEA。 .你用过default rel
所以这将是 RIP 相关的)。
Assembler Error: Mach-O 64 bit does not support absolute 32 bit addresses 的几乎完全相同的副本 (MacOS 不允许将符号地址用作 32 位立即数,因此这是一个汇编时错误,而在 Linux 上,只有当您尝试链接到 ELF 共享对象而不是非 PIE 可执行文件时才会出现错误。)
还有相关的:
mov r32, imm32
,则最好使用 RIP 相关的 LEA 关于linux - 如何使用 nasm 编译带有 .bss 部分的共享文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59470897/
我一直假设链接器分配了任何库的 bss 部分并将其映射到进程中。该部分的大小将取决于库报告的 bss 的大小。 我查看了进程的/proc/[PID]/maps 文件,并计算了加载库的 bss 部分的大
这个问题已经有答案了: No .BSS in PE file (2 个回答) 已关闭 6 年前。 我使用 NASM 组装了以下代码: global _start section .data v
我正在编写一些适用于 .o 文件的自定义 ELF 二进制后处理代码。部分处理包括对二进制数据执行重定位。输入文件由 GNU 汇编程序根据我自己的汇编代码生成。 看看 GNU 汇编程序生成的这些疯狂的重
“.bss”命令在 MSP430 汇编代码中起什么作用?例如,“.bss beep_cnt,2”对变量 beep_cnt2 有何作用? .bss beep_cnt,2
我知道 BSS 段存储未初始化的全局和静态变量并将它们初始化为零。但是如果全局/静态变量被初始化并且我的第二个问题是我读到 BSS 段不消耗内存,那么它存储这些变量的位置呢?谢谢 最佳答案 您可能读到
我一直在研究减少应用程序的内存占用。继上一个问题后:GDB - can I find large data elements in memory我已经找到并删除了大多数最大的罪魁祸首。 nm --si
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: .bss section in elf file 你好, BSS(Block started by symb
这个问题在这里已经有了答案: Why is the .bss segment required? (6 个答案) 关闭 4 年前。 .bss 部分的意义是什么,因为我们已经有单独的数据部分。它比数据
这个问题在这里已经有了答案: Why is the .bss segment required? (6 个答案) 关闭 6 年前。 在C编程中,当一个程序执行时,程序中使用的所有数据都会被放在不同的
这是简短的控制台应用程序示例 static char buffer[4096]; int main() { for(int i=0;i<4096;i++) { buffer[i
正如我们所知,.bss 包含未初始化的变量。如果在 C 代码中,程序员在使用它们之前初始化变量。那么在执行 C 代码之前.bss 不必为零。 我说得对吗? 谢谢 最佳答案 在 C 代码中,任何具有静态
我正在使用一个测试程序来了解内核版本为 2.6.32-279.el6.x86_64 的 linux 6.3 上的 C 内存模型。 首先我编译了下面的代码, #include int main(voi
我想在编译时声明我的 C 程序中的所有变量,例如: char cache[CACHE_SIZE]; char udp_ring[MAX_UDP_PACKET_SIZE*MAX_REQUESTS]; i
我知道 .bss 的默认对齐方式对于 GCC 是 8 字节,正如这个问题中提到的 Why the int type takes up 8 bytes in BSS section but 4 byte
我有一个功能: void testfunction() { static char_t theChar1 = 1; static unsigned char smallArray[1]; sta
据我所知,如果设置了 -fzero-initialized-in-bss,则未明确初始化的静态变量(并且对于 GCC,即使是那些明确初始化为零的变量,默认情况下就是这种情况)通常存储在 BSS 段中。
静态内存布局的 BSS 部分 [应该] 用于“未初始化的全局变量”或“设置为 0 的全局变量”。 我正在运行一些测试,突然注意到局部静态变量也在增加 BSS 段的大小。 例子:- 在任何静态变量之前
静态内存布局的 BSS 部分 [应该] 用于“未初始化的全局变量”或“设置为 0 的全局变量”。 我正在运行一些测试,突然注意到局部静态变量也在增加 BSS 段的大小。 例子:- 在任何静态变量之前
我正在学习虚拟内存管理和进程内存分配。并对此做一些实验。有以下一些容易混淆的地方: 案例1 #include int main() { return 0; } 编译代码并使用二进制文件运行
希望有人能帮助我了解我在大学学习的一个漏洞。 在c代码中有一个未绑定(bind)的strcat strcat(buffer, argv[1]); 目的是将该缓冲区溢出到保存的 EIP 中,并让它显示在
我是一名优秀的程序员,十分优秀!