Bug 38992

Summary: aarch64: Could NOT find JNI
Product: Sisyphus Reporter: Stanislav Levin <slev>
Component: cmake-modulesAssignee: Vitaly Lipatov <lav>
Status: CLOSED FIXED QA Contact: qa-sisyphus
Severity: critical    
Priority: P5 CC: lav, viy, zerg
Version: unstable   
Hardware: aarch64   
OS: Linux   
Bug Depends on:    
Bug Blocks: 38788    

Description Stanislav Levin 2020-09-25 10:35:43 MSK
При переходе с v3.18.2 на v3.18.3 сломался поиск JNI на aarch64:

```
$ cat CMakeLists.txt
...
find_package(JNI REQUIRED)
```

```
CMake Error at /usr/share/cmake/Modules/FindPackageHandleStandardArgs.cmake:165 (message):
  Could NOT find JNI (missing: JAVA_AWT_LIBRARY JAVA_JVM_LIBRARY)
Call Stack (most recent call first):
  /usr/share/cmake/Modules/FindPackageHandleStandardArgs.cmake:458 (_FPHSA_FAILURE_MESSAGE)
  /usr/share/cmake/Modules/FindJNI.cmake:374 (FIND_PACKAGE_HANDLE_STANDARD_ARGS)
  CMakeLists.txt:53 (find_package)


-- Configuring incomplete, errors occurred!
```

Ошибка связана с "фиксом":
https://gitlab.kitware.com/cmake/cmake/-/commit/65856616d73cd1e963a4b8dcc859efbb1f19ede2

То есть ожидаемая директория теперь `/usr/lib/jvm/jre/lib/arm64` вместо `/usr/lib/jvm/jre/lib/aarch64`.

Самое простое - отревертить это изменение.
Comment 1 Stanislav Levin 2020-09-25 10:42:33 MSK
Или более правильно зайти в астрим с
```diff
- set(_java_libarch "arm64")
+ set(_java_libarch "arm64" "aarch64")
```

Попробую.
Comment 2 Stanislav Levin 2020-09-25 11:46:04 MSK
upstream ticket:
https://gitlab.kitware.com/cmake/cmake/-/issues/21237
Comment 3 Vitaly Lipatov 2020-09-25 13:48:18 MSK
Я посмотрел в Debian, у них
/usr/lib/jvm/java-11-openjdk-arm64/
https://packages.debian.org/buster/arm64/openjdk-11-jdk-headless/filelist

И в Fedora
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.212.b04-0.fc28.x86_64/jre/lib/amd64

У нас из каких-то соображений aarch64:
%ifarch %{aarch64}
%global archinstall aarch64
%endif


Игорь, может вы подскажете про необычный путь? Я бы если не поменял его, то как минимум сделал симлинк, чтобы было больше совместимости с миром.
Comment 4 viy 2020-09-25 14:13:29 MSK
aarch64 у нас по наследству от федоры. Там в java-1.8.0-openjdk так и в rawhide,
и в релизах, как минимум, с fedora 30.
Поэтому в апстрим идти можно ссылаясь и на федору.

можете убедиться, скачав с http://mirror.yandex.ru
/fedora/linux/releases/30/Everything/aarch64/os/Packages/j/java-1.8.0-openjdk-1.8.0.201.b09-6.fc30.aarch64.rpm

 $ rpm -qlp java-1.8.0-openjdk-1.8.0.201.b09-6.fc30.aarch64.rpm
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.201.b09-6.fc30.aarch64/jre/lib/aarch64/libawt_xawt.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.201.b09-6.fc30.aarch64/jre/lib/aarch64/libjawt.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.201.b09-6.fc30.aarch64/jre/lib/aarch64/libjsoundalsa.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.201.b09-6.fc30.aarch64/jre/lib/aarch64/libsplashscreen.so
[...]

/fedora/linux/development/rawhide/Everything/aarch64/os/Packages/j/java-1.8.0-openjdk-1.8.0.272.b08-0.0.ea.fc34.aarch64.rpm
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.272.b08-0.0.ea.fc34.aarch64/jre/lib/aarch64/libawt_xawt.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.272.b08-0.0.ea.fc34.aarch64/jre/lib/aarch64/libjawt.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.272.b08-0.0.ea.fc34.aarch64/jre/lib/aarch64/libjsoundalsa.so
/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.272.b08-0.0.ea.fc34.aarch64/jre/lib/aarch64/libsplashscreen.so
[...]
Comment 5 Repository Robot 2020-09-26 00:46:56 MSK
cmake-3.18.3-alt2 -> sisyphus:

 Sat Sep 26 2020 Vitaly Lipatov <lav@altlinux.ru> 3.18.3-alt2
 - add aarch64 dir support in FindJNI.cmake (ALT bug 38992)