c-Erlang驱动程序错误



我必须写一个Erlang驱动程序,所以我从三个小的开始:driverc.c,代码很简单,driver Erlang Data是一个长数字的地址,每次调用驱动程序都是将这个数字增加n或乘以nn只是一个数字(0,…,9(,作为char传递,代码为:

#include<stdio.h>
#include<stdlib.h>
#include<erl_driver.h>
#include<ei.h>
#include<string.h>
#define SOMME 1
#define PRODUIT 2
static ErlDrvData start(ErlDrvPort port, char *command) ;
static void stop(ErlDrvData data) ;
static ErlDrvSSizeT control(ErlDrvData data, unsigned int command, char *buf, ErlDrvSizeT len, char **rbuf, ErlDrvSizeT rlen);
static long *number;
static ErlDrvEntry myentry={
NULL,
start,
stop,
NULL,
NULL,
NULL,
"driverc",
NULL,
NULL,
control,
NULL,
NULL,
NULL,
NULL,
NULL
};
DRIVER_INIT(driverc)
{return &myentry;}
ErlDrvData start(ErlDrvPort port, char *command)
{number=(long*)driver_alloc(sizeof(long)) ;
*number=0;
set_port_control_flags(port,PORT_CONTROL_FLAG_BINARY);
return (ErlDrvData)number;
}
void stop(ErlDrvData data)
{long *olddata;
olddata=(long*)data;
driver_free(olddata);
}
ErlDrvSSizeT control(ErlDrvData data, insigned int command, char *buf, ErlDrvSizeT len, char **buf, ErlDrvSizeT rlen)
{long    reply, m, *olddata, newdata;
int     index, result, n;
char    c;
c=*buf;
n=c-'0'; /* convert character representation to true integer digit */
m=(long)n;
olddata=(long*)data;
index=0;
switch (command) {
case SOMME : newdata=(*olddata)+m;
*olddata=newdata;
reply=newdata;
break;
case PRODUIT : newdata=(*olddata)*m;
*olddata=newdata;
reply=newdata;
break;
default : reply=-1;
break;
}
result=ei_encode_long(*rbuf,&index,reply) ; /* this function convert a long number (reply) to binary and write it in *rbuf */
return sizeof(reply) ;
} 

当我试图编译它时,它会返回错误,我不知道问题出在哪里,shell输出如下。

cc driverc.c  -I/usr/local/lib/erlang/usr/include
error : undefined symbol : main
referenced by .... 
error : undefined symbol : driver_alloc
referenced by .... 
error : undefined symbol : set_port_control_flags
referenced by .... 
error : undefined symbol : ei_encode_long
referenced by .... 
error : linked command failed with exit code 1 .... 

https://ibb.co/LnTDtmt

从"编译和链接示例驱动程序":

驱动程序将被编译并链接到共享库(Windows上的DLL(。对于gcc,这是通过链路标志-shared-fpic来完成的。当我们使用ei库时,我们也应该包含它。

链接器抱怨找不到main,因为它认为它正在构建一个独立的程序。将其构建为共享库应该可以解决这个问题。

Erlang/OTP存储库中有一个示例Makefile可能很有用,它包含了所有必需的标志。

相关内容

最新更新