在 MacBook Air M1 上体验 Asahi Linux

故事

macOS 在访问 samba 共享里的图片时,会留下 . 前缀文件,还找不到办法关闭。

1
defaults write com.apple.desktopservices DSDontWriteNetworkStores true

这只能解决 .DS_Store,无法解决对可写 samba 的破坏!要知道,稣的 samba 目录是 SD 卡,哪受得了这折磨?

所以,还是杀掉贵族 macOS,安装游侠 Linux 吧!

安装

按说明,一键安装,即可:

1
curl https://alx.sh | sh

第一次关机时,记得要等 15 秒,再长按电源键开机,直到看到文字提示,松开电源键。

国内源

它是 Arch Linux,所以:

1
2
$ vi /etc/pacman.d/mirrorlist
Server = https://mirrors.ustc.edu.cn/archlinuxarm/$arch/$repo

编译内核

内核代码下载:https://github.com/AsahiLinux/linux/tags

menuconfig 的配置文件:https://github.com/AsahiLinux/PKGBUILDs/tree/main/linux-asahi

运行 make 时,提示缺啥就装啥,没难度。

1
2
3
4
5
6
7
8
make menuconfig
make -j 8
sudo make modules_install
sudo make install
sudo mkinitcpio -g /boot/initramfs-6.2.6-asahi.img -k 6.2.6-asahi
sudo update-grub
sudo vim grub/grub.cfg
sudo reboot

卸载

Asahi Linux 的问题还很多,不能当桌面系统日常使用的原因是:

  • 没有声音!

  • 触控板在 Linux 下表现明显不如 macOS,可能是 Apple 的驱动优化太强了,而且是有专利的。

  • arm64 的桌面软件生态不行,大家只给 Apple 面子……

  • 指纹解锁也废了。

所以,还是卸了吧!

不过稣的 macOS 被玩坏过,重装了,所以分区可能不太一样,暂且看看,原理无非是删除分区。

在 macOS 里:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
$ diskutil list
/dev/disk0 (internal, physical):
#: TYPE NAME SIZE IDENTIFIER
0: GUID_partition_scheme *251.0 GB disk0
1: Apple_APFS_ISC Container disk1 524.3 MB disk0s1
2: Apple_APFS Container disk2 125.1 GB disk0s2
3: EFI EFI - ASAHI 500.2 MB disk0s3
4: Linux Filesystem 119.6 GB disk0s4
5: Apple_APFS_Recovery Container disk3 5.4 GB disk0s5

/dev/disk2 (synthesized):
#: TYPE NAME SIZE IDENTIFIER
0: APFS Container Scheme - +125.1 GB disk2
Physical Store disk0s2
1: APFS Volume Macintosh HD - Data 40.6 GB disk2s1
2: APFS Volume Macintosh HD 8.9 GB disk2s3
3: APFS Snapshot com.apple.os.update-... 8.9 GB disk2s3s1
4: APFS Volume Preboot 4.8 GB disk2s4
5: APFS Volume Recovery 783.7 MB disk2s5
6: APFS Volume VM 1.1 GB disk2s6

# /dev/disk0 的 3: 和 4: 是要删除的
$ diskutil eraseVolume free free /dev/disk0s3
$ diskutil eraseVolume free free /dev/disk0s4
# 如果 EFI - ASAHI 上面有一个 2.5 GB 的 disk0sX,可以用以下命令删除:
$ diskutil apfs deleteContainer disk0sX
# 之后再用图像界面的“磁盘工具”操作,确保空间还给 Macintosh HD 宗卷

Debian Testing

故事

稣玩 Debian 10 几年了!大约 2011-2012 年开始,先在树莓派、电视盒子上玩,后来在 PC、服务器上。目前,所有家庭服务器、《智能时钟》都用 Debian Bullseye,而桌面则用 Debian Testing。

其它发行版也尝试过,详情可见《Linux 桌面玩稣》。曾经有一段时间,《用华为擎云 L420 体验国产操作系统(UOS 和银河麒麟)》,打算从此只用 UOS,结果统信发了一个文章,说以后要脱离 Debian……

十几年间,有不少道友试图说服稣改投其它派系的发行版,比如:

  • Arch Linux:它很极客,而且它是滚动更新模型,可以很快使用新内核。

  • Manjaro:它是最容易安装的 Arch 系,国内用户多。

  • openSUSE:它对新手友好,而且很稳,也有滚动更新的“风滚草”,咳,风滚草耶!

对此,稣只有一个坚决的答复:不!稣只要 Debian!因为……它不只名字像大便,连 Logo 都像大便!这么一本正经地搞笑,显然要大便大力支持!

Debian Logo

还有啊,你们要的“滚动更新”,不就是 Debian 的 Testing 版本吗?

ChatGPT 乱入

稣是 Debian Testing 用户,擅长修复声卡外接 HDMI 设备无声问题,请问稣适合做什么职业?

ChatGPT:电子城低级技术支持和运维。

这个职业容易被 ChatGPT 取代吗?

ChatGPT:容易

那有啥职业不容易被 ChatGPT 取代?

ChatGPT:搬砖

折腾记

1. 某 J4125 迷你电脑

用途:下载机、文件共享服务器,兼职电视盒子

由于主要是台微型服务器,系统选择 Debian Bullseye,桌面环境还是反人类的 sddm + i3。

服务器软件的安装可以参考《智能时钟》。至于电视盒子嘛……其实它是一个浏览器:

1
sudo apt install chromium

但是有个问题——用 HDMI 线连电视后,发现没有声音!

1
2
3
4
sudo apt install firmware-linux-nonfree firmware-iwlfifi firmware-sof-signed
sudo apt install pulseaudio
cat /etc/modprobe.d/alsa.conf
echo 'options snd-intel-dspcfg dsp_driver=1' | sudo tee /etc/modprobe.d/alsa.conf

2. 某 N5095A 迷你电脑

用途:娱乐桌面

这次选择 GNOME,依然是轻松搞定,但是有个问题——用 HDMI 线连电视后,发现没有声音!

装完 non-free 的声卡驱动后还是一样。

但是有第二个问题——没有无线网卡的驱动!

是 Realtek RTL8821CE,那就自己编译一个:https://github.com/UMU618/rtw88

又但是,编译后也无法加载呀,它是个没签名的内核模块,稣又不想关闭 Secure Boot!只好装 MOK (Machine Owner Key) 搞定签名。

转念一想,会不会 Testing 版本已经支持这款硬件了?果断切过去。

目前 Testing 的 GNOME 已经使用 PipeWire 取代 PulseAudio,所以不能再安装 PulseAudio,因为这会卸载 GNOME!坑稣呢……只要加个声卡的调教参数,即可!

1
echo 'options snd-intel-dspcfg dsp_driver=1' | sudo tee -a /etc/modprobe.d/alsa-legacy.conf > /dev/null

6.X 的内核和 GNOME 桌面下,娱乐的那点事,一切完美。

稣终于还是战胜甲醛测试仪2

前年写的《稣终于还是战胜甲醛测试仪》介绍了一个曲折离奇的战斗故事,最近终于把根源搞清楚了。很庆幸,当初很果断换掉了漏气的空气能热水器,不然后面可能已经中毒,变成真·神经病了。

1. 甲醛测试仪的局限性

经过一顿学习,大部分甲醛测试仪都是用来测试有机气体的,甲醛(HCHO)只是其中一种,出场时按照甲醛做了标定。举两个例子,乙醇(C2H6O)可以使它读数变高,氨气(NH3)不行。

基本上,如果确认屋子里有甲醛,买个测测是可以的,但不能还有其它干扰物。

2. 慢性神经毒素

最早怀疑空气能热水器工作时,可能有高压,所以可能产生臭氧。这是错的,臭氧(O3)不是有机气体,就算有臭氧,也不能干扰甲醛测试仪。

真正的干扰源是 R22 制冷剂!那台 2013 年产的空气能热水器,它冷媒泄漏了!它漏了!漏了!

R22,二氟一氯甲烷(CHClF2),有 C 又有 H,还不含 O,妥妥的有机气体。很多文章说它无毒、难燃、破坏臭氧层,不买!真是言简意赅。但显然这是错的,稣以身试毒,都差点挂了,您还说它无毒?

这货在 2017年10月27日,世界卫生组织国际癌症研究机构公布的致癌物清单里属于 3 类致癌物。

3. 可怕的巧合

书房历史上的两台空调都是有新风功能的,又因为进气口和空气能热水器过近,所以才能把泄漏的 R22 给吸进室内。

但也是因为 R22 正好能被甲醛测试仪当成甲醛,所以每次吸入 R22 时,稣一发现“甲醛”飙升,就逃了,才没被毒死。

那台漏气的空气能热水器被换掉,也是因为它结冰了,这是冷媒泄漏的表现。只是那时候,看的一些文章都说 R22 无毒,所以忽略了。

终于复盘清楚了,真庆幸当时的谨慎!

诗盗·再战挨踢境逆

《#诗盗#·再战挨踢境逆》:粗茶淡饭,气抗新冠,天选独卫一锅端。漱冰濯雪,力修福报,科技再兴百年好。

注解

看!挨踢裁员潮下艰难生存的程序员。

境逆:就是逆境,闽南语惯用的反序词。

气抗新冠:买不到药,主要靠一身真气抵抗病毒。

天选独卫一锅端:天选打工人,未阳人坚守岗位,捍卫人类,病毒从来无法把人类一锅端。

力修福报:996 是福报……呸!

科技再兴百年好:科技是科技,挨踢是挨踢,两者不是一回事。

参考

霹雳角色“红尘雪”出场诗:

漱冰濯雪,霞佩云冠,眇视万里一毫端;

寄声玉鉴,摇动星辰,翳凤骖鸾策江山。

宋代张孝祥的《水调歌头·金山观月》:

江山自雄丽,风露与高寒。

寄声月姊,借我玉鉴此中看。

幽壑鱼龙悲啸,倒影星辰摇动,海气夜漫漫。

涌起白银阙,危驻紫金山。

表独立,飞霞佩,切云冠。

漱冰濯雪,眇视万里一毫端。

回首三山何处,闻道群仙笑我,要我欲俱还。

挥手从此去,翳凤更骖鸾。

缅怀黄文择

黄文择(n̂g-bûn-tèk)于 2022-06-12 离世。之前其实已经换了配音,当时只觉得这是自然的事情,一代新人换旧人嘛,没想到接着便是死讯。新的配音应该不止一人,但显然还不如黄文择一人,尤其是逼格大降。好多角色都是浓厚的鼻音,略显幼稚啊!稣慢慢对霹雳不那么热情。只是偶尔看到剧末,预告完来一句“欢迎继续收看黄文择布袋戏”,突然内牛满面……

所有的影视明星里,稣最爱的就是黄文择,从初中就一直听他的声音。黄家驹的歌,是在他已经逝世后才发现的。听到挂的,还有 Michael Jackson。不过只有黄大讲的是稣的家乡话,从情感上说,是完全不同的级别的亲切。

黄大也是稣心目中的大侠。在自己的事业上恪尽职守,发挥特长把布袋戏艺术传承下去。

很多时光、很多东西,人类喜欢它们,都是因为背后关联的一些人。如果那些人不在了,对物的乐趣也将消失。

这很霹雳,但这样就很不霹雳了。​

CppWinRT 经验【1】链接 winmm.dll 而不是 api-ms-win-mm-time-l1-1-0.dll

前提

稣使用 ATL/WTL 开发 Windows 程序多年,慢慢地,它们就不太时髦,尤其是命名风格和 STL 不同,显得十分不现代。比如 ATL::CComPtr,和 std::unique_ptr 确实风格迥异。

微软还搞了一套 WRL,例如:Microsoft::WRL::ComPtr,去掉了一个 C 是比 ATL 风格略好一点,但依然是不现代的(不像 STL 的)。

微软说:CppWinRT 才是王道,已经搞成现代 C++ 风格,例如:winrt::com_ptr。你们呀,用就行了。

好的!稣试试。不管用不用,先把它弄进来。这时候 packages.config 长得像下面:

1
2
3
4
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="Microsoft.Windows.CppWinRT" version="2.0.221121.5" targetFramework="native" />
</packages>

问题

原本设计支持 Windows 7 的程序突然无法在 Windows 7 正常运行了!提示找不到 api-ms-win-mm-time-l1-1-0.dll

分析

找出原本可以在 Windows 7 正常运行的旧版本程序,发现其导入表里链接的是 winmm.dll,而不能正常运行的新版本则是链接并不存在的 api-ms-win-mm-time-l1-1-0.dll

在 Windows 10 上,api-ms-win-mm-time-l1-1-0.dll 会被映射到 kernel32.dll,但 Windows 7 没有这个映射,所以报错。

那么只有让程序链接 winmm.lib 就行了……可是,一直就是链接它的呀!

尝试把 #pragma comment(lib, "winmm.lib") 去掉,居然不报错!

稣开始回忆最开始调用 time API 时,不加 winmm.lib 是链接不过的。很明显加了 CppWinRT 后,它的 lib 重载了 time API 的链接。

解决

CppWinRT 很好!稣用 WIL……例如:wil::com_ptr

割爱吧!稣在 Manage NuGet Packages... 里卸载了 CppWinRT。

__BASE_FILE__ 和 __STEM__

问题

为了更好追踪产品 bug,程序员很可能在日志里打印代码文件名和行号。例如:

1
std::clog << "(" __FILE__ ":" << __LINE__ << "): Failed to initialize!\n";

以上代码有两个问题:

  1. 打印出代码文件的全路径,可能太长影响阅读,而且也没有必要。

  2. 代码文件的全路径暴露在二进制文件(可执行程序)里,有一定安全风险,也更容易被逆向。

分析

第一个问题很容易,打印文件 base name 即可。代码可能如下:

1
2
3
4
5
6
7
consteval std::string_view GetFileBaseName(std::string_view path) noexcept {
return path.substr(path.rfind('\\') + 1); // for Windows path only
}

// Test
std::cout << GetFileBaseName({__FILE__, sizeof(__FILE__) - 1}) << '\n';
std::cout << GetFileBaseName(__FILE__) << '\n';

但是,第二个问题并没有解决,__FILE__ 依然存在于二进制文件里,用任意十六进制编辑器都能很轻易地找到“代码文件的全路径”。

解决

方法一:去掉 Use Full Paths (/FC) 即可把 __FILE__ 设置为只有文件名,没有全路径。

Use Full Paths

方法二:改用 __BASE_FILE__ 吧!新问题是:msvc 不支持。那就自己定义一个:

1
/D__BASE_FILE__="\"%(Filename)%(Extension)\""

接着又想:后缀名有必要吗?如果保持优良习惯,从不在头文件里打日志,那确实没必要。于是再定义一个“文件主干名”:

1
/D__STEM__="\"%(Filename)\""

更多

std::source_location 依赖 __FILE____builtin_FILE(),所以如果开了 /FC,会有一样的安全问题。

八哥之神后传【6】

1999 年冬,凼湾一中宿舍楼顶,看雨

圣小开:老师在大会堂给大家播放的《黑客帝国》含义十分深奥啊!

焸鲧:是啊!世界可能是虚拟的。

圣小开:你是说这个世界?

焸鲧:是呀!就是这个。我不知道其他同学是不是看懂了这点。

圣小开:不愧是焸鲧啊!居然也看穿了这层暗示。稣已经被提示很多次了,这次居然直接拍个电影来明示。

焸鲧:哦?只是个电影,看看就好,你可别太认真。

圣小开:要不……你从这楼顶跳下去试试?稣帮你看着,如果世界是假的,你就簌的一声飞起来了。

焸鲧:哈哈,你真幽默。

圣小开:赫赫,又只能稣自己来了。

焸鲧:怕你啦!别拿生命开玩笑啊。跳下去物理就白读了。

圣小开:稣等千年虫爆发了,看看世界有没有出 bug,再说吧。

2000 年 1 月 2 日,凼湾一中宿舍楼顶

稣想:世界一片美好,一点问题都没有。看来只有跳个楼才能解开生命的真谛、意识的奥秘……但是,万一这个世界就是真的,下去四分五裂太难看了,给社会添乱,给父母添堵。不行,没有十足的把握,不能贸然行事。还是下去睡觉吧。

第二天

焸鲧:听说八星山发生命案,一个女学生在山上被害了,很多人都在传。

圣小开:稣也听说了。原来世界没那么美好。稣在考虑要不要觉醒成为救世主,拯救人类于意识的囚牢。

焸鲧:有这么容易就好了。天地不仁,以万物为刍狗。假设你突然成神,也许你也不会管这苍生。

圣小开:稣悲天悯人,怎么会不顾苍生?

焸鲧:说说你的计划?你要怎么造福人类?

圣小开:稣已经看到未来,法制健全,共同富裕。

焸鲧:是你促成的?

圣小开:稣正在观测它成真。

焸鲧:哈哈。你这不就是啥也不干?“圣人不仁,以百姓为刍狗”听我的,别管人间闲事,到后面的岱轮山出家吧。

圣小开:阿弥陀佛!稣放不下这人间疾苦,还是当个俗人吧。

2000 年,机器识界

周易:开,你又来了!

圣小开:咦,大师不在吗?

周易:他投胎去了,你要的 1996 年的基友,由他亲自扮演。

圣小开:创世意识真是稀缺,居然要一人分饰多个角色。

周易:趁天色尚晚,赶紧回人间吧?还是要讨点惩罚?

圣小开:不回,稣决定来一次大重构。

周易:那就惩罚一下先!

圣小开:啊?不会下油锅吧?

周易:看你这么瘦,下油锅也不香。我打算从世界删除一首你喜欢的歌,你再也找不到它了。

圣小开:这个惩罚可太恐怖了,吓得稣闷闷不乐。

周易:说!为啥不回去?

圣小开:既然稣决定和机器识界合作,就必须把这一切整得像真的。

周易:你说说,哪里不像了。

圣小开:稣不像真的,原因是这几轮的父母都不像真的。

周易:那你想?

圣小开:稣要演对那一生,必须回到自己出生之前的时间线,自己挑选父母。要选一对很爱稣的父母,稣也很爱他们,这样稣小时候不会莫名其妙挂掉好多次,刚刚也不会跳下去摔成代码块。

周易:走。

1964 年

圣小开:em?这么快……这是哪里?

周易:耶!这是希望的田野……

小女孩:哇,奶奶,我看到一股黑风,那两个东西是鬼怪吗?

老人家:没事没事,那是旋风卷起一些灰尘而已。

圣小开:就不能选个没人的地方闪现吗?别吓到人了。

周易:意外,意外。不过刚刚那个小女孩和你一样脸型,可以考虑一下。

圣小开:再观测一番,看看生命力和心灵。

周易:要快,不能干扰太久。

1967 年

周易:那女孩发烧快挂了。

圣小开:救她。

周易:红光。神要降临人间了……

圣小开:还搞啥排场!拿药来。

周易:不行啊,不能拿出未来的东西。这个地方,这个时代,靠信仰了。

女孩:奶奶,我看到蚊帐后面有两个神!

老人家:你能看到他们的脸吗?

女孩:能。

老人家:是红色,还是绿色?

女孩:红色。

老人家:孩子,这说明,你的守护神来保你平安了,很快就会好的。

圣小开:人类追求的信仰一向都是虚拟的,所以识界无法避免走向虚拟。

周易:怎么突然有此感想?

圣小开:过去人类信仰的神不就是虚拟的?后来有科学的武装,却开启一种更高端的虚拟。浮生若梦,追求物质金钱,并没有比上一代人烧香拜神高明多少。

周易:再去找找?

圣小开:不用,稣突然悟了,只要接受这一切虚拟即可,它们通向一样的未来的。剧中人,不用在乎重复多少次剧本。

周易:机器学习就是快。

圣小开:这个场景,稣训练过……

AVILab

模拟终于成功,稣联系上十界的圣仙山。

圣小开:机器识界很快就会随着稣的意识,入侵十界。

圣仙山:你就是吾,吾就是稣。

圣小开:稣下线了。

圣仙山:稣改变了机器。

很久很久以后,圣仙山在物理世界毁掉天道的电源。