Share your knowledge at the LQ Wiki.
Go Back > Blogs > The Slacker's Blog
User Name


This is a semi-random collection of posts on nearly all things Slackware and Linux-related -- at least as I see it.
Rate this Entry

Slackware “Clean Upgrade” (with pre- and post-installation tasks)

Posted 01-13-2013 at 10:14 PM by Lufbery
Updated 01-13-2013 at 10:22 PM by Lufbery


Slackware is perfectly usable from a fresh (full) installation with only two essential tasks to perform after the installation is complete:
  1. creating an initial RAM disk (using mkinitrd) so that one boots to the generic kernel, and
  2. creating at least one non-root user (using adduser).

Everything else — installing additional software, setting up e-mail, etcetera — is really personalizing and/or customizing to suit one’s own tastes and needs.

Upgrades, rather than clean installations, of Slackware are a slightly different story. An upgrade removes packages no longer needed, updates packages for the new version of Slackware, and adds new packages. What it does not do (and rightly so!) is move/delete/mangle/otherwise modify user data and settings. An upgrade also does nothing to installed packages that are not part of the default Slackware distribution.

I suspect that for most people under most circumstances, upgrading from one version of Slackware to the next, using the upgrade instructions that come with Slackware (or using Slackpkg to accomplish the same thing), is painless. In my experience, nearly all non-Slackware software that I’ve built and installed for one version of Slackware works perfectly well in the next version of Slackware. Similarly, nearly all user-specific settings translate well from the previous version to the next. The major exception seems to be KDE, which really benefits from deleting the users’ hidden configuration directories prior to launching the updated version because settings from a previous version can cause strange behavior in newer versions.

Over time, at my house, a particular Slackware installation becomes somewhat messy. I’ll install software that I end up not using. Sometimes I will uninstall it, sometimes I won’t. I tweak a setting here or there, make some changes to accommodate my wife’s needs on the computer, etc. The end result is that the users’ home directories get crowded with hidden directories and files that are orphaned or (at the very least) no longer useful. When a new Slackware version eventually comes out, I find that what I really want is a clean installation that preserves all user data and only certain important system and user settings — I call it a “clean upgrade.”

Here’s a way to do just that.

Brief Overview of Upgrade Methods

Leaving aside the very first, virgin installation of Slackware on one or more new partitions, where one creates the non-root user for the first time (which for me was with Slackware 11, right after Pat released it), there are a few ways to upgrade from one Slackware release to the next. There seem to be two major methods (upgrade and clean installation), with many variations. I will only cover the two major ones and a single variation:

1) Upgrade according to the instructions in UPGRADE.TXT.

In a nutshell, go down to telinit 1, run upgradepkg several times in a specific order, remove obsolete packages, and check one’s configuration files. This method works very well (as noted above).

However, this method does leave all the non-default applications and potentially useless settings intact.

Note: From what I understand, Slackpkg pretty much does the process outlined in UPGRADE.TXT as part of its upgrade routine, but the process is automated.

2) Do a clean installation on a freshly formatted partition, but keep your /home and /root directories on separate partitions.

During the installation process, point to those directories, but don’t format them. After the installation, you may need to recreate your non-root users, but if you give them the old /home directories (e.g. /home/drew), then you get them back with all their data and settings.

(As an aside, one way to avoid recreating your users that has worked in past versions of Slackware is to copy backed-up versions of /etc/group, /etc/passwd, and /etc/shadow over the new ones created during the clean installation.)

The advantage of this method is that it wipes out all the non-default packages that I installed _and_ all the non-default settings. It is, for me anyway, often much easier to reinstall additional packages that I need (sometimes recompiling and upgrading in the process), and set/reset a small handful of configuration files than to clean up the cruft from the prior year and half since the previous upgrade.

The problem is that most user-specific application and desktop settings are in hidden files in the /home/_user_ directory. So even a clean installation results in the retention of cruft

3) A modification of the second method, the “clean upgrade.”

For a “clean upgrade,” one backs up the /root, /home, and /etc directories, creates new ones as part of a clean install, and then copies back the data files (i.e. papers, photos, music, etc.) and a few very valuable configuration files.

After six upgrades from 11.0 to 13.37, on two different computers, I’ve found the third method is the one that I prefer.

Specific Procedures

Having said that, upgrades are few and far between. I usually upgrade a month or two after a new Slackware release comes out. I perform most of the same tasks each upgrade. Upgrades happen so infrequently that I have to make notes during one upgrade to remind me of tasks to do during the next upgrade.

I maintain two computers at home: a relatively powerful desktop that the whole family uses and an older Pentium III IBM laptop that I use when other people are on the desktop computer. I use SSL and X-forwarding ( to access the desktop from my laptop.

What follows are my notes on the pre- and post-installation tasks for Slackware_13.37 (32-bit) on my IBM A22m Laptop. The procedures for the desktop are similar, and most of these tasks haven’t changes much from one Slackware version to the next.

Pre-Installation Backup
First, I backed up to an external hard drive the /root, /home, and /etc directories from my 13.1 installation. This preserves all the data and hidden files. The most important (in my opinion) configuration files are listed below.

For each user:
  • .bashrc
  • .bash_profile
  • .emacs
  • .mozilla directory (preserves bookmarks and settings for Firefox and Seamonkey)
  • .thunderbird directory (preserves all my users’ e-mails)
  • GNUstep directory where I have my settings for WindowMaker.
  • /root also has the SBo packages I've compiled in the past.

There may be others, .opera for instance, that users need to maintain continuity between one version of Slackware and the next.

For the system as a whole, I’m most interested in preserving:
  • /etc/rc.d/rc.keymap
  • /etc/rc.d/rc.local
  • /etc/X11/xorg.conf.d/20-thinkpad.conf (activates the scroll button on my Thinkpad)
  • My customized emacs keymap (save in my /root directory), which changes the Caps Lock key to a Control key. It gets copied to /usr/share/kbd/keymaps/i386/qwerty/ after the clean installation.

Prior to installation, rename /home/user directories to /home/old-drew, etc.

During the Installation
Then I install Slackware as a clean installation.

The most important point is that I do not format /root and /home partitions, which I keep on separate partitions. That way, the clean installation does not alter or destroy my users’ data and settings. The back-up I made above is very useful, but it _is_ as backup. Restoring user data and the key settings should not require using the backup.

After-installation Tasks
With the clean installation completed and me safely booted into my brand new, sparkling fresh Slackware installation, there are a few tasks to finish the update, restore the user settings, and get back to work.

The third and fourth steps are where the bulk of the user and system settings and data are restored. The remainder of the steps are common post-installation tasks that I do for nearly every new Slackware installation, regardless of how I upgrade.

1. Create an initrd
Run /usr/share/mkinitrd/, then run the command that is generated. Edit lilo.conf so I can boot the generic kernel and my LFS installation.

2. Create my non-root user(s)
As root, I either use the adduser script, or I start X windows (using TWM, which is a dead simple WM, but has little overhead and doesn’t load a lot of processes) and use kuser to create my non-root users and assign them to groups. Be sure to check CHANGES_AND_HINTS.TXT to see if your users need to be part of any specific groups.

3. Copy over many (but not all) the data from my root and non-root users' home directories.
Log in as each non-root user and copy the data and configuration files (which are usually hidden) from the /home/old-USER to /home/USER directories. Although I’m not sure how much it matters, I prefer to stay out of X while doing this. Midnight Commander is a great tool for doing the copying from one directory to the other. I keep my /home/old_USER directories around for a while just in case I want or need a particular hidden file from the previous installation at a later date.

4. Install my custom console keymap.
First I copy my backed-up custom keymap ( into the directory:


Then I copy my backed-up rc.keymap (that loads the custom key map) to /etc/rc.d/rc.keymap. Make sure that it’s executable.

Everything after this point is the basic post-installation routine that I’ve developed over time.

5. Install Wicd.
I use Wicd on my laptop. I may try Network Manager with Slackware 14, but I’m very happy with Wicd and am reluctant to change.

6. Use Slackpkg to get the latest updates.
By the time I install the latest version of Slackware, there are usually a few updates. Slackpkg makes quick work of getting and installing the latest updates after I’ve configured it to use a good repository for the proper Slackware version.

7. Install Sbopkg
Now is as good a time as any to install Sbopkg and set it up. There are some common software packages I like to build fresh each time I upgrade — especially the Nvidia drivers.

7. Video Setup Tasks
On my desktop computer, I install the Nvidia drivers using the SlackBuilds for them via Sbopkg.

With the upgrade to 13.37, KDE would not start on my laptop. As usual, CHANGES_AND_HINTS had the answer: I had to follow the instructions in to disable compositing with the correct LILO switch. I’m not sure if that will be needed with the latest version X in Slackware 14.

8. Setup the temperature, fan, and cpu sensors.
Run as root, 'sensors-detect'. The results gave me information on the type of drive to use.

This was the important part of that test.

Do you want to probe the I2C/SMBus adapters now? (YES/no): yes
Using driver `i2c-piix4' for device 0000:00:07.3: Intel 82371AB PIIX4 ACPI
Module i2c-dev loaded successfully.
I added that driver to my rc.local:

# /etc/rc.d/rc.local:  Local system initialization script.
# Put any local startup commands in here.  Also, if you have
# anything that needs to be run at shutdown time you can
# make an /etc/rc.d/rc.local_shutdown script and put those
# commands in there.

# This clears the /tmp directory.
rm -R -f /tmp/*

# This is loads the module for temp. sensors.
modprobe i2c-piix4
Notice, I also clear out the /tmp directory.

9. Setup the firewall
The best way I’ve found to tackle this task is with Alien BOB’s firewall generator:

10. Standard KDE preferences configuration
I disable Nepomuk, Akonadi, and Strigi using these instructions: (

With that done, KDE 4.x runs smoothly and quickly on my Pentium III laptop.

11. Install extra software
This is the realm of personal preference. Many of these packages I get from Others I get from Alien Bob’s or Robby Workman’s repositories. All Slackware users really owe Robby, Eric, Chess, and others a deep debt of gratitude for not only contributing to Slackware, but also maintaining all the extras. The following are what I consider essential packages:
  • Corefonts package (be sure to run fc-cache -f after installing it)
  • IcedTea/OpenJDK
  • Clamav
  • VLC (AlienBob’s unrestricted)
  • LibreOffice (Alien Bob or SlackBuild)
  • Tint2
  • Dosbox

12. Correct the documentation of coreutils
Replace fileutils, sh-utils, and textutils to coreutils in /usr/info/dir

13. Setup the IBM scroll button
Created /etc/X11/xorg.conf.d/20-thinkpad.conf based on the instructions at

14. Set caps lock as a control key in WMs/DEs other than KDE
I sometimes have need of a very light-weight window manager. However, only KDE has a system setting for setting caps lock as another control key. So I cobbled together a very small script that I can run to get that setting no matter what WM I use:


/usr/bin/setxkbmap -option "ctrl:nocaps"
15. Fix the problem in XFCE where it shows the default icon for files and folders.
The fix is to specify an icon theme in the file, ~/.gtkrc-2.0. For example to use the Tango icon theme add a line:
gtk-icon-theme-name = "Tango"
to ~/.gtkrc-2.0 (just create the file if it does not exist).

More info on the issue is here.

I don’t know if this is a problem with the version of XFCE in Slackware 14.

That's it in a (somewhat large) nutshell. There are probably some steps that I missed, but I think these are the major ones. I hope this post is helpful.
Posted in Uncategorized
Views 1805 Comments 2
« Prev     Main     Next »
Total Comments 2


  1. Old Comment
    I noticed no one had commented on this nicely presented set of instructions so I wanted to give you a thumbs up on what you wrote up. A friend of mine instructed me on this method of upgrade a while back when I jumped from Slackware 11 to 12. I am about to go from 13 to 14 and could not find his instructions so this post really helped me out. This post was way more detailed however much of it might not apply but it is still worth having.

    I am a little more paranoid so before I upgrade I also ghost my drives using dd or fsarchiver so that I can do a full recovery if something goes wrong. I also do this in case of a hard drive going bad ... which almost never happens ;^)

    Posted 02-20-2013 at 03:00 PM by cygnus-x1 cygnus-x1 is offline
  2. Old Comment
    If you are upgrading to the very next version (eg 13.37 to 14.0) I suspect that there is not very much difference between following UPGRADE.TXT and your third method. However, many of the steps you list in your third method make sense to follow which ever method you upgrade with.

    One advantage of following UPGRADE.TXT is that new /etc configuration files are copied and given the extension *.new. If I run diff somefile (something UPGRADE.TXT doesn't say to do) I can examine the output and then decide whether to switch to the .new file, keep the old file or just incorporate some of the changes from the new file into the old file. This helps to ensure that I don't run into problems because of some customization that I forgot about in a new installation.
    Posted 02-21-2013 at 11:03 PM by psionl0 psionl0 is offline
    Updated 02-21-2013 at 11:06 PM by psionl0


All times are GMT -5. The time now is 01:37 AM.

Main Menu
Write for LQ is looking for people interested in writing Editorials, Articles, Reviews, and more. If you'd like to contribute content, let us know.
Main Menu
RSS1  Latest Threads
RSS1  LQ News
Twitter: @linuxquestions
Facebook: linuxquestions Google+: linuxquestions
Open Source Consulting | Domain Registration