jnr-ffi Отображение на C Libray Сбои при вызове функции c - PullRequest
0 голосов
/ 14 октября 2018

У меня есть база данных значений ключей, которая написана на C со следующими функциями для установки и получения значений.

typedef uint64_t ARK;
#define ARC ARK

int ark_set(ARK *ark, uint64_t klen, void *key, uint64_t vlen, void *val, int64_t *rval)

int ark_get(ARK *ark, uint64_t klen, void *key, uint64_t vbuflen, 
            void *vbuf, uint64_t voff, int64_t *res);

и некоторыми другими функциями для создания байтов ARK, подсчета, распределения и использования.Однако они работают, как и ожидалось, всякий раз, когда я пытаюсь установить или получить значение, сбой JVM.

Вот мой интерфейс JNR

public interface ARKInterface {
    int ark_create(String file, @u_int64_t Pointer ark, long flags);

    int ark_count(@u_int64_t Pointer ark, @Out NumberByReference count);

    int ark_set(@u_int64_t Pointer ark, @u_int64_t NativeLong klen, Pointer key, 
       @u_int64_t NativeLong vlen, Pointer val, @Out NumberByReference res);

   int ark_get(@u_int64_t Pointer ark, long klen, Pointer key, long vbuflen, 
       Pointer vbuf, long voff, @Out NumberByReference res);
}

И вот что я пытаюсь установить значение

public static void main(String[] args) {
        ARKInterface libc = LibraryLoader.create(ARKInterface.class).load("arkdb-0");

        Pointer ark = Memory.allocateDirect(Runtime.getRuntime(libc), TypeAlias.u_int64_t);
        int _create = libc.ark_create(null, ark, 1);

        System.out.println("ARK Creation return " + _create);
        System.out.println(ark.toString());

        NumberByReference count = new NumberByReference(TypeAlias.int64_t);
        int _count = libc.ark_count(ark, count);

        System.out.println("Count method return value " + _count);

        System.out.println("Total Count is " + count.longValue());

        byte[] _key = "key".getBytes();
        byte[] _value = "value".getBytes();


        Pointer kp = Memory.allocateDirect(Runtime.getRuntime(libc), _key.length);
        kp.put(0, _key, 0, _key.length);

        Pointer vp = Memory.allocateDirect(Runtime.getRuntime(libc), _value.length);
        vp.put(0, _value, 0, _value.length);

        int set_result = libc.ark_set(ark, new NativeLong(_key.length), kp, new NativeLong(_value.length), vp, count);
        System.out.println("ARK Sets and the result is - " + set_result);
}

После запуска фляги я получаю фатальную ошибку, в coredumps ничего не происходит.

ARK Creation return 0
jnr.ffi.provider.BoundedMemoryIO[address=0x7f12e8026000 size=8]
Count method return value 0
Total Count is 0
#
# A fatal error has been detected by the Java Runtime Environment:
#
#  SIGFPE (0x8) at pc=0x00007f12b1886133, pid=83423, tid=0x00007f12ec663700
#
# JRE version: OpenJDK Runtime Environment (8.0_181-b13) (build 1.8.0_181-b13)
# Java VM: OpenJDK 64-Bit Server VM (25.181-b13 mixed mode linux-amd64 compressed oops)
# Problematic frame:
# C  [libarkdb-0.so+0x23133]  ark_enq_cmd+0x533
#
# Core dump written. Default location: /tmp/capi/core or core.83423
#
# An error report file with more information is saved as:
# /tmp/capi/hs_err_pid83423.log
#
# If you would like to submit a bug report, please visit:
#   http://bugreport.java.com/bugreport/crash.jsp
# The crash happened outside the Java Virtual Machine in native code.
# See problematic frame for where to report the bug.
#
Aborted (core dumped)

Что-то не так связано с отображением или передачей значений.

...