Android: невозможно загрузить системную библиотеку

Я работаю над проприетарным приложением для Android-боксов, которое читает вход HDMI и отображает его на части экрана. Для этого мы используем R9 Mini Android TV box ( ссылка). Поставщик предоставил исходный код примера приложения для чтения входа HDMI, но приложению не удалось запустить всплывающее окно с сообщением об ошибке (к сожалению, SourceIn прекратил работу).

Ниже приведена трассировка стека исключений:

02-28 15:38:36.988 3232-3232/rtk.com.RealtekSourceIn W/art: Method processed more than once: void android.app.Instrumentation.callActivityOnResume(android.app.Activity)
02-28 15:38:37.090 3232-3232/rtk.com.RealtekSourceIn A/art: art/runtime/barrier.cc:90] Check failed: count_ == 0 (count_=-1, 0=0) Attempted to destroy barrier with non zero count
02-28 15:38:37.090 3232-3232/rtk.com.RealtekSourceIn A/art: art/runtime/runtime.cc:366] Runtime aborting --- recursively, so no thread-specific detail!
02-28 15:38:37.090 3232-3232/rtk.com.RealtekSourceIn A/art: art/runtime/runtime.cc:366] 
02-28 15:38:37.090 3232-3232/rtk.com.RealtekSourceIn A/libc: Fatal signal 6 (SIGABRT), code -6 in tid 3232 (RealtekSourceIn)

Сбой инициируется из кода в зависимости библиотеки. При отладке декомпилированного файла.class. Ниже приведен код, в котором выдается вышеупомянутая ошибка:

static {
    System.loadLibrary("realtek_runtime");
}

Я видел файлы.so в папке /system/lib/ и нашел librealtek_runtime.so присутствовать, поэтому я не могу понять, почему loadLibrary не работает.

Ниже приведен соответствующий код:

RTKSourceInActivity:

public class RTKSourceInActivity extends Activity {

    private String TAG="HDMIRxActivity";
    private ViewGroup m_Root;
    private HDMIRxPlayer m_HDMIRxPlayer = null;
    private final Handler mHandler = new Handler();
    private byte[] mCapture;
    private static final long SCREENSHOT_SLOT = 200;
    private boolean mIsFullScreen = true;

    private File mRecordFile;
    private boolean mRecordOn = false;

    @Override
    public void onResume() {
        Log.d(TAG,"onResume");
        super.onResume();
        if(hasRtkMusicPlaybackService()) {
            Intent i = new Intent("com.android.music.musicservicecommand");
            i.putExtra("command", "stop");
            sendBroadcast(i);
        }
        m_Root = (ViewGroup) findViewById(R.id.root);
        m_HDMIRxPlayer = new HDMIRxPlayer(this, m_Root, 1920, 1080);
    }

...
}

HDMIRxPlayer:

public HDMIRxPlayer(Context context, ViewGroup parent, int width, int height)
{
    mContext = context;
    mSurfaceView = new SurfaceView(context);
    mSurfaceHolder = mSurfaceView.getHolder();
    mSurfaceHolder.addCallback(HDMIRXCallback);
    mSurfaceHolder.setFixedSize(width, height);
    parent.addView(mSurfaceView);

    mHDMIRX = new RtkHDMIRxManager(); // Exception here 

    IntentFilter hdmiRxFilter = new IntentFilter(HDMIRxStatus.ACTION_HDMIRX_PLUGGED);
    mContext.registerReceiver(hdmiRxHotPlugReceiver, hdmiRxFilter);
}

RtkHDMIRxManager класс.car внутри jar зависимостей (realtek-classes), предоставленных поставщиком.

Когда я поместил точки отладки в декомпилированную версию RtkHDMIRxManagerЯ нашел исключение в:

static {
    System.loadLibrary("realtek_runtime");
}

Любое направление, указывающее на решение, было бы очень полезно.

1 ответ

Решение

2 способа решения:

  1. Я должен был использовать android:sharedUserId="android.uid.system" и подписать приложение с соответствующим pem а также pk8 файлы.

  2. Установите приложение, используйте команды adb для перемещения приложения в каталог /system/. Не это системное приложение. Вы можете поделиться всеми системными ресурсами сейчас.

Другие вопросы по тегам