Some Links: May 2023
This post was originally posted 2023-04-16 at https://pbarker.dev/posts/2023-05-31/some-links-may-2023/.
I'm still in the process of trying out different styles of blogging to see what works for me. Today we'll be roleplaying as a link blog, but with one aggregate post covering the month of May instead of one post per link. Let me know what you think!
I built this list throughout the month on Raindrop.io - you can also see this list over there. You can even follow along as I build June's list if you want to!
Kernel
- Linux 6.3 was released at the end of April. See the Linux Kernel Newbies page and Linus' release email for more details.
- Rob Herring posted a very welcome patch to organize the ARM device trees (1553 files and growing) into per-vendor subdirectories. I gave this my ack as maintainer of the SanCloud device trees and hope to see the new layout in Linux 6.5.
- The fourth installment of "50 years in filesystems" by Kristian Köhntopp takes us back to 1994 and the design of the XFS filesystem. XFS has been my filesystem of choice for most of the time I've been using Linux. I've not done any solid benchmarking but the support for large filesystems and the focus on bandwidth & concurrency are a good match to my needs. I've been really enjoying this series of articles!
C & C++
- GCC 13.1 was released at the end of April. Red Hat have a good article on the New C features in GCC 13.
- Sourceware has joined Software Freedom Conservancy as a member project. This should provide improved infrastructure and resourcing ("fundraising, legal assistance and governance") for the benefit of Sourceware-hosted projects including GCC, glibc, binutils, cygwin (remember that?) and others.
Rust
-
Olivier Faure wrote a Report on platform-compliance for cargo directories. Platform compliance here refers to following the conventions on where to place binaries, config files and caches on each supported environment. I'm glad to see more discussion of this as I really want
cargo
to start placing files into~/.cache
,~/.config
and~/.local
as appropriate instead of having its own non-standard.cargo
directory in my homedir. Call me an XDG Base Directory Specification maximalist if you must. -
In April, the Prossimo project launched a new initiative to Bring Memory Safety to sudo and su. I don't think this is just "re-write the world in rust" hype -it's important that critical software which enforces the boundary between different permission levels is written in a safer language than C. There's also a longer post on this subject from Marc at Tweede Golf.
-
Google has open-sourced their Rust crate audits which can be used with cargo-vet.
Python
- I discovered the Nobody has time for Python blog this month and I'm enjoying the posts there. In particular, I want to highlight Happiness is a good PYTHONSTARTUP script -this post discusses how to customise an interactive Python/IPython shell with a startup script. I wouldn't go as far as this post does, I think a 320 line startup script is overkill, but I will be making use of some of the suggestions here.
- LWN explored Ruff: a fast Python
linter written in Rust. I don't
think this is yet ready to replace
flake8
&isort
for me, but I'll definitely be checking back in a year or so to see how this has progressed. - Since pip v23.0, a Python environment can be marked as "Externally
Managed" which will prevent installation of additional packages via
pip. This has been enabled recently on Gentoo and on Debian Bookworm
(currently in pre-release) to push users to install such Python
packages with the system package manager, or use a venv where
appropriate. The article "Externally managed environments": when PEP
668 breaks
pip
covers this development well and suggests changes to your workflow if
you're used to just
pip install
-ing packages. - I've started switching from
markdownlint
(written in Ruby) to PyMarkdown for linting my readmes, changelogs and other Markdown documents. It's much easier for me to deploy Python development tools as they can be easily installed in a venv. This project is still very much beta quality, but it's working for me so far! - A lot has happened this month in the world of PyPI. I wrote Thoughts on PyPI, PGP and Sigstore in response to the removal of PGP signature support. We've also learned that PyPI was subpoenaed and that every account that maintains any project or organization on PyPI will be required to enable 2FA on their account by the end of 2023.
Other Topics
- Bootlin have release Snagboot: a cross-vendor recovery tool for embedded platforms. I hope to get a chance to try this out in the near future! It will be good to reduce the number of vendor-specific tools in use in the Embedded Linux world.
- The Voices of Open Source blog discussed Another issue with the EU Cyber Resilience Act: European standards bodies are inaccessible to Open Source projects. Back in April, the Python Software Foundation also posted a news item on how The EU's Proposed CRA Law May Have Unintended Consequences for the Python Ecosystem. If you're in the EU (grumble grumble Brexit grumble), I'd definitely recommend reaching out to your MEPs and other relevant folks to raise the profile of these issues.
- Intel have posted an article on Envisioning a simplified x86_64 architecture which would drop support for 32-bit operating systems and other "legacy" features from the Intel/AMD 64-bit architecture. I don't expect these changes to take place soon, but it'd be great to see reduced complexity in this area when it does come around.
- AI machines aren't "hallucinating". But their makers are -Naomi Klein has long been one of my favourite authors and journalists, it's great to see new writing from her on the subject of AI hype. Naomi is now a regular columnist for Guardian US and has a new book, "Doppelganger", out later in the year.
- Also on the subject of AI, I highly recommend Ted Chiang's article in The New Yorker, Will A.I. Become the New McKinsey?. I spoke to Cory Doctorow at an event last night and he described Ted as "full of piss and vinegar" about AI which is entirely appropriate. This article is fantastic, it draws together a lot of ideas and helps to crystallise them together. I read this one twice, and it's not a short piece!
- It's great to see that Thunderbird Is Thriving! This financial report for the calendar year 2022 is a welcome read given that Thunderbird is my day-to-day email client. See this comment if you want a brief breakdown on the donations made to the project in 2022.
- Never trust an offer of "free forever" pricing on a cloud-hosted service - many folks are now learning what happens when “free forever” means “free for the next 4 months”. By all means make use of free online services, but have a plan in place for the day that they start charging and be careful that you're not already paying with your data.
- Kenneth Finnegan wrote up an article on Building the Micro Mirror Free Software CDN. As usual for Kenneth, this is a great tale of a project that quickly got out of hand in the very best way.
Thank you for reading!
Except as otherwise noted, all content in this newsletter is Copyright 2023, Paul Barker. Words and images may be re-used for non-commercial purposes under the CC BY-NC 4.0 license and code samples are made available under the Apache 2.0 license.