Firefly开源社区

12
发表新贴
打印 上一主题 下一主题

[Android] ROC-RK3566安卓RKNN模型例程无法使用,且会导致重启

46

积分

0

威望

0

贡献

技术小白

积分
46

ROC-RK3566安卓RKNN模型例程无法使用,且会导致重启

发表于 2021-8-20 15:40:07      浏览:7074 | 回复:14        打印      只看该作者   [复制链接] 楼主
本帖最后由 zwmasdf 于 2021-8-20 15:45 编辑

如题,安卓RKNN模型无法按照例程跑,主要有以下几个问题
一、rknnrt/examples/rknn_mobilenet_demo下的例程无法编译,按照ReadMe.md的步骤无法完成CMake的编译
       主要修改了:ANDROID_NDK_PATH=......../Android/Sdk,这里不管指向Sdk还是指向Sdk/ndk、21.4.7075529都无法导致编译成功,
       然后尝试修改了19行的cmake为C:/Users/R190095/AppData/Local/Android/Sdk/cmake/3.10.2.4988404/bin/cmake还是无法编译成功,
       提示无法找到....../Android/Sdk/platforms/android-24,然后去Sdk/platforms下找,发现没有android-24的文件夹,至此,放弃该编译方式。
       使用第二种NDK+Cmake编译
二、使用Android Studio新建Native C++工程
       修改app/build.gradle,修改如下:
  1. defaultConfig {
  2.     ......
  3.     externalNativeBuild {
  4.         cmake {
  5.             cppFlags ''
  6.             abiFilters 'armeabi-v7a', "arm64-v8a"
  7.         }
  8.     }

  9.     ndk {
  10.         abiFilters 'armeabi-v7a', "arm64-v8a"
  11.     }
  12. }
复制代码
   然后将rknn相关lib和头文件加到工程中,如图所示
   
    然后修改CMakeList.txt,代码如下:
  1. cmake_minimum_required(VERSION 3.10.2)

  2. project("mytest")

  3. add_library(
  4.         mytest
  5.         SHARED
  6.         native-lib.cpp)

  7. include_directories(${CMAKE_SOURCE_DIR}/include)

  8. add_library(rknn_api_android #这里不管有没有android后缀都一样
  9.         SHARED
  10.         IMPORTED)

  11. set_target_properties(rknn_api_android #这里不管有没有android后缀都一样
  12.         PROPERTIES IMPORTED_LOCATION
  13.         ${CMAKE_SOURCE_DIR}/lib/${ANDROID_ABI}/librknn_api_android.so) #这里不管有没有android后缀都一样

  14. add_library(rknnrt
  15.         SHARED
  16.         IMPORTED)

  17. set_target_properties(rknnrt
  18.         PROPERTIES IMPORTED_LOCATION
  19.         ${CMAKE_SOURCE_DIR}/lib/${ANDROID_ABI}/librknnrt.so)

  20. find_library(
  21.         log-lib
  22.         log)

  23. target_link_libraries(
  24.         mytest

  25.         rknn_api_android  #这里不管有没有android后缀都一样
  26.         rknnrt

  27.         ${log-lib})
复制代码
   接着修改native-lib.cpp代码,内容如下:
   
  1. #include <jni.h>
  2. #include <string>
  3. #include <android/log.h>
  4. #include <pthread.h>

  5. #include "rknn_api.h"

  6. #define TAG "NATIVE_LIB"

  7. #define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, TAG, __VA_ARGS__)

  8. static unsigned char *load_model(const char *filename, int *model_size)
  9. {
  10.     FILE *fp = fopen(filename, "rb");
  11.     if(fp == nullptr) {
  12.         LOGD("fopen %s fail!\n", filename);
  13.         return nullptr;
  14.     }
  15.     fseek(fp, 0, SEEK_END);
  16.     int model_len = ftell(fp);
  17.     unsigned char *model = (unsigned char*)malloc(model_len);
  18.     fseek(fp, 0, SEEK_SET);
  19.     if(model_len != fread(model, 1, model_len, fp)) {
  20.         LOGD("fread %s fail!\n", filename);
  21.         free(model);
  22.         return nullptr;
  23.     }
  24.     *model_size = model_len;
  25.     fclose(fp);
  26.     return model;
  27. }

  28. void* test(void *arg) {
  29.     int model_len = 0;
  30.     unsigned char *model = nullptr;
  31.     rknn_context ctx;
  32.     int ret;

  33.     model = load_model("/vendor/model/mobilenet_v1.rknn", &model_len);
  34.     if(!model) {
  35.         LOGD("load model failed\n");
  36.         return nullptr;
  37.     }
  38.     LOGD("load model ok");
  39.     ret = rknn_init(&ctx, model, model_len, 0, nullptr);
  40.     if(ret < 0) {
  41.         LOGD("rknn_init fail! ret=%d\n", ret);
  42.         return nullptr;
  43.     }
  44.     LOGD("rknn_init ok");
  45.     return nullptr;
  46. }

  47. extern "C" JNIEXPORT jstring JNICALL
  48.         Java_com_example_mytest_MainActivity_stringFromJNI(
  49.     JNIEnv* env,
  50.     jobject /* this */) {
  51.     std::string hello = "Hello from C++";
  52.     LOGD("hello");
  53.     int err;
  54.     pthread_t ntid;
  55.     err = pthread_create(&ntid, nullptr, test, nullptr);
  56.     if (err != 0) {
  57.         LOGD("can't create thread: %s\n", strerror(err));
  58.     }

  59.     return env->NewStringUTF(hello.c_str());
  60. }
复制代码

    然后使用adb root && adb remount激活root(前提是安卓启用开发者并启用root)
    接着把rknn_mobilenet_demo下的model文件夹通过adb push model /vendor/拷贝到开发板内
    接着adb push Android/rknn_server/${BOARD_ARCH}/rknn_server到/vendor/bin目录,这里试了切换不同架构的rknn_server也不行
    然后adb push Android/librknn_api/${BOARD_ARCH}/librknnrt.so到/vendor/lib64(64位系统特有)和/vendor/lib目录,换架构也不行
    然后adb shell进入控制台, 并通过su切换成root, 接下来执行:
           chmod 777 /vendor/bin/rknn_server
           setenforce 0
           /vendor/bin/rknn_server &

    然后编译安卓程序,运行后控制台依次打印hello和load model ok,然后卡住了,app上也没显示Hello from C++
    然后过了几秒钟开发板重启了,尝试切换架构,push不同的文件到开发板,都不行
    后来去/vendor/lib和/vendor/lib64下看librknnrt.so文件属性,发现都是只读的,而且无法删除


以上是尝试调用rknn的过程,但是一直以失败而告终,请求支持

回复

使用道具 举报

1万

积分

18

威望

20

贡献

神级创客

Rank: 8Rank: 8

积分
10850

突出贡献

发表于 2021-8-20 16:29:59        只看该作者  沙发
不建议使用太新的NDK版本,参考脚本的版本android-ndk-r16b
回复

使用道具 举报

46

积分

0

威望

0

贡献

技术小白

积分
46
发表于 2021-8-20 16:37:21        只看该作者  板凳
zyk 发表于 2021-8-20 16:29
不建议使用太新的NDK版本,参考脚本的版本android-ndk-r16b

那问题二重启又是咋回事
回复

使用道具 举报

1万

积分

18

威望

20

贡献

神级创客

Rank: 8Rank: 8

积分
10850

突出贡献

发表于 2021-8-20 17:13:00        只看该作者  地板
固件是什么版本,跑官方demo是否会重启
回复

使用道具 举报

46

积分

0

威望

0

贡献

技术小白

积分
46
发表于 2021-8-20 17:32:29        只看该作者  5#
Firefly版本为:
rk3566_roc_pc/Android11.0/V1.0.2106160927/8849e45f60b4
版本号:
rk3566_roc_pc-userdebug 11 RQ1D.210105.003.eng.lzf.20210616.092756 release-keys
跑官方demo直接失败了,demo从:https://www.t-firefly.com/doc/download/103.html#other_478下载下来的
但是跑官方demo也会重启,步骤如下:
adb root
adb remount
adb push ./rknn_ssd_demo /vendor
adb push ./model /vendor
adb shell
su
setenforce 0
/vendor/bin/rknn_server &
cd /vendor
chmod 777 rknn_ssd_demo
./rknn_ssd_demo ./model/ssd_inception_v2.rknn  ./model/road.bmp
回复

使用道具 举报

1万

积分

18

威望

20

贡献

神级创客

Rank: 8Rank: 8

积分
10850

突出贡献

发表于 2021-8-21 08:57:04        只看该作者  6#
更新到最新的固件试试
回复

使用道具 举报

46

积分

0

威望

0

贡献

技术小白

积分
46
发表于 2021-8-23 08:19:37        只看该作者  7#
zyk 发表于 2021-8-21 08:57
更新到最新的固件试试

ROC-3566的安卓固件百度云提取码有误
回复

使用道具 举报

1万

积分

18

威望

20

贡献

神级创客

Rank: 8Rank: 8

积分
10850

突出贡献

发表于 2021-8-23 09:15:43        只看该作者  8#
提取码可以正常操作,请检查输入是否有误
回复

使用道具 举报

46

积分

0

威望

0

贡献

技术小白

积分
46
发表于 2021-8-23 13:34:55        只看该作者  9#
zyk 发表于 2021-8-23 09:15
提取码可以正常操作,请检查输入是否有误

3566和3568固件通用吗
回复

使用道具 举报

46

积分

0

威望

0

贡献

技术小白

积分
46
发表于 2021-8-23 16:32:59        只看该作者  10#
zyk 发表于 2021-8-23 09:15
提取码可以正常操作,请检查输入是否有误

现在不会重启了,但是rknn_init()返回-7,不知道是什么原因,换rknn模型也不行
回复

使用道具 举报

返回列表
12
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

友情链接 : 爱板网 电子发烧友论坛 云汉电子社区 粤ICP备14022046号-2
快速回复 返回顶部 返回列表