Installation-Notes on OpenSuSE Leap 15.6


There's strictly no warranty for the correctness of this text. You use any of the information provided here at your own risk. I can not be held responsible, if you damage your system by using any of the information provided her.


Contents:


1. Introduction

These are my installation notes about the Linux distribution "OpenSuSE Leap 15.6". I installed it in October 2024.

There are also notes on my previous distribution "OpenSuSE 13.1". Here, I've only covered topics, that differ from the old installation. So if something's missing here, take a look at the previous website.


2. UEFI. Using the Distribution's Installer

In most cases, today's PCs come with a UEFI-Bios. It seems, it requires a separate boot partition, which is created by the SuSE installer. There's also a feature called "Secure Boot". that has to be disabled, to boot something else than Windows. I could boot Linux, when setting "Secure Boot" in the Bios/UEFI to "Other OS". It may be possible, that Leap 15.6 could also handle "Secure Boot", but I haven't tried that yet.
Edit: When installing on my other PC, it was necessary to activate "Secure Boot" support in the Linux installation program. Otherwise, the PC wouldn't boot lateron, and I had to reinstall all over again.

When installing Leap 15.4 earlier, I had this problem: The installer couldn't identify my monitor, so it set a bad resolution by default, that caused unwanted lines on the screen.
On the first screen, it was possible to press "e" to configure the boot settings of the installer program. Here, I added the word "nomodeset" to the boot line, that starts with "linux ...". This disables a feature of the kernel called "KMS". The result here was, that a correct resolution was set, and the screen of the installer was fine.

The installer then recognized the network as one of the first steps. Fortunately, it could handle my Wi-Fi-hardware (which the at the moment also recent Puppy Linux distribution "FossaPup64 9.5" couldn't).
When letting the installer fully configure the network, it started installing package updates from internet repositories. Unfortunately, this also installed a new kernel, that didn't work with my system at all. So I had to restart, and then make the installer skip the network-configuration, and install everything from DVD at first. Even with the more recent kernel installed (that didn't work), it was still possible though, to select the previous kernel in the boot-loader menu of GRUB2. So the original kernel wasn't deinstalled. But that was not, what I wanted, so I still skipped network configuration.

Partitioning: I wanted to install Leap on an external USB-hard-drive. So I selected "guided" and chose the wanted hard drive for partitioning. The default suggestions for partitioning would have installed to the Windows hard drive, so that was something to pay attention to.

From the kernel options, I took out the words "splash=silent", "nomodeset" and "quiet".

I deactivated setting up a firewall and AppArmor.

I selected to install a "Xfce4"-system. Xfce4 is a lightweight, but capable window manager.

All in all, I had to try several times, until the installer worked and my settings were the way I wanted them, but in the end it worked.
Edit: On my other PC, I'm using this content in the file "/etc/default/grub" at the moment:

GRUB_DISTRIBUTOR=
# Selection of boot-item in the menu:
GRUB_DEFAULT=0
# Time before booting selected item:
GRUB_TIMEOUT=5
GRUB_CMDLINE_LINUX_DEFAULT="resume=/dev/disk/by-uuid/... preempt=full security=apparmor mitigations=on video=DP-1:640x480@60 video=DP-2:d video=DP-3:d"
GRUB_CMDLINE_LINUX=""
GRUB_TERMINAL="gfxterm"
GRUB_GFXMODE="640x480"
GRUB_BACKGROUND=
GRUB_THEME=
SUSE_BTRFS_SNAPSHOT_BOOTING="false"
GRUB_USE_LINUXEFI="true"
GRUB_DISABLE_OS_PROBER="false"
GRUB_ENABLE_CRYPTODISK="n"

"AppArmor" and Mitigation are activated. This makes the system a bit slower, but it is said that it's the better option for security reasons. "Mitigation" disables some features of the CPU, to make it less vulnerable against socalled "Spectre/Meltdown"-attacks. If performance was really a problem, it would be possible to deactivate these protections again.
The "video="-options in the kernel-line refer to the circumstances on my PC, where I'm using a standard VGA-output called "DP-1". The command "xrandr" would tell you the name of your video output. "video=" leaves "KMS" intact, that is, I'm not using "nomodeset" here (which would deactivate it). Somehow my graphics card seem to need KMS to find the screen resolutions.


3. Setting Screen Resolutions

On first boot, I selected "Settings / Display" from the menu to set the screen resolution. I noticed, that the tool is part of Xfce4, not of YaST2.
I selected the theme "Adwaita light".

Setting the resolution of the displaymanager (the program, that displays the login-screen), was a bit more tricky. In my case, the displaymanager is called "LightDM". To set its resolution, a file

/usr/share/X11/xorg.conf.d/52-myres.conf

can be created, with this content:

Section "Monitor"
    Identifier "HDMI-2"
    Option "PreferredMode" "1280x720"
EndSection

This sets a "preferred resolution", that is respected by LightDM. Use the command "xrandr -q" to find out, which term you have to use for the "Identifier". It's "HDMI-2" in my case, but it may be a different term on your system, depending on the connection to your monitor.
When logged into the X-server afterwards, the command "xrandr -s" can be used to manually change resolutions on the console. Also the selection "Settings / Display" of the Xfce4 menu can be used to do that, making the settings more permanent.

Actually, my monitor has a preferred resolution of "1920x1080". I decided to set this resolution now, and increase all fonts a lot.


4. Soundcard Configuration

The soundcard is setup automatically at startup now, so it seems, the corresponding module of YaST2 isn't used any more. It may even cause conflicts.

Everything is working with "pulseaudio" now.
"alsa" with "alsamixer" is also still available though.

To get the file "/dev/dsp", install the package "alsa-oss...rpm". Actually, also running

modprobe snd_pcm_oss

as root is needed for that. If only "/dev/dsp1" is created then, just create a symbolic link with "ln -s /dev/dsp1 /dev/dsp" as root.


5. Disabling or Deinstalling Expendable Services

I chose "Session and autostart" (German version: "Sitzung und Startverhalten / Automatisch gestartete Anwendungen") from the program menu. Everything except the printer-applet, the network-applet, the Xfce-configuration-service and the Xfce-notification-service wasn't useful to me, so I just deactivated these other services. The bluetooth-stuff may be useful, when bluetooth is used.

The "package update indicator" in the system tray of the task-bar suggested installing lots of updates (because I had installed from the original, older DVD). When I let it do the updates, after reboot the new kernel was started, and nothing worked any more. I then reinstalled the whole system from scratch once more, and deinstalled "package-update-indicator...rpm".


6. Editing Configuration Files

"aliases" can be defined in "/etc/profile.d/alias.bash". But you can also use the tradtitional file "/etc/bash.bashrc.local".


7. Editing Keyboard Shortcuts

The keyboard shortcuts for Xfce4 can be edited in

/home/user/.config/xfce4/xfconf/xfce-perchannel-xml/xfce4-keyboard-shortcuts.xml

But that was actually quite painful this time. So I attach my whole file, that finally worked, here. Rename it accordingly, after making a backup of the original file.

Notice, there's also a file

/etc/xdg/xfce4/xfconf/xfce-perchannel-xml/xfce4-keyboard-shortcuts.xml

If the file in the "/home"-directory doesn't exist, the file from the "/etc"-directory is copied to the "/home"-directory, which may be unexpected.

On OpenSuSE Leap 15.6, it is also possible to install and use LXDE instead of Xfce4 as the window-manager. For setting the keyboard shortcuts in LXDE, I can rely on my old notes about it.


8. Font-Settings in LXDE

This should set most fonts in LXDE:


9. Resizing the Mouse Pointer in LXDE

To set a new size of the mouse pointer in LXDE, change this line in "/home/user/.gtkrc-2.0":

gtk-cursor-theme-size=18

There's a similar line in "/home/user/.config/lxsession/LXDE/desktop.conf":

iGtk/CursorThemeSize=18

Changing the numbers from 18 to 32 and restarting LXDE increases the size of the mouse pointer in a reasonable way (that is, not as much as you would think).


10. Resizing the Icons and Menu Fonts in Firefox

In Firefox 129, the size of the icons in the toolbar (like the icon of the "Home" button) was way too small.

To fix it, I pointed Firefox to "about:config" and searched with the term "devp" for the setting "layout.css.devPixelsPerPx". Default is "-1.0". Setting this value to "2" zoomed the whole user interface including the toolbar icons to 200%.

Now the size of the icons was fine, but the menu fonts were way too big. I went to the profile folder

/home/user/.mozilla/firefox/[somenumbers].default-release

Inside it, I created a new folder called "chrome". I changed to that folder and created a file called "userChrome.css". It had this content:

@namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul");

* {
  font-size: 10pt !important;
}

It is also possible to set a certain font-family by adding for example the line

font-family: DejaVu Sans !important;

inside the curly brackets.
Then I had to make Firefox recognize the file "userChrome.css" at startup. I pointed Firefox to "about:config" and searched with the term "userprof" for the preference "toolkit.legacyUserProfileCustomizations.stylesheets" and changed its value from "false" to "true".

I also changed the "Zoom" setting in the graphical Firefox preferences.
The text of websites can be changed at runtime with "Ctrl++" and "Ctrl+-".

Then I restarted Firefox. That way I finally had suitable sizes of icons and fonts, which is of importance to me.


11. Desktop Messages in LXDE

LXDE makes use of the file manager "pcmanfm". pcmanfm is also responsible for starting applications from desktop icons or for dealing with inserted USB-devices.
If suddenly windows are popping up on the desktop with messages about these kind of processes, you can prevent this by checking the settings in "pcmanfm".


12. Disabling IPv6

IPv6 has something to do with longer web-adresses. When IPv6-support is enabled, it can slow down accessing websites significantly. So when I notice, that the web-browser takes some time before it opens a website, I disable IPv6 on my system.
On Leap 15.6, I added the following lines as root to the file "/etc/sysctl.conf":

net.ipv6.conf.all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
net.ipv6.conf.lo.disable_ipv6 = 1

Then I ran the command

sysctl -p

After that, IPv6-support was disabled, and websited opened quickly again.


13. Fixing Display Access. Setting the Hostname

The "hostname", that is the name of the computer, can be set as root just by typing it into the file "/etc/hostname".

When the error

No protocol specified

appears, when starting window-applications in the terminal, it has something to do with the user not having permission to access the X-server's "display". The error can be fixed, by running the following command as an ordinary user (it's the ordinary user, who is owner of his display):

xhost +local:[hostname or ip]

The hostname can be found in "/etc/hostname" or by running the command "hostname". Just "xhost +" would make the display accessible to everyone (on the internet), so it's better to use the more secure command mentioned above.

Before running the command, it took a very long time to startup Firefox. Afterwards, I didn't get the "No protocol specified"-message any more, and Firefox started quickly again.


14. Enabling Video Players

On OpenSuSE Leap, some video players on websites may not work by default. While Youtube worked in Firefox, I had problems with some other players on websites like "tagesschau.de", "ardmediathek.de" or "tele5.de". The problems occurred only with Firefox, not with Google Chrome. The reason were missing "H.264"-codecs, as explained here.
So I added the Packman repository (which only supports SuSE distributions), and gave it a priority of 90. Then I used YaST2 to install the following packages from Packman: "libavcodec.., libavformat.. and libavdevice..", each followed by several numbers like 56 and 60.
After that, the other video players also worked in Firefox.


15. Installing Important Packages

Some packages, that I consider important, are not installed by default. I installed them lateron:


16. Additional Software

These, I also installed:

Some major applications weren't also installed by default and had to be added:


17. xfce-terminal

"xfce-terminal" is a very nice terminal program:

So that's all pretty nice and made me leave "xterm" behind after having used it for decades.


18. Activating WiFi-USB-Stick "TL-WN823N" - Realtek RTL8192EU

For some reason, I wanted to use WLAN (WiFi) with my SuSE-PC. So I bought a cheap, modern WLAN-USB-stick called "T-Link TL-WN823N (Realtek RTL8192EU)".
At first, it seemed it couldn't get a connection to my router though.
The stick showed up in "lsusb", "iwconfig".

nmcli dev wifi list

showed the available networks. But it still wouldn't connect.

It turned out, the default driver module "rtl8xxxu" isn't sufficient.
A better driver module for this stick called "8192eu" has been written. The source code is available, but compiling may not be that easy.
I found precompiled binaries in a repository of a user named Sauerland. I thought, they wouldn't work, because the file versions didn't seem to correspond directly to the version number of my 15.5 default kernel, and installing new kernel modules is always a delicate process anyway. But to my surprise, it worked with the rpms there, which were called:

rtl8192eu-blacklist-rtl8xxxu-5.11.2.1.git20230622-lp154.2.9.x86_64.rpm
rtl8192eu-kmp-default-5.11.2.1.git20230622_k5.14.21_15.500.24.69-lp154.2.9.x86_64.rpm
rtl8192eu-ueficert-5.11.2.1.git20230622-lp154.2.9.x86_64.rpm

(At some point, I had to use "rpm -i ... --nodeps" to make them install.)
After a reboot, the blacklisting of the "rtl8xxxu"-module took effect, so it wasn't loaded. When I did

modprobe 8192eu

it succeded, and after that, the stick finally connected.


19. Making WiFi-USB-Stick "TP-Link AC600 (Archer T2U)" work - Realtek RTL8821AU

With the cheap WiFi-stick "TL-W823N" mentioned above, WLAN (WiFI) worked in general, but was rather slow, because it didn't support the newer, faster WiFi-protocols.
So I bought another stick called "TP-Link AC600 (Archer T2U)" (also for less than 20,- EUR).
It seems, there can be different kind of chips built into this stick. "lsusb" showed this ID for my stick:

2357:011f

It is said, that this ID refers to the Realtek chip "RTL8821AU".

Again, there are precompiled binaries for OpenSuSE Leap 15.5 in Sauerland's repository. The binaries are compiled from driver-source-code written by "morrownr". The rpm-files in the repository are called:

rtl8821au-kmp-default-20230812_k5.14.21_15.500.22-lp154.9.1.x86_64.rpm
rtl8821au-ueficert-20230812-lp154.9.1.x86_64.rpm

After installing them with "rpm -i ....rpm" and doing a "depmod" as root, I could install the driver with

modprobe 8821au

Then, the WiFi-USB-stick worked, and its performance was alright.


20. Making Changes to Boot Loader Options

Some options of the boot-loader GRUB2 (like for example the look and the resolution of the boot menu) can be changed by editing the file

/etc/default/grub

as 'root'. The changes can then be applied to the system by running the command

update-bootloader

(In the past, the command "grub2-mkconfig -o /boot/grub2/grub.cfg" had to be executed for this step.)

The settings are also taken into account by an installation that uses UEFI.


21. Recording Internal Audio with Pulseaudio and Audacity

Instructions from here.

  1. alsamixer: Enable soundcard recording. Press F4 to go to the recording settings, then press "Space" until "L R Recording" is visible. Set a reasonable volume.

  2. audacity: Go to "Edit/Preferences". Start recording in audacity (select "pulse" as source). (Reason: Only, if audacity is recording, it is shown in pavucontrol).

  3. pavucontrol:

If not, consider creating a pulseaudio loopback device.


22. Make "convert" Convert pdf-Files to jpg-Files

If "convert" doesn't let you convert pdfs to jpgs, add this line to the file "/etc/ImageMagick-7/policy.xml":

<policy domain="coder" rights="read | write" pattern="PDF" />


23. Pipewire, Pulseaudio and Jack

"jack" provides multiple virtual audio connections on the Linux system, mainly for music production. They connect for example synthesizer plugins with audio effect programs and so on.
Unfortunately, pulseaudio (used for general audio like listening to music or watching movies) and jack (used for music production) conflict with each other.
"pipewire" is a layer that is supposed to make them work side by side. On my computer that works alright.
To use pipewire, the packages "pipewire-alsa...rpm", "pipewire-jack...rpm" and "pipewire-pulseaudio...rpm" have to be installed. During installation, the corresponding "pulseaudio"-packages are removed. Nevertheless, pulseaudio (including "pavucontrol") is still there, just as alsa and jack are still there then, but are used in combination with pipewire.
The pipewire-tool "qpwgraph" can show the virtual audio connections. Regarding jack, this tool replaces the traditional "qjackctl".
The command-line commands "jack_control start" and "jack_control stop" can be used to start and stop jack now. It seems though, pipewire starts jack automatically, when programs are started that need it.
After installing pipewire, programs such as "zynaddsubfx" and "hydrogen" worked again.

Using pipewire, I noticed audio lag though, for example with Youtube in Firefox.
Following a suggestion on the internet, I created a directory

/home/user/wireplumber/wireplumber.conf.d

and inside a file "51-disable-suspension.conf", with the following content:

monitor.alsa.rules = [
  {
    matches = [
      {
        # Matches all sources
        node.name = "~alsa_input.*"
      },
      {
        # Matches all sinks
        node.name = "~alsa_output.*"
      }
    ]
    actions = {
      update-props = {
        session.suspend-timeout-seconds = 0
      }
    }
  }
]
# bluetooth devices
# monitor.bluez.rules = [ { matches = [ { # Matches all sources node.name = "~bluez_input.*" }, { # Matches all sinks node.name = "~bluez_output.*" } ] actions = { update-props = { session.suspend-timeout-seconds = 0 } } } ]

That fixed the audio lag, and pipewire works nicely now. The audio-setting applet in the LXDE-bar is missing though, but that's not a problem, as I just can open "alsamixer" in the terminal instead.



Email: hlubenow2 {at-symbol} gmx.net
Back