- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试在 Matlab 中混合 C 代码,该代码与我使用 nasm 组装的对象链接。当我尝试混合代码时,我收到来自 Matlab 的错误。这是我用来混合代码的命令:
mex main.c hello.o
这是 C 代码:
#include <stdio.h>
#include <stdlib.h>
#include "mex.h"
extern char * helloWorld();
void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[]) {
char * sentence = helloWorld();
printf("%s\n", sentence);
}
汇编代码如下:
global helloWorld
section .data
greeting: db "Hello, World", 0
section .text
helloWorld:
mov eax, greeting
ret
我用来汇编代码的命令是:
nasm -felf64 -gdwarf2 -o hello.o hello.asm
这是我在尝试混合 C 代码时收到的错误:
/usr/bin/ld: hello.o: relocation R_X86_64_32 against `.data' can not be used
when making a shared object; recompile with -fPIC
hello.o: could not read symbols: Bad value
collect2: ld returned 1 exit status
nasm 没有 -fPIcflags。我尝试使用 get_GOT 宏以及默认 rel,但我仍然遇到相同的错误。所有帮助将不胜感激。谢谢你
最佳答案
我在使用 VS2010 作为编译器的 Windows 机器(WinXP 32 位)上。这是我所做的:
为 Windows 下载 NASM 汇编程序
在汇编代码中为导出的符号名称添加下划线:
global _helloWorld
section .data
greeting: db "Hello, World", 0
section .text
_helloWorld:
mov eax, greeting
ret
编译汇编代码如下:nasm -f win32 -o hello.obj hello.asm
在 MATLAB 中,编译链接到生成的目标文件的 MEX 文件:
>> mex main_mex.c hello.obj
正如我所说,mex
之前配置为使用 Visual Studio 2010 进行编译。
#include <stdio.h>
#include <stdlib.h>
#include "mex.h"
extern char* helloWorld();
void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[])
{
char *sentence = helloWorld();
mexPrintf("%s\n", sentence);
}
运行 MEX 函数:
>> main_mex
Hello, World
在 64 位 Windows 上,我做了以下更改:
bits 64 ; specify 64-bit target processor mode
default rel ; RIP-relative adresses
section .text
global helloWorld ; export function symbol (not mangled with an initial _)
helloWorld:
mov rax, greeting ; return string
ret
section .data
greeting: db "Hello, World", 0
然后:
>> !nasm -f win64 -o hello.obj hello.asm
>> mex -largeArrayDims hello_mex.c hello.obj
>> hello_mex
Hello, World
关于c - 使用与用 nasm 组装的对象链接的 matlab 混合 C 代码时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18367089/
在组装方面,我绝对是个初学者。我尝试找出以下内容的输出应该是什么: Jan dd 255,256 Feb dw 16, 17, 18, 19 Mar db 8, 9, 10, 11 Sub edi,
我正在用 AT&T 语法编写。这个循环应该检查大小写是否在 61-7A ASCII 范围内(这意味着是这个小字母) - 如果不是,则将其转换为空格“”。 change: movb (%esi)
mov eax, ptr_to_num1 ; little endian mov ebx, ptr_to_num2 ; little endian xor ecx, ecx xor edx, edx
我正在制作用于组装的 atoi 函数。 无论我尝试什么都行不通,我也不知道为什么。 有谁知道是什么问题? org 100h mov si, stri ;parameter call atoi
我正在使用 tasm 编写汇编程序。我的任务是编写一个程序,该程序将使用冒泡排序按字母顺序对输入的字符串进行排序。前任。如果你输入“hello”,它应该写成“ehello”。我已经写了请求输入字符串并
假设我的 GPU 包含一个名为 ADT7473 的芯片。 . 我有兴趣从该芯片接收有关我的卡温度的信息。 我的问题是,如何访问这个芯片?是使用 IN/OUT 指令完成的吗? 编辑: 我可能会添加芯片文
我需要在DOS下通过Assembly(intel)+C(c99)绘制QRCode。但看来我的内存太少了。我尝试将图像存储为位数组: image db 11111110b, ... 但无论如何我没有结果
这里有一个简短的问题。我有一个程序集被一些开发人员重复使用,其中包含各种功能,但在技术上分为代表功能逻辑 block 的各种命名空间。 现在,它提供的公共(public) namespace 越少越好
小端: mov eax,4 push dword 0x44434241 mov ebx,1 mov ecx,esp mov edx,4 int 0x80 add esp,4 我不明白为什么它打印 A
是否可以使用元编程技巧来允许在 assembly block 上使用 SFINAE?例如检测处理器上是否有类似“CPUID”的指令:(这不是有效的代码,但说明了我想要实现的目标) // This sh
我有以下形式的项目 - pom.xml - projectA - pom.xml - src/main/ - java - startupScript - projectB
在《微处理器的音乐应用》一书中,作者给出了以下算法,将两个 8 位有符号整数与 16 位有符号结果进行 4 象限相乘: 对原始操作数进行无符号乘法。然后为了更正结果,如果被乘数符号为负,则无符号单精度
我们有一个项目,我们正在 build 大量 Scalatra microservices通过使用 sbt-assembly 打包它们插件,然后使用 sbt-docker 创建 Docker 镜像插入。
所有使用布局的 assemble 用户都知道“{{> body }}”标记了任何使用布局的页面的内容插入点。但是是否可以定义多个插入点,而不是将所有内容都扔到 {{> body }} 所在的位置? 例
我刚开始学习汇编,我没有找到任何有用的内容。 我正在创建一个简单的程序来读取用户输入,基本上: section .bss opA: resw 1 opB: resw 1 section
我目前正在尝试在 bochs 中编译并运行一个简单的引导加载程序。目前,这是我的 bootloader.asm 文件: [BITS 16] [ORG 0x7C00] ;Where the code g
我正在组装一个“simon”游戏,我需要在按钮打开时发出蜂鸣声,蜂鸣声也应该彼此不同。谢谢 最佳答案 您可以使用speaker让您的设计保持简单。 扬声器可让您播放不同频率的方波,it can act
我无法通过任何文档找到问题的答案。 可靠集合通过云的多个节点共享,并且具有名称和持久性。 它们可以通过不同的应用程序共享还是特定于应用程序? 例如,两个不同的 MVC 应用程序对同一帐户托管的可靠字典
嗨,我有一个 SBT 构建文件,用于处理我们组织内的集成测试,测试本身可以工作,我可以单独运行单元和它测试。但是,当使用 sbt-assemble 打包应用程序时,我无法按顺序运行两个测试(unit+
我正在运行一些汇编代码,但我无法弄清楚一行代码的作用。代码是: leaq 0(,%rax,4), %rdx 我知道lea基本上是一种mov指令,但它只移动地址。因此,我们将某些内容的地址移动到%
我是一名优秀的程序员,十分优秀!