创龙瑞芯微RK3568交叉编译(c和驱动module)

发布时间 2023-10-20 17:45:04作者: imxiangzi

前言
由于项目需要,接触多个公司的RK3568,正点原子的,创龙的,迅为的。最后选择了创龙的。做了一段时间,发现给的教程和其他参考资料很少。所以必须一点一点得自己试验。以后的文章页会一点一点的写。希望给需要的小伙伴带个路。

资料中
大部分功能在用户资料里面有,小伙伴一步步可以跟着做,仅仅说一般工程需要的。

(1)灯

灯的底层配置已经在设备树中配好了,直接echo就行!

注:开发板的灯在边边上。开始的时候怎么点都不亮,最后才发现灯在边边上,半天没找到。

(2)GPIO

开发板没有直接引出GPIO,引出的都复用其他功能了,这个有点没办法。

注:在class的gpio里面直接export就行,用到了就会busy,用不到就能export。

(3)串口

串口都搞成485和232了,没有TTL电平的。

注:485口是有+和-的,利用485转232或者TTL的时候别接错了。

(4)can

直接根据资料中就可以发送。

注:地址最大只能FFF,多了就没办法了。

测试
(1)编译.c文件gcc

aarch64-buildroot-linux-gnu-gcc
搜寻里面的gcc,有很多个,但是需要用的是这个,后面加上自己的文件名就行。为了方便,直接给个例程:

aarch64-buildroot-linux-gnu-gcc hello.c -o hello
前面hello.c是自己的c文件,注意名字必须全对。虽然编译的是c文件,但是文件名后面最好有后缀。后面的hello是自己输出的名字,这个就随便了。

注:c文件里面头自己添加了线程,交叉编译的时候并不用添加-lthread这个指令。

下面给出具体具体函数:

#include <pthread.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include "fcntl.h"
#include <string.h>
#include <net/if.h>
#include <sys/socket.h>
#include <linux/can.h>
#include <linux/can/raw.h>

#include "sys/ioctl.h"

int count = 0;
void *thread_fun(void *arg)
{
while(1)
{
printf("led_running\n");
count++;
if(count == 1)
{
system("echo 1 > /sys/class/leds/user-led0/brightness");
system("echo 0 > /sys/class/leds/user-led1/brightness");
}
if(count == 2)
{
system("echo 0 > /sys/class/leds/user-led0/brightness");
system("echo 1 > /sys/class/leds/user-led1/brightness");
}
if(count == 2)count = 0;
sleep(1);
}
}

int main()
{
pthread_t tid;
if (pthread_create(&tid, NULL, thread_fun, (void *)(&tid)) != 0)
{
perror("pthread_led_create error");
exit(1);
}
else
{
printf("led thread open correct\n");
}
pthread_join(tid,NULL);
}

这个就是点灯函数,由于gpio没有办法引出来,所以只能用系统函数凑合。如果是真正的gpio,还需要在开始的时候export,这个是没办法的。

(2)编译驱动ko文件

网上查询了好多,结果都不能用,都没办法编译出ko文件,不是这错就是那错。最后才给弄出来。

先来主函数myhello.c:

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>

static int __init hello_init(void)
{
printk(KERN_INFO "%s : enter\n", __func__);
return 0;
}

static void __exit hello_exit(void)
{
printk(KERN_INFO "%s : enter\n", __func__);
}

module_init(hello_init);
module_exit(hello_exit);

MODULE_AUTHOR("wang");
MODULE_DESCRIPTION("hello");
MODULE_LICENSE("GPL");
这个是最简单的驱动函数,网上的教程很多,这个就不多说了。

下面是make文件

注:记住名字一定得是Makefile,其他的不行;

注:里面的一定要自己敲,分清楚Tab和空格,切记。要不编译不过去。具体可以看看makefile怎么编写的,有现成的也不能直接用,复制过去的格式已经变了。

MVTOOL_PREFIX = /home/wang/RK3568/rk356x_linux_release_v1.3.1_20221120/buildroot/output/rockchip_rk3568/host/bin/aarch64-buildroot-linux-gnu-gcc
CROSS_COMPILE= $(MVTOOL_PREFIX)
KDIR := /home/wang/RK3568/rk356x_linux_release_v1.3.1_20221120/kernel


TARGET =myhello
EXEC = $(TARGET)
obj-m :=$(TARGET).o
PWD :=$(shell pwd)
all:
$(MAKE) -C $(KDIR) M=$(PWD) modules
clean:
rm -rf *.o *~core.depend.*.cmd *.ko *.mod.c .tmp_versions $(TARGET)
其中:

MVTOOL_PREFIX:gcc的位置,这个搞了很久,还用另一个gcc的,也能编译过去,但是不敢保证最后是对的。aarch64-none-linux-gnu-gcc,并且位置不一样。

注:存放位置一定要自己改写,从rk356x_linux_release_v1.3.1_20221120之后是一定的,前面的需要改到自己的位置。

KDIR:内核的位置。这个和上面一样,前面的位置不一样,必须添加/kernel,如果不添加会报错。

TARGET:你的文件名字。

注:你的文件是xxx.c,这个是去掉.c之后的名字。中间生成有其他文件,名字也是这个,但是后缀不一样。所以必须这个地方必须是你文件的名字,不加后缀。

下面是编译指令:

make ARCH=arm64
注:这里后面的架构名称必须加上。这个地方卡了很久。其他平台上我都试验了,龙芯上,A40i上,正点原子的其他开发板上都试验了,都没啥问题。仅仅在这里出现一大堆错误。原来这个地方需要加上后面。记住直接make是不行的。

结语
Linux的文件就这样,坑非常多,一点注意不到就不行了。后面会一点点的给大家写创龙的瑞芯微RK3568的知识。如果需要经常关注的小伙伴可以关注公众号,具体的翻看前面的文章,里面有具体的二维码。
————————————————
版权声明:本文为CSDN博主「翱翔的灿烂」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_45426095/article/details/133905671