diff options
Diffstat (limited to 'content/bsd')
14 files changed, 546 insertions, 457 deletions
diff --git a/content/bsd/desktop-freebsd-wont-improve-unless-people-are-using-it.md b/content/bsd/desktop-freebsd-wont-improve-unless-people-are-using-it.md index 80e94025..723c82c4 100644 --- a/content/bsd/desktop-freebsd-wont-improve-unless-people-are-using-it.md +++ b/content/bsd/desktop-freebsd-wont-improve-unless-people-are-using-it.md @@ -1,66 +1,120 @@ ---- -title: "Desktop FreeBSD won't improve unless people are using it" -category: bsd -abstract: I have hits from /r/bsd, but almost none of those people are using BSD -date: 2023-03-29T21:15:51+02:00 -year: 2023 -draft: false -tags: -- FreeBSD -- Reddit ---- ++++ +title = "FreeBSD on the Desktop won't improvide unless people are using it" +author = ["Michał Sapka"] +date = 2023-03-29T22:09:00+02:00 +categories = ["bsd"] +draft = false +weight = 2002 +abstract = "I have hits from /r/bsd, but almost none of those people are using BSD" +[menu] + [menu.bsd-varia] + weight = 2002 + identifier = "freebsd-on-the-desktop-won-t-improvide-unless-people-are-using-it" + name = "Desktop FreeBSD won't improve unless people are using it" ++++ + Shamelessly, I posted my previous post, [FreeBSD on a Thinkpad Extreme G2](https://d-s.sh/2023/freebsd-on-thinkpad-x1-extreme-g2/) on [/r/bsd Reddit](https://www.reddit.com/r/BSD/comments/124v5cm/freebsd_on_a_thinkpad_x1_extreme_g2/). -The result, some 24 hours later, is 100 visitors. Out of that 100, 57 are using a desktop. Out of that 57, only 2 used FreeBSD—2%. No other BSDs are recorded. +The result, some 24 hours later, is 100 visitors. +Out of that 100, 57 are using a desktop. +Out of that 57, only 2 used FreeBSD—2%. No other BSDs are recorded. + +People who are into BSD don't use BSD. +This seems to be a reason for lacking hardware support. +If no one uses FreeBSD, no one will encounter those problems. If no one encounters them, no one will fix them. + + +## Update 2023-04-14 {#update-2023-04-14} + +The article, got quite the round around the internets, gathering some interests from [Reddit](https://old.reddit.com/r/freebsd/comments/126fvkz/desktop_freebsd_wont_improve_unless_people_are/), [Hacker News](<https://news.ycombinator.com/item?id=35378367>), Twitter, Discover BSD, or [Vermaden](https://vermaden.wordpress.com/2023/04/03/valuable-news-2023-04-03/). +With all that interest come quite a few questions and comments. +The following is an attempt to summarize it all. -People who are into BSD don't use BSD. This seems to be a reason for lacking hardware support. If no one uses FreeBSD, no one will encounter those problems. If no one encounters them, no one will fix them. -### Update 2023-04-14 +### People who use FreeBSD don't care about FreeBSD hardware {#people-who-use-freebsd-don-t-care-about-freebsd-hardware} -The article, got quite the round around the internets, gathering some interests from [Reddit](https://old.reddit.com/r/freebsd/comments/126fvkz/desktop_freebsd_wont_improve_unless_people_are/), [Hacker News](https://news.ycombinator.com/item?id=35378367), Twitter, Discover BSD or [Vermaden](https://vermaden.wordpress.com/2023/04/03/valuable-news-2023-04-03/). With all that interest come quite a few questions and comments. The following is an attempt to summarize it all. +This makes perfect sense. +If your FreeBSD installation on X220 works flawlessly, you may not care about anything more modern. +But there will come a time when you will need to replace the hardware. -### People who use FreeBSD don't care about FreeBSD hardware +{{< img-r "freebsd-beastie.png" >}} +FreeBSD Beastie +{{< /img-r >}} -This makes perfect sense. If your FreeBSD installation on X220 works flawlessly, you may not care about anything more modern. But there will come a time when you will need to replace the hardware. +This comment, however, came as a proof that the sample from my blog is invalid. +This may be the case, but I don't buy it. +All traffic on the aforementioned post came from Reddit's BSD forum. +It's the one place where you could expect that people using BSD would hang. +It may also be that it's quite a random sample - it's small, and people who have yet to become into BSD but are BSD-curious opened my blog post. +I am in no place to debunk or confirm this. +I, however, know that many people presenting at FreeBSD conferences do it using Macs or Windows. +So even if the numbers are dubious, the overall feeling remains sorrowful. -{{<img-pull-right "freebsd-beastie.png">}} -This comment, however, came as a proof that the sample from my blog is invalid. This may be the case, but I don't buy it. All traffic on the aforementioned post came from Reddit's BSD forum. It's the one place where you could expect that people using BSD would hang. It may also be that it's quite a random sample - it's small, and people who have yet to become into BSD but are BSD-curious opened my blog post. I am in no place to debunk or confirm this. I, however, know that many people presenting at FreeBSD conferences do it using Macs or Windows. So even if the numbers are dubious, the overall feeling remains sorrowful. +To add to the above: there are also stats for the commented opinion piece. +Two hundred forty-four people opened it from /r/freebsd. +Of that, 24 people were using FreeBSD, and just 2 were using OpenBSD. -To add to the above: there are also stats for the commented opinion piece. Two hundred forty-four people opened it from /r/freebsd. Of that, 24 people were using FreeBSD, and just 2 were using OpenBSD. -### Your statistics may be invalid as people mask their browser agent. +### Your statistics may be invalid as people mask their browser agent. {#your-statistics-may-be-invalid-as-people-mask-their-browser-agent-dot} -This also may be the case. Why, then, is the referer not spoofed? It's a much more invasive data point than the underlying OS. But I'm a simple Firefox user, never used Librewolf. +This also may be the case. +Why, then, is the referer not spoofed? +It's a much more invasive data point than the underlying OS. +But I'm a simple Firefox user, never used Librewolf. -### FreeBSD is a server OS -Yeah, this is the sentiment I've read before jumping aboard. My problem with this idea is that each and every FOSS OS is a value in itself. The current poster boy, Linux, also had huge problems getting to work on various machines. In my opinion, it's limiting OS to a single use case is a completely valid point - your use case for FreeBSD is on a server, and this is where it currently shines (or not, depending on your experience). Some folks despise allocating any FreeBSD dev time to the desktop as there are many server issues. +### FreeBSD is a server OS {#freebsd-is-a-server-os} -But again, I don't see it this way. Limiting FreeBSD to the server only is short-lighted. Unless you are already powering your servers with BSD, there will always be a question, "Why not Linux. It's what everyone else is doing". And Linux got into its current position not by being a great server machine but rather by attracting the interest of some very skillful people. And it did it by allowing more and more people to free themselves from Windows on their machines. +Yeah, this is the sentiment I've read before jumping aboard. +My problem with this idea is that each and every FOSS OS is a value in itself. +The current poster boy, +Linux, also had huge problems getting to work on various machines. +In my opinion, it's limiting OS to a single use case is a completely valid point - your use case for FreeBSD is on a server, and this is where it currently shines (or not, depending on your experience). +Some folks despise allocating any FreeBSD dev time to the desktop as there are many server issues. -I see FreeBSD problems as having two primary causes: the [Unix wars](https://en.wikipedia.org/wiki/Unix_wars) of the past and limited resources now. If FreeBSD were easier to use on a wide range of end-user machines (which tend to be laptops), the easier it would for people to want to develop it. BSDs are now a far second choice. Why would someone invest time? They may fall in love with the OS, but unless they try it, it will never happen. +But again, I don't see it this way. +Limiting FreeBSD to the server only is short-lighted. +Unless you are already powering your servers with BSD, there will always be a question: "Why not Linux. It's what everyone else is doing". +And Linux got into its current position not by being a great server machine but rather by attracting the interest of some very skillful people. +And it did it by allowing more and more people to free themselves from Windows on their machines. -### I like our small userbase +I see FreeBSD problems as having two primary causes: the [Unix wars](https://en.wikipedia.org/wiki/Unix_wars) of the past and limited resources now. +If FreeBSD were easier to use on a wide range of end-user machines (which tend to be laptops), the easier it would for people to want to develop it. +BSDs are now a far second choice. +Why would someone invest time? +They may fall in love with the OS, but unless they try it, it will never happen. + + +### I like our small userbase {#i-like-our-small-userbase} I'm as elitist as the other person. [DWM](https://dwm.suckless.org/) stated that -> "This keeps its userbase small and elitist. No novices asking stupid -questions." +> "This keeps its userbase small and elitist. +> No novices asking stupid questions. + +I can't find this quote anymore, but the sentiment seems similar. +However, there are two aspects here. -I can't find this quote anymore, but the sentiment seems similar. However, there are two aspects here. +FreeBSD comes with no graphical interface by default. +This makes it much closer to minimalist distros than Ubuntu. +This still allows anyone to feel like a hacker. -FreeBSD comes with no graphical interface by default. This makes it much closer to minimalist distros than Ubuntu. This still allows anyone to feel like a hacker. +The second, however, is that some problems are unsolvable by end-user. +Writing drivers is EXTREMELY difficult, and, as I've recently learned (thanks, Jeff!), this is especially true when it comes to WiFi drivers, as there is no open implementation. +This means that any progress requires a trial-and-error process based on reverse engineering. +No one without deep knowledge of low-level programming will be able to make any progress, and even those few will need people with real hardware for testing. -The second, however, is that some problems are unsolvable by end-user. Writing drivers is EXTREMELY difficult, and, as I've recently learned (thanks, Jeff!), this is especially true when it comes to WiFi drivers, as there is no open implementation. This means that any progress requires a trial-and-error process based on reverse engineering. No one without deep knowledge of low-level programming will be able to make any progress, and even those few will need people with real hardware for testing. -### Hardware support is years behind Linux +### Hardware support is years behind Linux {#hardware-support-is-years-behind-linux} Yes, and this is what I was referring to. -### Why would anyone use BSD on a desktop? + +### Why would anyone use BSD on a desktop? {#why-would-anyone-use-bsd-on-a-desktop} It's a great system, just needs a lot of work on hardware support :-) -### Your post is worthless, and only the comments are interesting + +### Your post is worthless, and only the comments are interesting {#your-post-is-worthless-and-only-the-comments-are-interesting} It's more than I anticipated. That post was small and written without any deeper research. But the discussion around it makes me believe that I hit something real. diff --git a/content/bsd/early-freebsd-thoughts.md b/content/bsd/early-freebsd-thoughts.md index 118938b9..123cab21 100644 --- a/content/bsd/early-freebsd-thoughts.md +++ b/content/bsd/early-freebsd-thoughts.md @@ -1,40 +1,79 @@ ---- -title: "Early FreeBSD Thoughts" -category: bsd -abstract: I've been using FreeBSD on my server for the last few weeks and I like it! -date: 2023-02-15T20:50:01+01:00 -year: -draft: false -tags: -- FreeBSD -- NIX -- VPS -- pkg -- ports -- rc ---- -Early FreeBSD thoughts ++++ +title = "FreeBSD: Early thoughts" +author = ["Michał Sapka"] +date = 2023-02-15T21:12:00+01:00 +categories = ["bsd"] +draft = false +weight = 2001 +abstract = "I've been using FreeBSD on my server for the last few weeks and I like it!" +[menu] + [menu.bsd-varia] + weight = 2001 + identifier = "freebsd-early-thoughts" + name = "FreeBSD: early thoughts" ++++ -I'm leaning more and more towards joining the [FreeBSD](https://www.freebsd.org/) crowd. +I'm leaning more and more towards joining the [FreeBSD](https://www.freebsd.org/) crowd. -The community is small and welcoming, and I'm driven towards more minor groups. But I was surprised to find out hoh welcoming it was. People seem to be actually happy to help a noob -something the Linux crowd forgot how to do. +The community is small and welcoming, and I'm driven towards more minor groups. +But I was surprised to find out hoh welcoming it was. +People seem to be actually happy to help a noob - something the Linux crowd forgot how to do. -{{<img-pull-right "freebsd-beastie.png" "FreeBSD Bestie">}} -Another aspect is the documentation. People say it's excellent, and I consider it to be selling short. I'm reading [The Official Handbook](https://docs.freebsd.org/en/books/handbook/). It starts with the assumption that the reader has close to 0 knowledge but never treats him as a moron. And chapter by chapter explains how and why things work this way. It may not be for everyone, as you are expected to want to learn - but it is invaluable if you are in the target group. It's worth reading even if you don't want to move to BSD, as a lot applies to other NIXs, like Linux. +{{< img-r "freebsd-beastie.png" >}} +FreeBSD Beastie +{{< /img-r >}} -And, of course, the system itself. I've been using unix-inspired OSs exclusively for over a decade (and quite often before that). FreeBSD is so close, that from day 0, I am able to navigate it. And what I see is a very well-thought system without many pitfalls Linux fell into. Just two examples that strike me the most. +Another aspect is the documentation. +People say it's excellent, and I consider it to be selling short. +I'm reading [The Official Handbook](https://docs.freebsd.org/en/books/handbook/) +It starts with the assumption that the reader has close to 0 knowledge but never treats him as a moron. +And chapter by chapter explains how and why things work this way. +It may not be for everyone, as you are expected to want to learn - but it is invaluable if you are in the target group. +It's worth reading even if you don't want to move to BSD, as a lot applies to other NIXs, like Linux. -In Linux, the root partition is a mess. System and userland are intertwined, and I wonder if anyone understands where things should go. Just look at how many explanations of the structure there are! Should this particular config be in /var/ or maybe in /etc/? AFAIK there are no generic guidelines, just tribal knowledge. If FreeBSD, there's a [dedicated chapter](https://docs.freebsd.org/en/books/handbook/basics/#dirstructure) in the documentation! There's also a strict rule where userland should live - in /usr. Everything you install goes to /usr - the executables, the configs, etc. Finally, a new user can experiment without fearing breaking the system! +And, of course, the system itself. +I've been using unix-inspired OSs exclusively for over a decade (and quite often before that). +FreeBSD is so close, that from day 0, I am able to navigate it. +And what I see is a very well-thought system without many pitfalls Linux fell into. +Just two examples that strike me the most. -The other one is the `rc` subsystem. The Linux world has a neverending war between Systemd and, well, everything else. Here? The system itself dictates how to manage the cattle - elegantly and logically. +In Linux, the root partition is a mess. +System and userland are intertwined, and I wonder if anyone understands where things should go. +Just look at how many explanations of the structure there are! +Should this particular config be in _var_ or maybe in _etc_? +AFAIK there are no generic guidelines, just tribal knowledge. +If FreeBSD, there's a [dedicated chapter](https://docs.freebsd.org/en/books/handbook/basics/#dirstructure) in the documentation! +There's also a strict rule where userland should live - in /usr. +Everything you install goes to /usr - the executables, the configs, etc. +Finally, a new user can experiment without fearing breaking the system! -{{<img-center "freebsd13-bootloader.png" "it even comes with bootloader baked in" "https://en.wikipedia.org/wiki/File:FreeBSD_13.0_boot_loader_screenshot.png">}} +The other one is the \`rc\` subsystem. +The Linux world has a neverending war between Systemd and, well, everything else. +Here? +The system itself dictates how to manage the cattle - elegantly and logically. -FreeBSD comes with two package managers: pkg and ports. Pkg is a standard replacement for brew/apt/pacman or whatever else is there. What is nice is that the user can configure to use packages updated quarterly or the latest. Want to have a stable infrastructure? Go with quarterly - bug fixes will be included in between updates. Want modern thingies? Go with the latest. My biggest issue with Ubuntu and its derivatives is how far behind the packages in apt are, as they are tied to the yearly distro update circle. You can mitigate this by using personal repositories, but those are a nuance to set up. FreeBSD comes prepared for servers and workstations at the same time. +{{< img-c "freebsd13-bootloader.png" >}} +How the OS greats us. +{{< /img-c >}} -And then there are ports for the demanding crowd. Since BSD is semi-compatible with Linux, you can compile most of its software. But there are some differences, so it requires some manual configuration or looking for dependencies. Or rather, it would, as FreeBSD has you covered. Ports is a single repository with makefiles for different projects tailored for the system. You can either compile anything with default settings or adjust the parameters easily. Want Firefox without JS support? Why not! I have yet to use ports, as they seem excessive for my humble VPS, but I love the idea. +FreeBSD comes with two package managers: pkg and ports. +Pkg is a standard replacement for brew/apt/pacman or whatever else is there. +What is nice is that the user can configure to use packages updated quarterly or the latest. +Want to have a stable infrastructure? +Go with quarterly - bug fixes will be included in between updates. +Want modern thingies? Go with the latest. +My biggest issue with Ubuntu and its derivatives is how far behind the packages in apt are, as they are tied to the yearly distro update circle. +You can mitigate this by using personal repositories, but those are a nuance to set up. +FreeBSD comes prepared for servers and workstations at the same time. -So, you have the best features from Ubuntu (stable versions), Arch (cutting edge), and from Gentoo (compile from source code) right at your disposal. +And then there are ports for the demanding crowd. +Since BSD is semi-compatible with Linux, you can compile most of its software. +But there are some differences, so it requires some manual configuration or looking for dependencies. +Or rather, it would, as FreeBSD has you covered. +Ports is a single repository with makefiles for different projects tailored for the system. +You can either compile anything with default settings or adjust the parameters easily. +Want Firefox without JS support? Why not! I have yet to use ports, as they seem excessive for my humble VPS, but I love the idea. -I am **this** close to installing FreeBSD on my personal computer. My work-issued Macbook is [already running a BSD derivative](https://en.wikipedia.org/wiki/Darwin_(operating_system)#Kernel)... for better or worse. +So, you have the best features from Ubuntu (stable versions), Arch (cutting edge), and from Gentoo (compile from source code) right at your disposal. +I am ****this**** close to installing FreeBSD on my personal computer. My work-issued Macbook is [already running a BSD derivative](https://en.wikipedia.org/wiki/Darwin_(operating_system)#Kernel)... for better or worse. diff --git a/content/bsd/first-time-the-zfs-saved-me.md b/content/bsd/first-time-the-zfs-saved-me.md deleted file mode 100644 index 77a5cb95..00000000 --- a/content/bsd/first-time-the-zfs-saved-me.md +++ /dev/null @@ -1,31 +0,0 @@ ---- -title: "First Time the ZFS Saved Me" -category: bsd -abstract: Automatic snapshot saved me from a full system reinstalation -date: 2023-03-18T06:04:33+01:00 -year: 2023 -draft: false -tags: -- FreeBSD -- ZFS ---- -{{<img-pull-right "zfs-logo.png">}} -As I was recently trying to [enable auto-switching audio to headphones](/2023/switching-between-speakers-and-headphones-on-freebsd/), I borked my FreeBSD installation. Somehow the speakers stopped working, and the headphone output added a loud hiss. Unfortunately, I was unable to fix it. - -My first thought was to reinstall the system, but then I remembered that I've read about [ZFS Snapshots](https://docs.oracle.com/cd/E19253-01/819-5461/gbcya/index.html). - -``` -zfs list -t snapshot -``` - -revealed that FreeBSD has already created a few of those recently. I knew this OS and ZFS go hand in hand, but I was still pleasantly surprised. - -To return the system to a previous version, all I had to do was - -``` -zfs snapshot <name> -``` - -and my system stopped responding. I was in X, so that's entirely on one. But the rollback was so instantaneous that my first thought was that something fried. - -After a good, old hard reset, everything worked as it was a few days ago. ZFS very well may be my new best friend. diff --git a/content/bsd/freebsd-13-2-was-released-and-broke-my-resume.md b/content/bsd/freebsd-13-2-was-released-and-broke-my-resume.md deleted file mode 100644 index f33c501f..00000000 --- a/content/bsd/freebsd-13-2-was-released-and-broke-my-resume.md +++ /dev/null @@ -1,20 +0,0 @@ ---- -title: "FreeBSD 13.2 was released and broke my resume" -category: bsd -abstract: There's a new version and new problems for me -date: 2023-04-11T16:10:29+02:00 -year: 2023 -draft: false -tags: -- FreeBSD -- WiFi -- iflwifi ---- -{{<img-pull-right "freebsd-beastie.png">}} -A new version of FreeBSD was released today, 13.2-RELEASE. - -The update went smoothly on my laptop, and there are a lot of updates in pkg. Unfortunately, my fix for [black screen after resume](/2023/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd/) stopped working. I had no time to debug it yet, so there is no bug report yet from my side. - -The drivers for iflwifi were updated, so I was hoping that maybe the [WiFi experience](https://d-s.sh/2023/freebsd-on-modern-intel-wifi-cards-and-resume/) would be better, but since the sleep/resume cycle is not working, I am unable to test it. - -Full release notes can be found on the [FreeBSD website](https://www.freebsd.org/releases/13.2R/relnotes/). diff --git a/content/bsd/freebsd-on-modern-intel-wifi-cards-and-resume.md b/content/bsd/freebsd-on-modern-intel-wifi-cards-and-resume.md deleted file mode 100644 index f5c402b0..00000000 --- a/content/bsd/freebsd-on-modern-intel-wifi-cards-and-resume.md +++ /dev/null @@ -1,25 +0,0 @@ ---- -title: FreeBSD on modern Intel WiFi cards and resume. -category: bsd -abstract: FreeBSD has a lot of problems with WiFi card -date: 2023-03-15T09:19:52+01:00 -year: 2023 -draft: false -tags: -- FreeBSD -- Thinkpad -- WiFi -- resume -- Intel -- AX200 ---- -{{<img-pull-right "freebsd-beastie.png" "FreeBSD Bestie">}} -I'm enjoying FreeBSD on my Thinkpad X1 Extreme G2 (and I say the full name just for SEO), but I've encountered my first unsolvable problem. This laptop uses an AX200 WiFi card, which drivers are still far from stable. I don't care much for WiFi AC, even though I'd love to be able to use it. - -The problem is that after resuming (which I assumed I [have already fixed](/2023/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd/)), the connection dies, and it's impossible to reconnect. It is a [known bug](https://wiki.freebsd.org/WiFi/Iwlwifi), and developers are addressing it, but as it stands, all attempts to reestablish connection end in kernel panic. - -Also, this driver is the reason my laptop's fans are doing overwork. - -This situation is something I knew could happen when I first installed FreeBSD. It's far less popular than Linux and therefore has much worse driver support. It is, however, an important factor for any other new joiner to the BSD user group. - -Gambare, [Bjoern A. Zeeb!](https://wiki.freebsd.org/BjoernZeeb) diff --git a/content/bsd/guide/updates/book-update-1.md b/content/bsd/guide/updates/book-update-1.md deleted file mode 100644 index 9e93e347..00000000 --- a/content/bsd/guide/updates/book-update-1.md +++ /dev/null @@ -1,33 +0,0 @@ ---- -title: "Book Update 1" -category: - - bsd - - bsd-guide - - bsd-update -abstract: Work commences -date: 2023-11-07T16:27:40+01:00 -draft: false ---- -As I've mentioned in my last previous [posts](posts), I am now working on a "A Newcomers Guide to BSD" book. - -The book will consist of four parts: - -1. Unix history and philosophy -2. General things that you get with BSD -3. High level overview of the most popular BSDs out there -4. Downsides of BSD - -It's easy to find *great* materials for BSD as long as you are an advanced user. -If you are just starting? -Good luck. -Install a random flavor and try to not get insane trying to piece all of this out. -This is the niche I want to cover, a small intro and a way to promote BSD to people who have no idea what it really is. - -The book will be available in print, from something like [Lulu](https://www.lulu.com/). -There will also be an e-book from e-book retailers, maybe even Amazon. - -The book will however be also free to download as PDF, and (if I find a way), in HTML form. -This is my first date with Latex after all :). - -I am currently studying & writing about *UNIX* history, as this is a necessary (and fascinating) introduction. - diff --git a/content/bsd/jails-usage-examples.md b/content/bsd/jails-usage-examples.md index cfea3983..6b37762b 100644 --- a/content/bsd/jails-usage-examples.md +++ b/content/bsd/jails-usage-examples.md @@ -1,15 +1,18 @@ ---- -title: "Some examples of using Jails" -category: -- bsd -- bsd-update -- update -abstract: How can we use FreeBSD Jails? -date: 2023-12-04T06:04:33+01:00 -draft: false ---- - -Creating Jails in FreeBSD is very easy. ++++ +title = "FreeBSD: examples of Jail usage" +author = ["Michał Sapka"] +categories = ["bsd"] +draft = false +weight = 2001 +abstract = "How can we use FreeBSD Jails?" +[menu] + [menu.bsd-freebsd] + weight = 2001 + identifier = "freebsd-examples-of-jail-usage" + name = "Some examples of using Jails" ++++ + +Creating Jails in FreeBSD is very easy. It takes few minutes to follow the [official handbook](https://docs.freebsd.org/en/books/handbook/jails/) and voilà! We've a dedicated container. But what can we do with it? @@ -19,7 +22,7 @@ Don't want that pesky Pyton? Straight to Jail. Java? Straight to jail! -## Simple jail - Ltex-Ls +## Simple jail - Ltex-Ls {#simple-jail-ltex-ls} I am not a native speaker, so my English skills are far from perfect. My terrible typing skills don't add anything good into the mix. @@ -27,7 +30,7 @@ Therefore, I am in need of a good grammar and spell checker. There is Grammarly, but it's closed source and cloud based. We don't want that. -Luckily an alternative exist - [LanguageTool](https://languagetool.org/pl). +Luckily an alternative exist - [LanguageTool](https://languagetool.org/). It is quite good and can run locally! I use it via an LSP - [Ltex-Ls](https://valentjn.github.io/ltex/ltex-ls/installation.html). Technically it's aimed at Latex, but it can work with any filetype. @@ -37,64 +40,64 @@ I really don't need that on my system. Let's lock it in a jail and allow our NeoVim[^lsp] to use it. [^lsp]: I can, of course, run in any other editor which supports the LSP standard, be it Emacs or some bad one. -First, let's create a Jail and call it `ltex`. +First, let's create a Jail and call it \`ltex\`. For now we can allow it access to the internet, as we will download some files. -{{<highlight shell "linenos=inline">}} +```shell ltex { - ip4 = inherit; - interface = em0; + ip4 = inherit; + interface = em0; } -{{</highlight>}} +``` We will remove network access after we are done with the setup. We don't want any of our writings to leak to the web. Then, let's log into the jail -{{<highlight shell "linenos=inline">}} +```shell doas jexec ltex /bin/sh -{{</highlight>}} +``` and add the dreaded java -{{<highlight shell "linenos=inline">}} +```shell pkg install openjdk-jre -{{</highlight>}} +``` then, let's fetch our latex-ls -{{<highlight shell "linenos=inline">}} +```shell cd /root wget https://github.com/valentjn/ltex-ls/releases/download/16.0.0/ltex-ls-16.0.0.tar.gz tar -xvf ltex-ls-16.0.0.tar.gz -{{</highlight>}} +``` for ease of use, let's remove the version number from the directory -{{<highlight shell "linenos=inline">}} +```shell mv ltex-ls-16.0.0/ ltex -{{</highlight>}} +``` -And our jail is ready, so let's leave it (either `exit` or the good, old Ctrl+d). -We can now open our nvim config file. +And our jail is ready, so let's leave it (either \`exit\` or the good, old Ctrl+d). +We can now open our nvim config file. This is not a guide about this part, so let's just assume you have LSP and LSP-Config intalled. Our config will look like this: -{{<highlight lua "linenos=inline">}} - lspconfig.ltex.setup{ - on_attach = on_attach, - cmd = { "doas", - "jexec", - "ltex", - "/root/ltex/bin/ltex-ls" }, - -- rest of config omitted - } -{{</highlight>}} - -Notice, that we now run the command as root inside the Jail. -It would make sense to allow passwordless-doas to our user due to `doas`. +```lua +lspconfig.ltex.setup{ + on_attach = on_attach, + cmd = { "doas", + "jexec", + "ltex", + "/root/ltex/bin/ltex-ls" }, +-- rest of config omitted +} +``` + +Notice, that we now run the command as root inside the Jail. +It would make sense to allow passwordless-doas to our user due to \`doas\`. I will update this guide if I figure out if we can commit this security nightmare here. But let's go a step further. @@ -102,22 +105,24 @@ Ltex-Ls allows to use machine learning based grammar check based on ngram data. We can add it to our jail. Let's log back in -{{<highlight shell "linenos=inline">}} +```shell doas jexec ltex /bin/sh -{{</highlight>}} +``` -Next we need to fetch the ngram data (you can find it on [LanguageTool website](https://dev.languagetool.org/finding-errors-using-n-gram-data.html). We need to have a `ngrams` folder which contains `en` (as the language shortcut). The ngrams should be inside the `en`. +Next we need to fetch the ngram data (you can find it on [LanguageTool website](https://dev.languagetool.org/finding-errors-using-n-gram-data.html). +We need to have a \`ngrams\` folder which contains \`en\` (as the language shortcut). +The ngrams should be inside the \`en\`. -I propose you move the files to `/var/ngrams/en` inside the Jail. +I propose you move the files to \`/var/ngrams/en\` inside the Jail. -We can now tell `NeoVim` to inform the `ltex-ls` runtime to use the ngrams. +We can now tell \`NeoVim\` to inform the \`ltex-ls\` runtime to use the ngrams. -{{<highlight lua "linenos=inline">}} +```lua -- our old config lspconfig.ltex.setup{ on_attach = on_attach, - cmd = { "doas", - "jexec", + cmd = { "doas", + "jexec", "ltex", "/root/ltex/bin/ltex-ls" }, -- ngram settings added @@ -129,20 +134,20 @@ lspconfig.ltex.setup{ }, }, -- rest of config still omitted -{{</highlight>}} +``` -Note that we instructed the LSP to use `/var/ngrams` folder. +Note that we instructed the LSP to use `/var/ngrams` folder. For program running inside a Jail, the Jail is full system. Even though we can access the ngram data on the host OS under `/jail/containers/ltex/var/ngrams` (depending on your config), for Jail, the `/jail/containers/ltex/` prefix doesn't exist as it points to root for the jail. We can now remove networking from the jail, so our Jail config just defines the existence of the jail -{{<highlight shell "linenos=inline">}} +```shell ltex { } -{{</highlight>}} +``` -And boom. We've got machine language grammar checking which is completely offline and does not pollute our primary system. +And boom. We've got machine language grammar checking which is completely offline and does not pollute our primary system. Our tinfoil friends will be proud of us. [this article will be expanded with more examples in the near future] diff --git a/content/bsd/moved-to-openbsd.md b/content/bsd/moved-to-openbsd.md index 66ec760e..a7037998 100644 --- a/content/bsd/moved-to-openbsd.md +++ b/content/bsd/moved-to-openbsd.md @@ -1,64 +1,101 @@ ---- -title: "Live from OpenBSD in Amsterdam" -category: bsd -abstract: A short info on OpenBSD Amsterdam -date: 2023-07-19T12:27:54+02:00 -year: -draft: false -tags: -- OpenBSD -- httpd -- relayd -- acme -- lets-encrypt -- vps -- amsterdam -- plausible -- plaprox ---- -This site, in its infancy, was running Debian on Linode. Then I moved [^fbsd] to [FreeBSD](https://freebsd.org) on Vultr. Today marks a day of another migration: hello from [OpenBSD](https://www.openbsd.org/) running on [OpenBSD Amsterdam](https://openbsd.amsterdam/).[^bloggers] -[^fbsd]: [Early FreeBSD Thoughts](https://michal.sapka.me/2023/early-freebsd-thoughts/) -[^bloggers]: for technical folks, tinkering with their sites is just as fun as making them. I still have to create a "Yet Another Blog System", but discovering BSD was a great award in itself. - -## OpenBSD - -{{<img-pull-right "openbsd.png" "OpenBSD logo">}} -OpenBSD is one of the three most popular BSD distributions. While [NetBSD](https://www.netbsd.org/) focuses on running on obscure hardware[^netbsd], and [FreeBSD](https://freebsd.org) has ZFS as its killer feature, OpenBSD is all about security[^security]. I was very happy with FreeBSD, but at the same time, I was never fully confident in my ability to configure it securely. Not that my server hosts anything of real value[^mwl-mail], but I still wouldn't like a machine I administer to become a cog in some botnet. Between learning forensics and a new OS, the latter seems nicer. -[^mwl-mail]: at least until "[Run Your Own Mail Server](https://www.tiltedwindmillpress.com/product/ryoms-esponsor/)" finally lands in my digital hands -[^netbsd]: There is a semi-widely known story about running NetBSD on a [toaster](https://www.embeddedts.com/blog/netbsd-toaster-powered-by-the-ts-7200-arm9-sbc/). It may not support a modern WiFi card, but if the device is old, you can run NetBSD on it. -[^security]: At least officially. In reality, I'm test-driving it on my laptop and have much fewer problems than with FreeBSD[^tphistory]. -[^tphistory]: You may want to check my writing about this epic fight - [FreeBSD on Thinkpad X1 Extreme G2](https://michal.sapka.me/2023/freebsd-on-thinkpad-x1-extreme-g2/). - -OpenBSD's official project goal[^goals] states that even though they aim to provide the most secure OS, each developer has their own goals and can freely pursue them as long as the project adheres to these goals. It's a very different approach to what we see anywhere else. There is no 10-year roadmap and constant consultations. Instead, we have a hacker-oriented[^hackathon] culture. This resulted in multiple projects having their inception in OpenBSD, like [OpenSSH](https://www.openssh.com/) or [LibreSSL](https://www.libressl.org/). -[^goals]: [OpenBSD Project Goals](https://www.openbsd.org/goals.html) -[^hackathon]: enough said that OpenBSD coined the term "Hackathon" before corporations stole it - like the internet. - -OpenBSD ships with a secure by-default mindset. All non-essential services are disabled, and those running are using sensible configurations. For example, I had huge problems configuring a firewall on FreeBSD, especially for IPv6[^ipv6]. On OpenBSD, it was much simpler. -[^ipv6]: [Fixing IPv6 and securing the domain](https://michal.sapka.me/2023/fixing-ipv6-and-securing-the-domain/) - -OpenBSD being a BSD, provides a complete system - system and user space are developed together. No GNU tools are needed, as everything comes together. At the same time, BSDs come with a lot of surprising things out of the box. FreeBSD wowed me with Jails[^jail]. -[^jail]: Jails are FreeBSD containerization mechanisms based solely on chroot(8). Ever since I learned how simple it can be, I started vocalizing my disgust for Docker. - -All in all, a lot of things I've learned on FreeBSD are easily transplantable to OpenBSD. They say that all BSDs are separate OSes, a stark difference from distributions of GNU/Linux. I fail to see it, as so much works the same. The package manager of FreeBSD may be more modern, and the separation between system space and user sapce[^hier] is not so evident here, but so many things work the same. I can not pretend to be a pro-BSDer, but I fail to see evidence of them diverging so narrowly to call them completely different OSes. But then again, maybe it's just my poor judgment and love for POSIX. -[^hier]: vide hier(7)of [OpenBSD](https://man.openbsd.org/hier) and of [FreeBSD](https://man.freebsd.org/cgi/man.cgi?hier(7)) ++++ +title = "OpenBSD: Live from OpenBSD in Amsterdam" +author = ["Michał Sapka"] +date = 2023-07-19T22:47:00+02:00 +categories = ["bsd"] +draft = false +weight = 2004 +abstract = "A short info on OpenBSD Amsterdam" +[menu] + [menu.bsd-openbsd] + weight = 2004 + identifier = "openbsd-live-from-openbsd-in-amsterdam" + name = "Forwarding requests from Relayd to a custom webserver" ++++ + +This site, in its infancy, was running Debian on Linode. +Then I moved [^fn:1] to [FreeBSD](https://freebsd.org) on Vultr. +Today marks a day of another migration: +hello from [OpenBSD](https://www.openbsd.org/) running on [OpenBSD Amsterdam](https://openbsd.amsterdam/).[^fn:2] + + +## OpenBSD {#openbsd} + +{{< img-r "openbsd.png" >}} +OpenBSD Logo +{{< /img-r >}} + +OpenBSD is one of the three most popular BSD distributions. +While [NetBSD](https://www.netbsd.org/) focuses on running on obscure hardware[^fn:3], and [FreeBSD](https://freebsd.org) has ZFS as its killer feature, OpenBSD is all about security[^fn:4]. +I was very happy with FreeBSD, but at the same time, I was never fully confident in my ability to configure it securely. +Not that my server hosts anything of real value[^fn:6], but I still wouldn't like a machine I administer to become a cog in some botnet. +Between learning forensics and a new OS, the latter seems nicer. + +OpenBSD's official project goal[^fn:7] states that even though they aim to provide the most secure OS, each developer has their own goals and can freely pursue them as long as the project adheres to these goals. +It's a very different approach to what we see anywhere else. +There is no 10-year roadmap and constant consultations. +Instead, we have a hacker-oriented[^fn:8] culture. +This resulted in multiple projects having their inception in OpenBSD, like [OpenSSH](https://www.openssh.com/) or [LibreSSL](https://www.libressl.org/). + +OpenBSD ships with a secure by-default mindset. +All non-essential services are disabled, and those running are using sensible configurations. +For example, I had huge problems configuring a firewall on FreeBSD, especially for IPv6[^fn:9]. +On OpenBSD, it was much simpler. + +OpenBSD being a BSD, provides a complete system - system and user space are developed together. +No GNU tools are needed, as everything comes together. +At the same time, BSDs come with a lot of surprising things out of the box. +FreeBSD wowed me with Jails[^fn:10]. + +All in all, a lot of things I've learned on FreeBSD are easily transplantable to OpenBSD. +They say that all BSDs are separate OSes, a stark difference from distributions of GNU/Linux. +I fail to see it, as so much works the same. +The package manager of FreeBSD may be more modern, and the separation between system space and user space[^fn:11] is not so evident here, but so many things work the same. +I can not pretend to be a pro-BSDer, but I fail to see evidence of them diverging so narrowly to call them completely different OSes. +But then again, maybe it's just my poor judgment and love for POSIX. And still no SystemD(1) in sight. I don't have enough willpower to learn forensics or Rust, not even to mention an OS-level complex PID1 process. -## OpenBSD Amsterdam +\## OpenBSD Amsterdam -{{<img-pull-right "openbsd-amsterdam.png" "OpenBSD Amsterdam logo">}} -I had a similar exodus of server providers. First, it was Linode, then Vultr. Linode became useless when I wanted to try BSD. Vultr was great as it provided images of FreeBSD and OpenBSD for its VMs. But why stop halfway? Vultr doesn't use BSD as the base system. While it may not be a big deal, I've recently learned of [OpenBSD Amsterdam](https://openbsd.amsterdam/).[^aws] -[^aws]: notice the lack of Amazon Web Services. Screw them. They have almost all of the interwebs in their server farm, but they will not have this blog! +{{< img-r "openbsd-amsterdam.png" >}} +OpenBSD Amsterdam logo +{{< /img-r >}} -OpenBSD Amsterdam is a small company based in (to the surprise of everyone reading this) Amsterdam. What's even better is that they serve OpenBSD VMS from OpenBSD hosts via vmm(4) and vmd(8) - a small virtualization driver baked into OpenBSD. Cool. +I had a similar exodus of server providers. +First, it was Linode, then Vultr. +Linode became useless when I wanted to try BSD. +Vultr was great as it provided images of FreeBSD and OpenBSD for its VMs. +But why stop halfway? +Vultr doesn't use BSD as the base system. +While it may not be a big deal, I've recently learned of[ OpenBSD Amsterdam](https://openbsd.amsterdam/)[^fn:12]. + +OpenBSD Amsterdam is a small company based in (to the surprise of everyone reading this) Amsterdam. +What's even better is that they serve OpenBSD VMS from OpenBSD hosts via vmm(4) and vmd(8) - a small virtualization driver baked into OpenBSD. Cool. What's even cooler is that they give a significant part of their earnings to the [OpenBSD Fundation](https://www.openbsdfoundation.org/). I could not resist, and a day after learning about them, I had already paid for a full year. -## Updates - -2023-12-12: moved info about web stack to a [dedicated article](/bsd/open-bsd-web-stack/) - - +## Updates {#updates} + +2023-12-12: moved info about web stack to a [dedicated article](/bsd/open-bsd-web-stack). + +[^fn:1]: [Early FreeBSD Thoughts](https://michal.sapka.me/2023/early-freebsd-thoughts/) +[^fn:2]: for technical folks, tinkering with their sites is just as fun as making them. + I still have to create a "Yet Another Blog System", but discovering BSD was a great award in itself. +[^fn:3]: There is a semi-widely known story about running NetBSD on a [toaster](https://www.embeddedts.com/blog/netbsd-toaster-powered-by-the-ts-7200-arm9-sbc/). + It may not support a modern WiFi card, but if the device is old, you can run NetBSD on it. +[^fn:4]: At least officially. + In reality, I'm test-driving it on my laptop and have much fewer problems than with FreeBSD[^fn:5]. +[^fn:5]: You may want to check my writing about this epic fight - [FreeBSD on Thinkpad X1 Extreme G2](<https://michal.sapka.me/2023/freebsd-on-thinkpad-x1-extreme-g2/>). +[^fn:6]: at least until "[Run Your Own Mail Server](https://www.tiltedwindmillpress.com/product/ryoms-esponsor/)" finally lands in my digital hands +[^fn:7]: : [OpenBSD Project Goals](https://www.openbsd.org/goals.html) +[^fn:8]: : enough said that OpenBSD coined the term "Hackathon" before corporations stole it - like the internet. +[^fn:9]: : [Fixing IPv6 and securing the domain](https://michal.sapka.me/2023/fixing-ipv6-and-securing-the-domain/) +[^fn:10]: : Jails are FreeBSD containerization mechanisms based solely on chroot(8). Ever since I learned how simple it can be, I started vocalizing my disgust for Docker. +[^fn:11]: : vide hier(7)of [OpenBSD](https://man.openbsd.org/hier) and of [FreeBSD](https://man.freebsd.org/cgi/man.cgi?hier(7)) +[^fn:12]: : notice the lack of Amazon Web Services. + Screw them. + They have almost all of the interwebs in their server farm, but they will not have this blog! diff --git a/content/bsd/open-bsd-7-3-was-released-today.md b/content/bsd/open-bsd-7-3-was-released-today.md deleted file mode 100644 index 0e4c94cc..00000000 --- a/content/bsd/open-bsd-7-3-was-released-today.md +++ /dev/null @@ -1,18 +0,0 @@ ---- -title: "Open Bsd 7 3 Was Released Today" -category: bsd -abstract: New version was released -date: 2023-04-10T19:12:59+02:00 -year: 2023 -draft: false -tags: -- OpenBSD ---- -{{<img-pull-right "open-bsd-7-3.png">}} -A new version of OpenBSD was released today. OpenBSD is the security-focused BSD. - -LibreSSH and OpenSSH were bumped. - -The full [changelog](https://www.openbsd.org/73.html) can be found on the official website. - -As always, there is a [cool artwork](https://www.openbsd.org/images/DryGarden.png). diff --git a/content/bsd/thinkpad/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd.md b/content/bsd/thinkpad/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd.md index e30d3cf1..005a6396 100644 --- a/content/bsd/thinkpad/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd.md +++ b/content/bsd/thinkpad/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd.md @@ -1,36 +1,45 @@ ---- -title: "Fixing Resume on ThinkPad X1 Extreme G2 on FreeBSD due to integrated graphic card" -category: bsd -abstract: you need to load the driver -date: 2023-02-27T10:27:55+01:00 -year: 2023 -draft: false -tags: -- ThinkPad -- FreeBSD -- tutorial ---- -*This applies to FreeBSD 13.1* - -Recently I [posted](/2023/freebsd-on-thinkpad-x1-extreme-g2/) about my problems with FreeBSD. One of them was resume. After installing FreeBSD, I was able to put my laptop to sleep via - -``` ++++ +title = "FreeBSD: Fixing Resume on ThinkPad X1 Extreme G2 due to integrated graphic card" +author = ["Michał Sapka"] +date = 2023-03-16T23:02:00+01:00 +categories = ["bsd"] +draft = false +weight = 2004 +abstract = "you need to load the driver" +[menu] + [menu.bsd-thinkpad] + weight = 2004 + identifier = "freebsd-fixing-resume-on-thinkpad-x1-extreme-g2-due-to-integrated-graphic-card" + name = "Fixing resume due to Intel driver" ++++ + +**This applies to FreeBSD 13.1** + +Recently I [posted](/2023/freebsd-on-thinkpad-x1-extreme-g2) about my problems with FreeBSD. +One of them was resume. +After installing FreeBSD, I was able to put my laptop to sleep via + +```shell acpiconf -s 3 ``` -And this worked fine. However, I was not able to resume it back from sleep. After pressing the power button laptop woke, but the screen was still black. I could `reboot`, and it would work, so only the screen was the problem. +And this worked fine. +However, I was not able to resume it back from sleep. +After pressing the power button laptop woke, but the screen was still black. +I could `reboot`, and it would work, so only the screen was the problem. -After asking about this on [FreeBSD Forums](https://forums.freebsd.org/threads/resume-on-thinkpad-x1-extreme-g2-ends-in-black-screen.88162/), [bsduck](https://forums.freebsd.org/members/bsduck.61635/) and [smithi](https://forums.freebsd.org/members/smithi.71028/) pointed me to dedicated drivers for the integrated Intel GPU. And it worked like a charm. +After asking about this on [FreeBSD Forums](https://forums.freebsd.org/threads/resume-on-thinkpad-x1-extreme-g2-ends-in-black-screen.88162/), [bsdduck](https://forums.freebsd.org/members/bsduck.61635/) and [smithi](https://forums.freebsd.org/members/smithi.71028/) pointed me to dedicated drivers for the integrated Intel GPU. +And it worked like a charm. All I had to do was: +```shell +pkg install drm-kmod +sysrc -f /etc/rc.conf kld_list+=i915kms +reboot ``` -# pkg install drm-kmod -# sysrc -f /etc/rc.conf kld_list+=i915kms -# reboot -``` - -(via [FreeBSD wiki](https://wiki.freebsd.org/Graphics#Intel_Integrated_Graphics_.28aka_HD_Graphics.29)). -Now the computer can sleep and resume without any problems. At least when using [sleep mode 3](https://man.freebsd.org/cgi/man.cgi?acpiconf(8)). The 4th doesn't work for me at all. +(via [FreeBSD Wiki](https://wiki.freebsd.org/Graphics#Intel_Integrated_Graphics_.28aka_HD_Graphics.29)). +Now the computer can sleep and resume without any problems. At least when using [sleep mode 3](https://man.freebsd.org/cgi/man.cgi?acpiconf(8)). +The 4th doesn't work for me at all. diff --git a/content/bsd/thinkpad/fixing-thinkpad-x1-wifi-on-freebsd.md b/content/bsd/thinkpad/fixing-thinkpad-x1-wifi-on-freebsd.md index 5a2fff19..cd9c804b 100644 --- a/content/bsd/thinkpad/fixing-thinkpad-x1-wifi-on-freebsd.md +++ b/content/bsd/thinkpad/fixing-thinkpad-x1-wifi-on-freebsd.md @@ -1,42 +1,68 @@ ---- -title: "Fixing ThinkPad X1 Wifi on Freebsd" -category: bsd -abstract: replacing a wificard fixes everything -date: 2023-08-03T09:35:36+02:00 -year: 2023 -draft: false -tags: -- ThinkPad -- FreeBSD -- Intel -- WiFi ---- -As much as I like FreeBSD, my laptop has mostly sat dormant for the last few weeks. It rocked an AX200, an excellent WiFi adapter unless you want to use it in FreeBSD. There were three reasons for this, with one primary cause: -1. WiFi speeds up to WiFi 2, -2. inability of the system to resume after suspend -3. occasional kernel panics - -Long story short[^wifiart], the firmware is yet to be properly reverse-engineered, and the card is still unsupported[^lies]. The team can't simply copy the Linux driver due to BSD/GPL license incompabilities[^openbsd], so the work needs to continue. -[^wifiart]: Vide [FreeBSD on modern Intel WiFi cards and resume](/2023/freebsd-on-modern-intel-wifi-cards-and-resume/) -[^lies]: technically [it is](https://wiki.freebsd.org/WiFi/Iwlwifi), but no real use case is feasable. -[^openbsd]: The OpenBSD team had no such problems, and the drivers are downloaded during installation and work out of the box. - -Luckily, ThinkPads are still good laptops, and the card was not soldered. So, there was a way: buy a better-supported card and just replace it. - -Unfortunately, Lenovo is not a good company. You can't simply buy any random card matching the port and be sure it will work. The BIOS has a whitelist of supported hardware, and if it detects anything outside of this list, the machine won't boot. - -Lenovo's support proved itself useless. I tried to contact them and get the list of whitelisted WiFi adapters, but at first, they had no idea what am I talking about, and when we finally got on the same page, they started to ignore me. After a few nags met with silence, I just gave up and ordered a used [Intel AC 9260](https://www.intel.com/content/www/us/en/products/sku/99445/intel-wirelessac-9260/specifications.html). - -Have I mentioned that ThinkPads are still good devices? Replacing the WiFi adapter was sparkly[^spark] but easy. Just pop the two antenna connectors, unscrew a single screw, remove the card, and do the same in reverse for the new one. Try to do that with a MacBook![^battery] -[^spark]: don't be a moron like me and disable the internal battery in BIOS before randomly poking the motherboard with a metal screwdriver. -[^battery]: or with battery. I'm replacing mine in a few days. If I went with Apple, I would need to go to a service station as my ungluing skills are nonexistent. - -{{<img-center "intel-ac9260.jpg" "Sitting and working nicely">}} - -Then, with a single reinstall[^reinstall] of the system, everything started working. I'm still limited to WiFi 2, but it works over 5GHz. It's a small problem because my system can finally suspend and resume. I no longer need to power off/power on all the time because it's no longer necessary. I no longer need to be annoyed by the booting speed[^systemd] because it will no longer be a constant sight for me. I also have a (not backed by any analysis) feeling that the laptop runs colder. -[^reinstall]: I'm a simple bare metal guy and was toying with OpenBSD. I don't know if a reinstall would be required if I had a working FreeBSD. -[^systemd]: Which is one of the few good things about [systemd](https://michal.sapka.me/2023/systemd-is-fast/) - -With this, I am now a two BSD[^golang] guy: [OpenBSD](/2023/moved-to-openbsd/) on the server and FreeBSD on the computer. Why not go fully into one? Mostly, BSDs are cool, and it's nice to get to know each other. But also each of them has its strengths and weaknesses. OpenBSD is secure, has httpd/relayd and modern PF[^pf] but a smaller number of ported software, no ZFS, and finding answers on the information highway is more difficult. For a server, those are non-issues, as I have no intention of installing random crap there. But for my computer, I want to experiment more. I will break the system so ZFS will be a great addition. And having more applications ready to `pkg install` will make it this much nicer. -[^golang]: I could have learned to Go, but I chose a totally unmarketable skill for a programmer. I think it makes it even cooler. -[^pf]: I am currently reading "[The Book of PF](https://nostarch.com/pf3)" so I can have any benefit. Great book. Would recommend. ++++ +title = "FreeBSD: Fixing ThinkPad X1 Wifi" +author = ["Michał Sapka"] +date = 2023-08-03T21:40:00+02:00 +categories = ["bsd"] +draft = false +weight = 2001 +abstract = "replacing a wificard fixes everything" +[menu] + [menu.bsd-thinkpad] + weight = 2001 + identifier = "freebsd-fixing-thinkpad-x1-wifi" + name = "Fixing WiFi for good" ++++ + +As much as I like FreeBSD, my laptop has mostly sat dormant for the last few weeks. +It rocked an AX200, an excellent WiFi adapter unless you want to use it in FreeBSD. +There were three reasons for this, with one primary cause: + +1. WiFi speeds up to WiFi 2, +2. inability of the system to resume after suspend +3. occasional kernel panics + +Long story short[^fn:1], the firmware is yet to be properly reverse-engineered, and the card is still unsupported[^fn:2]. +The team can't simply copy the Linux driver due to BSD/GPL license incompabilities[^fn:3], so the work needs to continue. + +Luckily, ThinkPads are still good laptops, and the card was not soldered. +So, there was a way: buy a better-supported card and just replace it. + +Unfortunately, Lenovo is not a good company. +You can't simply buy any random card matching the port and be sure it will work. +The BIOS has a whitelist of supported hardware, and if it detects anything outside of this list, the machine won't boot. + +Lenovo's support proved itself useless. +I tried to contact them and get the list of whitelisted WiFi adapters, but at first, they had no idea what am I talking about, and when we finally got on the same page, they started to ignore me. +After a few nags met with silence, I just gave up and ordered a used [Intel AC 9260](https://www.intel.com/content/www/us/en/products/sku/99445/intel-wirelessac-9260/specifications.html). + +Have I mentioned that ThinkPads are still good devices? Replacing the WiFi adapter was sparkly[^fn:4] but easy. +Just pop the two antenna connectors, unscrew a single screw, remove the card, and do the same in reverse for the new one. Try to do that with a MacBook![^fn:5] + +{{< img-c "intel-ac9260.jpg" >}} +Sitting and working nicely +{{< /img-c >}} + +Then, with a single reinstall[^reinstall] of the system, everything started working. +I'm still limited to WiFi 2, but it works over 5GHz. +It's a small problem because my system can finally suspend and resume. +I no longer need to power off/power on all the time because it's no longer necessary. +I no longer need to be annoyed by the booting speed[^fn:6] because it will no longer be a constant sight for me. +I also have a (not backed by any analysis) feeling that the laptop runs colder. + +With this, I am now a two BSD[^fn:7] guy: [OpenBSD](/2023/moved-to-openbsd) on the server and FreeBSD on the computer. +Why not go fully into one? +Mostly, BSDs are cool, and it's nice to get to know each other. +But also each of them has its strengths and weaknesses. +OpenBSD is secure, has httpd/relayd and modern PF[^fn:8] but a smaller number of ported software, no ZFS, and finding answers on the information highway is more difficult. +For a server, those are non-issues, as I have no intention of installing random crap there. +But for my computer, I want to experiment more. +I will break the system so ZFS will be a great addition. And having more applications ready to `pkg install` will make it this much nicer. + +[^fn:1]: Vide [FreeBSD on modern Intel WiFi cards and resume](_2023/freebsd-on-modern-intel-wifi-cards-and-resume_) +[^fn:2]: technically [it is](<https://wiki.freebsd.org/WiFi/Iwlwifi>), but no real use case is feasable. +[^fn:3]: The OpenBSD team had no such problems, and the drivers are downloaded during installation and work out of the box. +[^fn:4]: don't be a moron like me and disable the internal battery in BIOS before randomly poking the motherboard with a metal screwdriver. +[^fn:5]: or with battery. I'm replacing mine in a few days. If I went with Apple, I would need to go to a service station as my ungluing skills are nonexistent. +[^fn:6]: Which is one of the few good things about [systemd](<https://michal.sapka.me/2023/systemd-is-fast/>) +[^fn:7]: I could have learned to Go, but I chose a totally unmarketable skill for a programmer. I think it makes it even cooler. +[^fn:8]: I am currently reading _[[The Book of PF](https://nostarch.com/pf3)_ so I can have any benefit. Great book. Would recommend. diff --git a/content/bsd/thinkpad/freebsd-configuring-nvidia-and-xorg-on-thinkpad-x1-extreme-g2.md b/content/bsd/thinkpad/freebsd-configuring-nvidia-and-xorg-on-thinkpad-x1-extreme-g2.md index 68254d03..a9e815d4 100644 --- a/content/bsd/thinkpad/freebsd-configuring-nvidia-and-xorg-on-thinkpad-x1-extreme-g2.md +++ b/content/bsd/thinkpad/freebsd-configuring-nvidia-and-xorg-on-thinkpad-x1-extreme-g2.md @@ -1,55 +1,61 @@ ---- -title: "FreeBSD: configuring NVIDIA and Xorg on Thinkpad X1 Extreme G2" -category: bsd -abstract: A tutorial for making Nvidia work on FreeBSD -date: 2023-03-04T04:40:17+01:00 -year: 2023 -draft: false -tags: -- FreeBSD -- NVIDIA -- XOrg -- tutorial ---- -First, the bad news: I could not make FreeBSD work with Hybrid Graphics, so I use only the discrete one. To ensure this, open BIOS and - -1. Configuration -2. Display -3. Graphics Device -4. select `Discrete Graphics` ++++ +title = "FreeBSD: configuring Nvidia and Xorg" +author = ["Michał Sapka"] +date = 2023-03-16T23:02:00+01:00 +categories = ["bsd"] +draft = false +weight = 2005 +abstract = "A tutorial on making Nvidia work" +[menu] + [menu.bsd-thinkpad] + weight = 2005 + identifier = "freebsd-configuring-nvidia-and-xorg" + name = "Setting up Nvidia" ++++ + +First, the bad news: I could not make FreeBSD work with Hybrid Graphics, so I use only the discrete one. +To ensure this, open BIOS and: + +1. Configuration +2. Display +3. Graphics Device +4. select \`Discrete Graphics\` Then, log in as root and install the drivers: -``` -# pkg install nvidia-driver nvidia-xconfig +```shell +pkg install nvidia-driver nvidia-xconfig ``` The next step is to enable the drivers. -``` -# sysrc kld_list+=nvidia -# sysrc kld_list+=nvidia-modeset +```shell +sysrc kld_list+=nvidia +sysrc kld_list+=nvidia-modeset ``` -Some people advise adding Linux (`# sysrc kld_list+=linux`) to kld_list, but I got my GPU working without that. +Some people advise adding Linux (`sysrc kld_list+=linux`) to kld_list, but I got my GPU working without that. After that, either load the drivers manually or give the computer an old, good reboot. Login as root again and use the NVIDIA configurator to get Xorg configured. -``` -# nvidia-xconfig +```shell +nvidia-xconfig ``` -Then try starting your desktop environment, windows manager, or startx. You may be done, but I got an error about `Screen not found`. Tell Xorg where the NVIDIA GPU is if you have the same problem. Try probing the system for GPUs +Then try starting your desktop environment, windows manager, or startx. +You may be done, but I got an error about `Screen not found`. +Tell Xorg where the NVIDIA GPU is if you have the same problem. +Try probing the system for GPUs -``` -# pciconf -l | grep vga +```shell +pciconf -l | grep vga ``` You will see one on more elements on the list. The critical part is in the first column, for example: -``` +```shell vgapci0@pci0:1:0:0 ``` @@ -57,11 +63,11 @@ Our GPU is available under BUS 1:0:0 (we skip the first 0). You may need to try > For PCI/AGP cards, the bus−id string has the form PCI:bus:device:function (e.g., “PCI:1:0:0” might be appropriate for an AGP card). > -> [xorg documentation](https://www.x.org/releases/X11R7.7/doc/man/man5/xorg.conf.5.xhtml#heading10) +> [Xorg documentation](https://www.x.org/releases/X11R7.7/doc/man/man5/xorg.conf.5.xhtml#heading10X) Open `/etc/X11/xorg.conf`, look for `Section "Device"` and add: -``` +```shell BusID "PCI:1:0:0" ``` @@ -69,5 +75,4 @@ In my case, everything worked fine after that. Notes: -I learned the BUS trick from [Nude Systems](https://nudesystems.com/how-to-fix-no-screen-found-xorg-error-on-freebsd/) - +I learned the BUS trick from [Nude Systems](https://nudesystems.com/how-to-fix-no-screen-found-xorg-error-on-freebsd/). diff --git a/content/bsd/thinkpad/freebsd-on-thinkpad-x1-extreme-g2.md b/content/bsd/thinkpad/freebsd-on-thinkpad-x1-extreme-g2.md index c037c68f..9a969979 100644 --- a/content/bsd/thinkpad/freebsd-on-thinkpad-x1-extreme-g2.md +++ b/content/bsd/thinkpad/freebsd-on-thinkpad-x1-extreme-g2.md @@ -1,63 +1,98 @@ ---- -title: "FreeBSD on a Thinkpad Extreme G2" -category: bsd -abstract: it works, but there are some drawbacks -date: 2023-02-25T06:06:18+01:00 -year: 2023 -draft: false -tags: -- FreeBSD -- ThinkPad -- NVIDIA -- ax200 ---- ++++ +title = "FreeBSD: Review of Thinkpad Extreme G2" +author = ["Michał Sapka"] +date = 2023-02-25T22:30:00+01:00 +categories = ["bsd"] +draft = false +weight = 2002 +abstract = "it works, but there are drawbacks" +[menu] + [menu.bsd-thinkpad] + weight = 2002 + identifier = "freebsd-review-of-thinkpad-extreme-g2" + name = "Review" ++++ My wife got a new computer, so I can easily break my laptop whenever I want - so it's time for FreeBSD! -*All this applies to FreeBSD 13.1 at the time of publishing. I'll add links to any additions and errata in the future* +**All this applies to FreeBSD 13.1 at the time of publishing. +I'll add links to any additions and errata in the future** -### Installation -The installation process is great. It's more involved than something like Fedora, and some concepts were foreign to me. [Handbook's chapter on installation](https://docs.freebsd.org/en/books/handbook/bsdinstall/) guided me through every step, so there were no problems. Within 15 mins of booting from the USB Drive, I had a working hardened system running on an encrypted ZFS drive with wireless networking and essential services configured. +## Installation {#installation} -{{<img-center "freebsd-setup-fs.png" "Partitioning" "https://docs.freebsd.org/en/books/handbook/bsdinstall/">}} +The installation process is great. +It's more involved than something like Fedora, and some concepts were foreign to me. +[Handbook's chapter on installation](https://docs.freebsd.org/en/books/handbook/bsdinstall/) guided me through every step, so there were no problems. +Within 15 mins of booting from the USB Drive, +I had a working hardened system running on an encrypted ZFS drive with wireless networking and essential services configured. + +{{< img-c "freebsd-setup-fs.png" "https://docs.freebsd.org/en/books/handbook/bsdinstall/" >}} +Partitioning +{{< /img-c >}} Many things worked out of the box, but not all of them. -### Hardware -Setting X-Org was a breeze. Nvidia drivers are [available and ready to go](https://docs.freebsd.org/en/books/handbook/x11/#x-configuration-nvidia); no additional configuration is necessary. (*[update: I was wrong, but it is fixed now](#updates)*) +## Hardware {#hardware} + +Setting X-Org was a breeze. +Nvidia drivers are [available and ready to go](https://docs.freebsd.org/en/books/handbook/x11/#x-configuration-nvidia) no additional configuration is necessary. +(update: I was wrong, but it is fixed now) -Sound, of all things, work out of the box. Unfortunately, it doesn't auto-switch to headphone output, but there is [a known way to do this](https://freebsdfoundation.org/freebsd-project/resourcesold/audio-on-freebsd/) via device hints. +Sound, of all things, work out of the box. +Unfortunately, it doesn't auto-switch to headphone output, but there is [a known way to do this](https://freebsdfoundation.org/freebsd-project/resourcesold/audio-on-freebsd/) via device hints. -The integrated camera also works after running `webcamd -d ugen0.2 -i 0 -v 0`. Tested via `pwcview.` +The integrated camera also works after running `webcamd -d ugen0.2 -i 0 -v 0`. Tested via `pwcview`. -My laptop uses AX200 wireless card, which is [not yet fully supported by the system](https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=244261). It is recognized and works, but only up to WiFi 3 (g). I'd be ok with WiFi 4(n), but the driver is not ready, and WiFi 5 (AC) [is not supported by the OS](https://wiki.freebsd.org/WiFi/80211ac) at all. Funny enough, it [seems to be supported by OpenBD](https://man.openbsd.org/man4/iwx.4). I have yet to learn how different BSDs intertwine and different. FreeBSD is supposed to be more user-friendly, but it seems not to be the case here. Work on [fully supporting](https://wiki.freebsd.org/WiFi/Iwlwifi) the card is already planned, but I have no idea when I can expect results. From what I've learned, the team can't reuse code from Linux due to licensing incompatibilities between [GPL](https://www.gnu.org/licenses/gpl-3.0.html) and [BSD license](https://docs.freebsd.org/en/articles/license-guide/). ([update: there are more problems](#updates)) -{{<img-pull-right "freebsd-beastie.png" "FreeBSD Bestie">}} +My laptop uses AX200 wireless card, which is [not yet fully supported by the system](https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=244261). +It is recognized and works, but only up to WiFi 3 (g). +I'd be ok with WiFi 4(n), but the driver is not ready, and WiFi 5 (AC) [is not supported by the OS](https://wiki.freebsd.org/WiFi/80211ac) at all. +Funny enough, it [seems to be supported by OpenBD](https://man.openbsd.org/man4/iwx.4). +I have yet to learn how different BSDs intertwine and different. +FreeBSD is supposed to be more user-friendly, but it seems not to be the case here. +Work on [fully supporting](https://wiki.freebsd.org/WiFi/Iwlwifi) the card is already planned, but I have no idea when I can expect results. +From what I've learned, the team can't reuse code from Linux due to licensing incompatibilities between [GPL](https://www.gnu.org/licenses/gpl-3.0.html) and [BSD license](https://docs.freebsd.org/en/articles/license-guide/) [update: there are more problems]. -This is one of the few instances when I am rethinking my life choices, and I would love to be able to help with C code. Also, Bluetooth on this card is not supported, and there is no work done to address it - but luckily, I am already de-wirelessing my life. +{{< img-r "freebsd-beastie.png" >}} +FreeBSD Beastie +{{< /img-r >}} -USB devices are detected automatically and mostly work. However, my monitor (Dell P2723QE) has an integrated 1000Base-T ethernet connection, but on FreeBSD, only 100Base-T worked. +This is one of the few instances when I am rethinking my life choices, and I would love to be able to help with C code. +Also, Bluetooth on this card is not supported, and there is no work done to address it - but luckily, I am already de-wirelessing my life. -Another problem is Suspend/Resume. I can easily [suspend](https://wiki.freebsd.org/SuspendResume) the device, but after resuming it, the screen is still black. This seems to be a known problem across different OSes for this laptop and has some [known warkarounds](https://www.thinkwiki.org/wiki/Problem_with_display_remaining_black_after_resume#Solution_for_ThinkPads_with_Intel_Extreme_Graphics_2) for Linux, but I have no idea how to apply them to BSD. (*[update: there is a fix working](#updates)*) +USB devices are detected automatically and mostly work. +However, my monitor (Dell P2723QE) has an integrated 1000Base-T ethernet connection, but on FreeBSD, only 100Base-T worked. -The biggest problem here is battery drain. I have `power` enabled, but `acpinfo` reports about over 1% per minute. I was getting about the same drain on Arch Linux, but Manajaro acted much better. +Another problem is Suspend/Resume. +I can easily [suspend](https://wiki.freebsd.org/SuspendResume) the device, but after resuming it, the screen is still black. +This seems to be a known problem across different OSes for this laptop and has some [known warkarounds](https://www.thinkwiki.org/wiki/Problem_with_display_remaining_black_after_resume#Solution_for_ThinkPads_with_Intel_Extreme_Graphics_2) for Linux, but I have no idea how to apply them to BSD. [update: there is a fix working] + +The biggest problem here is battery drain. I have `power` enabled, but `acpinfo` reports about over 1% per minute. +I was getting about the same drain on Arch Linux, but Manajaro acted much better. I have not tested the fingerprint reader as I've never used it. -### Conclusion -My ThinkPad is far from being a brick under FreeBSD. It is, however, severely hindered. I plan to fix the memory drain and allow for a resume after suspension. This will make it a proper laptop again, as there are always USB dongles when faster WiFi is needed. Dongle town, however, is not what I want in the long term, and I'll need to follow the progress of the driver implementation closely. +### Conclusion {#conclusion} + +My ThinkPad is far from being a brick under FreeBSD. +It is, however, severely hindered. +I plan to fix the memory drain and allow for a resume after suspension. +This will make it a proper laptop again, as there are always USB dongles when faster WiFi is needed. +Dongle town, however, is not what I want in the long term, and I'll need to follow the progress of the driver implementation closely. It seems that for a desktop computer everything would work. -I'm falling in love with the system and its simplicity and logic. So even if I fail at fixing the above, I'll try to stick with it. And even if I get fed up with the state of hardware support, I'll keep FreeBSD as a secondary system. +I'm falling in love with the system and its simplicity and logic. +So even if I fail at fixing the above, I'll try to stick with it. +And even if I get fed up with the state of hardware support, I'll keep FreeBSD as a secondary system. For personal servers, however, I see no way of abandoning BSD. -### Updates -- 2023-02-27: [Fixing resume due to graphic drivers](/2023/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd/) -- 2023-02-04: [Configuring NVIDIA](/2023/freebsd-configuring-nvidia-and-xorg-on-thinkpad-x1-extreme-g2/) -- 2023-03-15: [Problems with WiFi after resume](/2023/freebsd-on-modern-intel-wifi-cards-and-resume/) +## Updates {#updates} +- 2023-02-27: [Fixing resume due to graphic drivers](/2023/fixing-resume-on-thinkpad-x1-extreme-g2-on-freebsd) +- 2023-02-04: [Configuring NVIDIA](/2023/freebsd-configuring-nvidia-and-xorg-on-thinkpad-x1-extreme-g2). +- 2023-03-15: [Problems with WiFi after resume](/2023/freebsd-on-modern-intel-wifi-cards-and-resume) diff --git a/content/bsd/thinkpad/switching-between-speakers-and-headphones-on-freebsd.md b/content/bsd/thinkpad/switching-between-speakers-and-headphones-on-freebsd.md index 82e842b7..3a0c37dc 100644 --- a/content/bsd/thinkpad/switching-between-speakers-and-headphones-on-freebsd.md +++ b/content/bsd/thinkpad/switching-between-speakers-and-headphones-on-freebsd.md @@ -1,29 +1,31 @@ ---- -title: "Switching Between Speakers and Headphones on FreeBSD" -category: bsd -abstract: How to change the audio device? -date: 2023-03-16T22:52:01+01:00 -year: 2023 -draft: false -tags: -- FreeBSD -- headphones -- speakers -- ThinkPad -- audio -- tutorial ---- -I want my laptop to switch to wired headphones when I attach them. FreeBSD has its own [Sound System](https://wiki.freebsd.org/Sound), so it's a great learning experience. I have yet to automate it (it is possible, but an attempt to do so forced me to do a complete rollback of the system state), but for now, this is working. ++++ +title = "FreeBSD: Switching Between Speakers and Headphones" +author = ["Michał Sapka"] +date = 2023-03-16T23:02:00+01:00 +categories = ["bsd"] +draft = false +weight = 2003 +abstract = "How to change the audio sevices?" +[menu] + [menu.bsd-thinkpad] + weight = 2003 + identifier = "freebsd-switching-between-speakers-and-headphones" + name = "Switching beteen headphnes and speakers" ++++ + +I want my laptop to switch to wired headphones when I attach them. +FreeBSD has its own [Sound System](https://wiki.freebsd.org/Sound), so it's a great learning experience. +I have yet to automate it (it is possible, but an attempt to do so forced me to do a complete rollback of the system state), but for now, this is working. First, check which audio outputs your device supports: -``` +```shell $ cat /dev/sndstat ``` In the case of my ThinkPad, this returns -``` +```shell Installed devices: pcm0: <NVIDIA (0x0094) (HDMI/DP 8ch)> (play) pcm1: <NVIDIA (0x0094) (HDMI/DP 8ch)> (play) @@ -39,13 +41,17 @@ pcm4 - the headphone jack I can now easily switch between them: -``` +```shell # enable speakers $ sysctl hw.snd.default_unit=3 -# enable headphones +# enable headphones $ sysctl hw.snd.default_unit=4 ``` -(replace the value with the correct id from `sndstat` file.) +(replace the value with the correct id from \`sndstat\` file.) -This, however, comes with a huge caveat. Some apps (khem khem, Firefox) not native to FreeBSD come configured with PulseAudio instead of FreeBSD's Sound System. This creates a level of indirection, and changing system output may not work instantly. In the case of Firefox, I need to reload the tab. Some apps, as I've heard, require a restart. +This, however, comes with a huge caveat. +Some apps (khem khem, Firefox) not native to FreeBSD come configured with PulseAudio instead of FreeBSD's Sound System. +This creates a level of indirection, and changing system output may not work instantly. +In the case of Firefox, I need to reload the tab. +Some apps, as I've heard, require a restart. |