mirror of
https://github.com/Cateners/tiny_computer.git
synced 2026-05-20 16:35:47 +08:00
Fix links, update packages, update hangover, update readme, update avnc...... update code to v1.1.0
This commit is contained in:
@@ -181,6 +181,16 @@ tmoe还会安装gnome-keyring,由于之前我做xfce包时会造成VSCode反
|
||||
|
||||
### 额外步骤
|
||||
|
||||
- 升级到Debian 13(xfce, lxqt,v1.1.0):
|
||||
- 更换内存分配器([原因](https://github.com/termux/proot/issues/313)。不过截至目前这个bug可能已经被修了,虽然issue没关)安装libtcmalloc-minimal4包,并设置库/usr/lib/aarch64-linux-gnu/libtcmalloc_minimal.so.4到/etc/ld.so.preload
|
||||
- 把/etc/apt/source.list的bookworm改为trixie
|
||||
- sudo apt update, sudo apt full-upgrade, sudo apt autoremove
|
||||
- 取消内存分配器的更改
|
||||
- xfce版本重新修补了libtiff.so.5库
|
||||
- 升级到GXDE 25:
|
||||
- 更换内存分配器
|
||||
- 使用AI重写的升级脚本(gxde-25-upgrade.sh),以便在不启动图形界面的情况下升级
|
||||
- 禁用MIT-SHM扩展(v1.1.0):/usr/local/bin/startvnc第372行添加set "${a}" "-extension" "MIT-SHM"
|
||||
- 将桌面壁纸的配置从monitorBuiltinDisplay改为monitorbuiltin(xfce,v1.0.99),疑似Termux:X11显示器名称改变导致壁纸失效
|
||||
- 修复用vscode打开文件时只打开了vscode本身(v1.0.25):去掉/usr/share/applications/code-no-sandbox.desktop的Exec的--unity-launch
|
||||
- 修复选择文本时会把文本发送到剪切板(v1.0.25):在/usr/local/bin/startvnc文件的start_tmoe_xvnc()的start_win10_tigervnc行前面加入`vncconfig -set SendPrimary=0 SetPrimary=0`
|
||||
|
||||
@@ -19,10 +19,12 @@ fi
|
||||
|
||||
echo "最新版本: $latest_version"
|
||||
|
||||
hangover_url="https://github.com/AndreRH/hangover/releases/download/hangover-${latest_version}/hangover_${latest_version}_debian12_bookworm_arm64.tar"
|
||||
hangover_url="https://github.com/AndreRH/hangover/releases/download/hangover-${latest_version}/hangover_${latest_version}_debian13_trixie_arm64.tar"
|
||||
|
||||
mirror_sites=(
|
||||
"https://github.akams.cn/"
|
||||
"https://gh-proxy.org/"
|
||||
"https://cdn.gh-proxy.org/"
|
||||
"https://edgeone.gh-proxy.org/"
|
||||
"https://gh.llkk.cc/"
|
||||
"https://github.moeyy.xyz/"
|
||||
"https://mirror.ghproxy.com/"
|
||||
|
||||
@@ -4,11 +4,13 @@ echo "正在更新软件包..."
|
||||
sudo apt update
|
||||
sudo apt upgrade -y
|
||||
|
||||
hangover_url="https://github.com/AndreRH/hangover/releases/download/hangover-10.14/hangover_10.14_debian12_bookworm_arm64.tar"
|
||||
latest_version="10.14"
|
||||
hangover_url="https://github.com/AndreRH/hangover/releases/download/hangover-11.0/hangover_11.0_debian13_trixie_arm64.tar"
|
||||
latest_version="11.0"
|
||||
|
||||
mirror_sites=(
|
||||
"https://github.akams.cn/"
|
||||
"https://gh-proxy.org/"
|
||||
"https://cdn.gh-proxy.org/"
|
||||
"https://edgeone.gh-proxy.org/"
|
||||
"https://gh.llkk.cc/"
|
||||
"https://github.moeyy.xyz/"
|
||||
"https://mirror.ghproxy.com/"
|
||||
|
||||
146
extra/gxde-25-upgrade.sh
Normal file
146
extra/gxde-25-upgrade.sh
Normal file
@@ -0,0 +1,146 @@
|
||||
#!/bin/bash
|
||||
|
||||
# 定义颜色以便于阅读
|
||||
RED='\033[0;31m'
|
||||
GREEN='\033[0;32m'
|
||||
YELLOW='\033[1;33m'
|
||||
NC='\033[0m' # No Color
|
||||
|
||||
echo -e "${GREEN}=== GXDE OS 15 -> 25 命令行升级工具 ===${NC}"
|
||||
|
||||
# 1. 检查 root 权限
|
||||
if [ "$(id -u)" -ne 0 ]; then
|
||||
echo -e "${RED}错误: 请使用 root 权限运行此脚本 (例如: sudo $0)${NC}"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 2. 风险确认 (替代 Zenity)
|
||||
echo -e "${YELLOW}警告:您即将执行 GXDE OS 15 到 25 的升级${NC}"
|
||||
echo "• 该操作不可逆且存在风险"
|
||||
echo "• 请确保系统已经更新到最新"
|
||||
echo "• 请确保已做好数据备份"
|
||||
echo "• 升级过程可能需要 1-3 小时,期间请勿关闭终端"
|
||||
echo ""
|
||||
read -p "您确定要继续吗?(输入 yes 继续,其他键取消): " confirm
|
||||
if [ "$confirm" != "yes" ]; then
|
||||
echo "操作已取消。"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
echo -e "${YELLOW}再次确认:这是一个高风险操作!!!${NC}"
|
||||
read -p "请输入 'I AGREE' (大写) 以确认并开始升级: " confirm_final
|
||||
if [ "$confirm_final" != "I AGREE" ]; then
|
||||
echo "操作已取消。"
|
||||
exit 0
|
||||
fi
|
||||
|
||||
echo -e "${GREEN}>>> 开始预处理...${NC}"
|
||||
|
||||
# 刷新缓存与修复依赖
|
||||
echo "正在刷新系统包缓存..."
|
||||
apt update
|
||||
aptss update
|
||||
export DEBIAN_FRONTEND=noninteractive
|
||||
echo "正在检查和修复系统依赖问题..."
|
||||
aptss install -f -yqq
|
||||
|
||||
# 删除冲突包
|
||||
echo "正在移除 qtbase5-dev..."
|
||||
apt autopurge qtbase5-dev -y
|
||||
|
||||
# 3. 替换软件源 (核心逻辑)
|
||||
echo "正在替换软件源..."
|
||||
# 备份并替换主源
|
||||
sed -i 's/bookworm/trixie/g' /etc/apt/sources.list
|
||||
|
||||
# 处理 PPA 源
|
||||
declare -A ppa_map=(
|
||||
["/etc/apt/sources.list.d/gxde.list"]='s/bixie/lizhi/g'
|
||||
["/etc/apt/sources.list.d/gxde-testing.list"]='s/tianlu/zhuangzhuang/g'
|
||||
)
|
||||
rm -vf /etc/apt/sources.list.d/gxde-bpo.list
|
||||
|
||||
for file in "${!ppa_map[@]}"; do
|
||||
if [[ -f "$file" ]]; then
|
||||
sed -i "${ppa_map[$file]}" "$file"
|
||||
echo "已更新源文件: $file"
|
||||
else
|
||||
[[ "$file" =~ testing ]] && continue
|
||||
echo -e "${RED}严重错误:关键源文件缺失 $file${NC}"
|
||||
exit 1
|
||||
fi
|
||||
done
|
||||
|
||||
# 屏蔽旧的更新器
|
||||
echo "正在屏蔽旧版更新器..."
|
||||
rm -fv /usr/bin/gxde-app-upgrader
|
||||
cat > /usr/bin/gxde-app-upgrader << EOF
|
||||
#!/bin/bash
|
||||
echo "警告:检测到您尚未完成系统大版本更新,请完成 CLI 更新流程!"
|
||||
EOF
|
||||
chmod +x /usr/bin/gxde-app-upgrader
|
||||
|
||||
# 刷新新源
|
||||
echo "正在刷新新源缓存..."
|
||||
apt update
|
||||
aptss update
|
||||
yes n | aptss install gxde-25-upgrader -yqq
|
||||
|
||||
echo -e "${GREEN}>>> 预处理完成,准备开始核心升级...${NC}"
|
||||
echo -e "${YELLOW}注意:接下来的过程请保持网络畅通,不要中断脚本运行。${NC}"
|
||||
sleep 3
|
||||
|
||||
# 4. 执行核心升级逻辑 (原 gxde-post-upgrade-fix 内容)
|
||||
|
||||
# 检查当前桌面环境状态
|
||||
ANDROID_INSTALLED=0
|
||||
DESKTOP_MISSING=0
|
||||
dpkg -s gxde-desktop-android &>/dev/null && ANDROID_INSTALLED=1
|
||||
dpkg -s gxde-desktop &>/dev/null || DESKTOP_MISSING=1
|
||||
|
||||
# 确定要安装的桌面包
|
||||
DESKTOP_PKG="gxde-desktop"
|
||||
if [ "$ANDROID_INSTALLED" -eq 1 ] && [ "$DESKTOP_MISSING" -eq 1 ]; then
|
||||
DESKTOP_PKG="gxde-desktop-android"
|
||||
echo "检测到 Android 环境,将安装: $DESKTOP_PKG"
|
||||
else
|
||||
echo "将在升级后安装: $DESKTOP_PKG"
|
||||
fi
|
||||
|
||||
# 执行 Full Upgrade
|
||||
echo -e "${GREEN}>>> 正在执行系统全面升级 (Full Upgrade)...这可能需要很长时间${NC}"
|
||||
yes n | env DEBIAN_FRONTEND=noninteractive aptss full-upgrade \
|
||||
-o DPkg::options::="--force-confdef" \
|
||||
-o DPkg::options::="--force-confold" \
|
||||
-o DPkg::options::="--force-overwrite" \
|
||||
-yqq --assume-yes
|
||||
|
||||
# 处理 grub 配置问题 (Hack)
|
||||
echo "正在处理 GRUB 配置..."
|
||||
if [ -f /var/lib/dpkg/info/grub-pc.postinst ]; then
|
||||
mv -v /var/lib/dpkg/info/grub-pc.postinst /var/lib/dpkg/info/grub-pc.postinst.bak
|
||||
dpkg --configure -a
|
||||
mv -v /var/lib/dpkg/info/grub-pc.postinst.bak /var/lib/dpkg/info/grub-pc.postinst
|
||||
else
|
||||
dpkg --configure -a
|
||||
fi
|
||||
|
||||
# 安装/更新核心软件包
|
||||
echo -e "${GREEN}>>> 正在安装/重装核心组件...${NC}"
|
||||
yes n | env DEBIAN_FRONTEND=noninteractive aptss install gxde-app-upgrader --reinstall -yqq
|
||||
|
||||
if yes n | env DEBIAN_FRONTEND=noninteractive aptss install $DESKTOP_PKG deepin-kwin-x11 libdtkcore-dev deepin-desktop-base spark-store gxde-control-center --reinstall -yqq; then
|
||||
|
||||
# 启用服务
|
||||
systemctl enable dde-filemanager-daemon.service || true
|
||||
|
||||
echo -e "${GREEN}-----------------------${NC}"
|
||||
echo -e "${GREEN}升级成功完成!${NC}"
|
||||
echo -e "${YELLOW}请按回车键重启您的计算机,或者按 Ctrl+C 稍后手动重启。${NC}"
|
||||
read
|
||||
reboot
|
||||
else
|
||||
echo -e "${RED}!!!!!! 升级过程中出现错误 !!!!!!${NC}"
|
||||
echo "请保留此终端输出,并反馈给 QQ 群 881201853"
|
||||
exit 1
|
||||
fi
|
||||
@@ -41,6 +41,10 @@ Turnip驱动。根据[这里](https://github.com/xDoge26/proot-setup/issues/26#i
|
||||
|
||||
快捷指令的彩蛋。原本放在容器里,但显然放这里更为合适
|
||||
|
||||
#### extra/tiny_virtual_mic
|
||||
|
||||
麦克风客户端。实现见tiny_virtual_mic.c
|
||||
|
||||
#### caj, edraw
|
||||
|
||||
这些分别是cajviewer,亿图图示的补丁
|
||||
|
||||
363
extra/turnip.patch
Normal file
363
extra/turnip.patch
Normal file
@@ -0,0 +1,363 @@
|
||||
diff --git a/src/freedreno/vulkan/tu_shader.cc b/src/freedreno/vulkan/tu_shader.cc
|
||||
index edc0ce1f6fe..e5b8e9bc44d 100644
|
||||
--- a/src/freedreno/vulkan/tu_shader.cc
|
||||
+++ b/src/freedreno/vulkan/tu_shader.cc
|
||||
@@ -2556,10 +2556,10 @@ tu_upload_shader(struct tu_device *dev,
|
||||
size += vpc_size;
|
||||
}
|
||||
|
||||
- pthread_mutex_lock(&dev->pipeline_mutex);
|
||||
+ mtx_lock(&dev->pipeline_mutex);
|
||||
VkResult result = tu_suballoc_bo_alloc(&shader->bo, &dev->pipeline_suballoc,
|
||||
size * 4, 128);
|
||||
- pthread_mutex_unlock(&dev->pipeline_mutex);
|
||||
+ mtx_unlock(&dev->pipeline_mutex);
|
||||
|
||||
if (result != VK_SUCCESS)
|
||||
return result;
|
||||
@@ -2589,9 +2589,9 @@ tu_upload_shader(struct tu_device *dev,
|
||||
|
||||
result = tu_setup_pvtmem(dev, shader, &pvtmem_config, pvtmem_size, per_wave);
|
||||
if (result != VK_SUCCESS) {
|
||||
- pthread_mutex_lock(&dev->pipeline_mutex);
|
||||
+ mtx_lock(&dev->pipeline_mutex);
|
||||
tu_suballoc_bo_free(&dev->pipeline_suballoc, &shader->bo);
|
||||
- pthread_mutex_unlock(&dev->pipeline_mutex);
|
||||
+ mtx_unlock(&dev->pipeline_mutex);
|
||||
return result;
|
||||
}
|
||||
|
||||
@@ -3427,10 +3427,10 @@ tu_empty_shader_create(struct tu_device *dev,
|
||||
if (!shader)
|
||||
return VK_ERROR_OUT_OF_HOST_MEMORY;
|
||||
|
||||
- pthread_mutex_lock(&dev->pipeline_mutex);
|
||||
+ mtx_lock(&dev->pipeline_mutex);
|
||||
VkResult result = tu_suballoc_bo_alloc(&shader->bo, &dev->pipeline_suballoc,
|
||||
32 * 4, 128);
|
||||
- pthread_mutex_unlock(&dev->pipeline_mutex);
|
||||
+ mtx_unlock(&dev->pipeline_mutex);
|
||||
|
||||
if (result != VK_SUCCESS) {
|
||||
vk_free(&dev->vk.alloc, shader);
|
||||
@@ -3541,9 +3541,9 @@ tu_shader_destroy(struct tu_device *dev,
|
||||
tu_cs_finish(&shader->cs);
|
||||
TU_RMV(resource_destroy, dev, &shader->bo);
|
||||
|
||||
- pthread_mutex_lock(&dev->pipeline_mutex);
|
||||
+ mtx_lock(&dev->pipeline_mutex);
|
||||
tu_suballoc_bo_free(&dev->pipeline_suballoc, &shader->bo);
|
||||
- pthread_mutex_unlock(&dev->pipeline_mutex);
|
||||
+ mtx_unlock(&dev->pipeline_mutex);
|
||||
|
||||
if (shader->pvtmem_bo)
|
||||
tu_bo_finish(dev, shader->pvtmem_bo);
|
||||
diff --git a/src/freedreno/vulkan/tu_wsi.cc b/src/freedreno/vulkan/tu_wsi.cc
|
||||
index 57cf9048b07..246a95dd894 100644
|
||||
--- a/src/freedreno/vulkan/tu_wsi.cc
|
||||
+++ b/src/freedreno/vulkan/tu_wsi.cc
|
||||
@@ -47,6 +47,10 @@ tu_wsi_init(struct tu_physical_device *physical_device)
|
||||
&options);
|
||||
if (result != VK_SUCCESS)
|
||||
return result;
|
||||
+
|
||||
+ if (strcmp(physical_device->instance->knl->name, "kgsl") == 0) {
|
||||
+ physical_device->wsi_device.is_tu_kgsl = true;
|
||||
+ }
|
||||
|
||||
physical_device->wsi_device.supports_modifiers = true;
|
||||
physical_device->wsi_device.can_present_on_device =
|
||||
diff --git a/src/util/anon_file.c b/src/util/anon_file.c
|
||||
index a9ad2a2aad8..f5dcd5b3b48 100644
|
||||
--- a/src/util/anon_file.c
|
||||
+++ b/src/util/anon_file.c
|
||||
@@ -117,6 +117,11 @@ get_or_create_user_temp_dir(char* buf, size_t len) {
|
||||
int uid = getuid();
|
||||
|
||||
env = os_get_option("XDG_RUNTIME_DIR");
|
||||
+#ifdef __linux__
|
||||
+ if (!env) {
|
||||
+ env = "/tmp";
|
||||
+ }
|
||||
+#endif
|
||||
if (env && env[0] != '\0') {
|
||||
snprintf(buf, len, "%s", env);
|
||||
return buf;
|
||||
diff --git a/src/util/u_process.c b/src/util/u_process.c
|
||||
index 6846acd2e0b..8551c227b88 100644
|
||||
--- a/src/util/u_process.c
|
||||
+++ b/src/util/u_process.c
|
||||
@@ -101,7 +101,7 @@ __getProgramName()
|
||||
{
|
||||
return strdup(program_invocation_short_name);
|
||||
}
|
||||
-#elif defined(__FreeBSD__) || defined(__DragonFly__) || defined(__APPLE__) || DETECT_OS_ANDROID || defined(__NetBSD__)
|
||||
+#elif defined(__FreeBSD__) || defined(__DragonFly__) || defined(__APPLE__) || DETECT_OS_ANDROID || defined(__NetBSD__) || defined(__linux__)
|
||||
#if defined(__NetBSD__)
|
||||
# include <sys/param.h>
|
||||
#endif
|
||||
diff --git a/src/vulkan/wsi/wsi_common.c b/src/vulkan/wsi/wsi_common.c
|
||||
index 6783fbd6efb..3a81c200c2a 100644
|
||||
--- a/src/vulkan/wsi/wsi_common.c
|
||||
+++ b/src/vulkan/wsi/wsi_common.c
|
||||
@@ -2491,7 +2491,7 @@ wsi_common_queue_present(const struct wsi_device *wsi,
|
||||
#endif
|
||||
}
|
||||
|
||||
- if (wsi->sw) {
|
||||
+ if (wsi->sw || (wsi->is_tu_kgsl && (swapchain->dma_buf_semaphore == VK_NULL_HANDLE))) {
|
||||
wsi->WaitForFences(vk_device_to_handle(dev),
|
||||
1, &swapchain->fences[image_index], true, ~0ull);
|
||||
}
|
||||
@@ -3217,7 +3217,7 @@ wsi_configure_cpu_image(const struct wsi_swapchain *chain,
|
||||
const struct wsi_cpu_image_params *params,
|
||||
struct wsi_image_info *info)
|
||||
{
|
||||
- assert(params->base.image_type == WSI_IMAGE_TYPE_CPU);
|
||||
+ // assert(params->base.image_type == WSI_IMAGE_TYPE_CPU);
|
||||
assert(chain->blit.type == WSI_SWAPCHAIN_NO_BLIT ||
|
||||
chain->blit.type == WSI_SWAPCHAIN_BUFFER_BLIT);
|
||||
|
||||
diff --git a/src/vulkan/wsi/wsi_common.h b/src/vulkan/wsi/wsi_common.h
|
||||
index c17a79c6b13..20c480babbc 100644
|
||||
--- a/src/vulkan/wsi/wsi_common.h
|
||||
+++ b/src/vulkan/wsi/wsi_common.h
|
||||
@@ -152,6 +152,7 @@ struct wsi_device {
|
||||
|
||||
|
||||
bool sw;
|
||||
+ bool is_tu_kgsl;
|
||||
|
||||
/* Set to true if the implementation is ok with linear WSI images. */
|
||||
bool wants_linear;
|
||||
diff --git a/src/vulkan/wsi/wsi_common_display.c b/src/vulkan/wsi/wsi_common_display.c
|
||||
index f72e85c5e66..ac83c92236a 100644
|
||||
--- a/src/vulkan/wsi/wsi_common_display.c
|
||||
+++ b/src/vulkan/wsi/wsi_common_display.c
|
||||
@@ -516,6 +516,12 @@ struct wsi_display_sync {
|
||||
|
||||
static uint64_t fence_sequence;
|
||||
|
||||
+#ifdef __linux__
|
||||
+static void thread_signal_handler (int signum) {
|
||||
+ pthread_exit (0);
|
||||
+}
|
||||
+#endif
|
||||
+
|
||||
static void
|
||||
_wsi_display_cleanup_state(struct wsi_display_swapchain *chain);
|
||||
|
||||
@@ -2024,7 +2030,9 @@ wsi_display_wait_thread(void *data)
|
||||
.events = POLLIN
|
||||
};
|
||||
|
||||
+#ifndef __linux__
|
||||
pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL);
|
||||
+#endif
|
||||
for (;;) {
|
||||
int ret = poll(&pollfd, 1, -1);
|
||||
if (ret > 0) {
|
||||
@@ -2052,9 +2060,21 @@ wsi_display_start_wait_thread(struct wsi_display *wsi)
|
||||
static void
|
||||
wsi_display_stop_wait_thread(struct wsi_display *wsi)
|
||||
{
|
||||
+#ifdef __linux__
|
||||
+ struct sigaction actions;
|
||||
+ memset (&actions, 0, sizeof (actions));
|
||||
+ sigemptyset (&actions.sa_mask);
|
||||
+ actions.sa_flags = 0;
|
||||
+ actions.sa_handler = thread_signal_handler;
|
||||
+ sigaction (SIGUSR2, &actions, NULL);
|
||||
+#endif
|
||||
mtx_lock(&wsi->wait_mutex);
|
||||
if (wsi->wait_thread) {
|
||||
+#ifndef __linux__
|
||||
pthread_cancel(wsi->wait_thread);
|
||||
+#else
|
||||
+ pthread_kill(wsi->wait_thread, SIGUSR2);
|
||||
+#endif
|
||||
pthread_join(wsi->wait_thread, NULL);
|
||||
wsi->wait_thread = 0;
|
||||
}
|
||||
@@ -3456,7 +3476,9 @@ udev_event_listener_thread(void *data)
|
||||
|
||||
int udev_fd = udev_monitor_get_fd(mon);
|
||||
|
||||
+#ifndef __linux__
|
||||
pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL);
|
||||
+#endif
|
||||
|
||||
for (;;) {
|
||||
nfds_t nfds = 1;
|
||||
@@ -3603,6 +3625,15 @@ wsi_display_finish_wsi(struct wsi_device *wsi_device,
|
||||
struct wsi_display *wsi =
|
||||
(struct wsi_display *) wsi_device->wsi[VK_ICD_WSI_PLATFORM_DISPLAY];
|
||||
|
||||
+#ifdef __linux__
|
||||
+ struct sigaction actions;
|
||||
+ memset (&actions, 0, sizeof (actions));
|
||||
+ sigemptyset (&actions.sa_mask);
|
||||
+ actions.sa_flags = 0;
|
||||
+ actions.sa_handler = thread_signal_handler;
|
||||
+ sigaction (SIGUSR2, &actions, NULL);
|
||||
+#endif
|
||||
+
|
||||
if (wsi) {
|
||||
wsi_for_each_connector(connector, wsi)
|
||||
wsi_display_free_connector(wsi, connector);
|
||||
@@ -3610,7 +3641,11 @@ wsi_display_finish_wsi(struct wsi_device *wsi_device,
|
||||
wsi_display_stop_wait_thread(wsi);
|
||||
|
||||
if (wsi->hotplug_thread) {
|
||||
+#ifndef __linux__
|
||||
pthread_cancel(wsi->hotplug_thread);
|
||||
+#else
|
||||
+ pthread_kill(wsi->hotplug_thread, SIGUSR2);
|
||||
+#endif
|
||||
pthread_join(wsi->hotplug_thread, NULL);
|
||||
}
|
||||
|
||||
diff --git a/src/vulkan/wsi/wsi_common_drm.c b/src/vulkan/wsi/wsi_common_drm.c
|
||||
index fe297d3ca01..8c48b29d733 100644
|
||||
--- a/src/vulkan/wsi/wsi_common_drm.c
|
||||
+++ b/src/vulkan/wsi/wsi_common_drm.c
|
||||
@@ -47,6 +47,9 @@
|
||||
static VkResult
|
||||
wsi_dma_buf_export_sync_file(int dma_buf_fd, int *sync_file_fd)
|
||||
{
|
||||
+ #if defined (__linux__)
|
||||
+ return VK_ERROR_FEATURE_NOT_PRESENT;
|
||||
+ #else
|
||||
struct dma_buf_export_sync_file export = {
|
||||
.flags = DMA_BUF_SYNC_RW,
|
||||
.fd = -1,
|
||||
@@ -64,11 +67,15 @@ wsi_dma_buf_export_sync_file(int dma_buf_fd, int *sync_file_fd)
|
||||
*sync_file_fd = export.fd;
|
||||
|
||||
return VK_SUCCESS;
|
||||
+ #endif
|
||||
}
|
||||
|
||||
static VkResult
|
||||
wsi_dma_buf_import_sync_file(int dma_buf_fd, int sync_file_fd)
|
||||
{
|
||||
+ #if defined (__linux__)
|
||||
+ return VK_ERROR_FEATURE_NOT_PRESENT;
|
||||
+ #else
|
||||
struct dma_buf_import_sync_file import = {
|
||||
.flags = DMA_BUF_SYNC_RW,
|
||||
.fd = sync_file_fd,
|
||||
@@ -84,6 +91,7 @@ wsi_dma_buf_import_sync_file(int dma_buf_fd, int sync_file_fd)
|
||||
}
|
||||
|
||||
return VK_SUCCESS;
|
||||
+ #endif
|
||||
}
|
||||
|
||||
/**
|
||||
diff --git a/src/vulkan/wsi/wsi_common_x11.c b/src/vulkan/wsi/wsi_common_x11.c
|
||||
index 5e4b3a68d07..d19b8faa196 100644
|
||||
--- a/src/vulkan/wsi/wsi_common_x11.c
|
||||
+++ b/src/vulkan/wsi/wsi_common_x11.c
|
||||
@@ -149,22 +149,7 @@ static bool
|
||||
wsi_x11_check_dri3_compatible(const struct wsi_device *wsi_dev,
|
||||
xcb_connection_t *conn)
|
||||
{
|
||||
- xcb_screen_iterator_t screen_iter =
|
||||
- xcb_setup_roots_iterator(xcb_get_setup(conn));
|
||||
- xcb_screen_t *screen = screen_iter.data;
|
||||
-
|
||||
- /* Open the DRI3 device from the X server. If we do not retrieve one we
|
||||
- * assume our local device is compatible.
|
||||
- */
|
||||
- int dri3_fd = wsi_dri3_open(conn, screen->root, None);
|
||||
- if (dri3_fd == -1)
|
||||
- return true;
|
||||
-
|
||||
- bool match = wsi_dev->can_present_on_device(wsi_dev->pdevice, dri3_fd);
|
||||
-
|
||||
- close(dri3_fd);
|
||||
-
|
||||
- return match;
|
||||
+ return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
@@ -1453,8 +1438,6 @@ x11_present_to_x11_dri3(struct x11_swapchain *chain, uint32_t image_index,
|
||||
!wsi_device->x11.ignore_suboptimal)
|
||||
options |= XCB_PRESENT_OPTION_SUBOPTIMAL;
|
||||
|
||||
- xshmfence_reset(image->shm_fence);
|
||||
-
|
||||
if (!chain->base.image_info.explicit_sync) {
|
||||
++chain->sent_image_count;
|
||||
assert(chain->sent_image_count <= chain->base.image_count);
|
||||
@@ -1832,11 +1815,6 @@ x11_acquire_next_image(struct wsi_swapchain *wsi_chain,
|
||||
return result;
|
||||
|
||||
assert(*image_index < chain->base.image_count);
|
||||
-#ifdef HAVE_X11_DRM
|
||||
- if (chain->images[*image_index].shm_fence &&
|
||||
- !chain->base.image_info.explicit_sync)
|
||||
- xshmfence_await(chain->images[*image_index].shm_fence);
|
||||
-#endif
|
||||
|
||||
return result;
|
||||
}
|
||||
@@ -2201,15 +2179,24 @@ x11_image_init(VkDevice device_h, struct x11_swapchain *chain,
|
||||
if (fd == -1)
|
||||
return VK_ERROR_OUT_OF_HOST_MEMORY;
|
||||
|
||||
- cookie =
|
||||
- xcb_dri3_pixmap_from_buffer_checked(chain->conn,
|
||||
- image->pixmap,
|
||||
- chain->window,
|
||||
- image->base.sizes[0],
|
||||
- pCreateInfo->imageExtent.width,
|
||||
- pCreateInfo->imageExtent.height,
|
||||
- image->base.row_pitches[0],
|
||||
- chain->depth, bpp, fd);
|
||||
+ cookie = xcb_dri3_pixmap_from_buffers_checked(chain->conn,
|
||||
+ image->pixmap,
|
||||
+ chain->window,
|
||||
+ image->base.num_planes,
|
||||
+ pCreateInfo->imageExtent.width,
|
||||
+ pCreateInfo->imageExtent.height,
|
||||
+ image->base.row_pitches[0],
|
||||
+ image->base.offsets[0],
|
||||
+ 0,
|
||||
+ 0,
|
||||
+ 0,
|
||||
+ 0,
|
||||
+ 0,
|
||||
+ 0,
|
||||
+ chain->depth,
|
||||
+ bpp,
|
||||
+ 1274,
|
||||
+ &fd);
|
||||
}
|
||||
|
||||
error = xcb_request_check(chain->conn, cookie);
|
||||
@@ -2239,6 +2226,9 @@ x11_image_init(VkDevice device_h, struct x11_swapchain *chain,
|
||||
}
|
||||
#endif
|
||||
|
||||
+ image->sync_fence = 0;
|
||||
+ return VK_SUCCESS;
|
||||
+
|
||||
out_fence:
|
||||
fence_fd = xshmfence_alloc_shm();
|
||||
if (fence_fd < 0)
|
||||
@@ -2281,12 +2271,6 @@ x11_image_finish(struct x11_swapchain *chain,
|
||||
{
|
||||
xcb_void_cookie_t cookie;
|
||||
if (!chain->base.wsi->sw || chain->has_mit_shm) {
|
||||
-#ifdef HAVE_X11_DRM
|
||||
- cookie = xcb_sync_destroy_fence(chain->conn, image->sync_fence);
|
||||
- xcb_discard_reply(chain->conn, cookie.sequence);
|
||||
- xshmfence_unmap_shm(image->shm_fence);
|
||||
-#endif
|
||||
-
|
||||
cookie = xcb_free_pixmap(chain->conn, image->pixmap);
|
||||
xcb_discard_reply(chain->conn, cookie.sequence);
|
||||
#ifdef HAVE_X11_DRM
|
||||
Reference in New Issue
Block a user