• Stars
    star
    476
  • Rank 92,280 (Top 2 %)
  • Language
    C
  • License
    GNU General Publi...
  • Created about 11 years ago
  • Updated almost 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

This modified version of the RealTek WiFi driver fixes some issues with RealTek cards on Linux.

rtl8188ce-linux-driver

This modified version of the RealTek WiFi driver fixes some issues with RealTek cards on Linux.

Why use this driver?

  1. It has been modified to allow you to transmit at up to 33 dBm instead of the stock driver hard limit of 20 dBm, regardless of your CRDA regulatory domain. This is a substantial increase in capability because every 3 dB increase is equivalent to a doubling of the power. IOW, you can pump out 4x more Tx power than before. This is subject to CRDA restrictions however (though you can set that to whatever you want, just make sure you're staying legal)
  2. It has a few default settings that generally increase stability
  3. Some helpful fixes are backported from newer kernels so that they can be enjoyed without upgrading the entire kernel (very useful for staying on your distros current kernel while benefitting from fixes relating to this driver)

Well supported RealTek cards:

    RTL8188CE
    RTL8192CE

Well supported kernel releases:

    3.2.x
    3.8.x
    3.11.x
    3.13.x
    3.14.x
    3.15.x
    3.16.x
    3.17.x
    3.18.x
    3.19.x
    4.0.x
    4.1.x
    4.2.x
    4.3.x
    4.4.x
    4.5.x
    4.6.x
    4.7.x
    4.8.x
    4.9.x
    4.10.x
    4.11.x
    4.12.x
    4.13.x
    4.14.x
    4.15.x
    4.16.x
    4.17.x
    4.18.x
    4.19.x
    4.20.x
    5.0.x
    5.1.x
    5.2.x
    5.3.x
    5.4.x
    5.5.x
    5.6.x
    5.7.x
    5.8.x
    5.9.x
    5.10.x
    5.11.x
    5.12.x
    5.13.x
    5.14.x
    5.15.x
    5.16.x
    5.17.x
    5.18.x
    5.19.x
    6.0.x

Well supported Ubuntu (and Ubuntu-based) releases:

    Ubuntu 12.04 (LTS)
    Ubuntu 13.04
    Ubuntu 13.10
    Ubuntu 14.04 (LTS)
    Ubuntu 14.10
    Ubuntu 15.04
    Ubuntu 15.10
    Ubuntu 16.04 (LTS)
    Ubuntu 16.10
    Ubuntu 17.04
    Ubuntu 17.10
    Ubuntu 18.04 (LTS)
    Ubuntu 20.04 (LTS)
    Ubuntu 22.04 (LTS)

    Elementary OS Luna
    Elementary OS Isis

    Linux Mint 13   Maya (LTS)
    Linux Mint 15   Olivia
    Linux Mint 16   Petra
    Linux Mint 17   Qiana (LTS)
    Linux Mint 17.1 Rebecca (LTS)

Well supported Fedora (and Fedora based) releases:

    Fedora 19
    Fedora 20
    Fedora 21
    Fedora 22
    Fedora 23
    Fedora 24
    Fedora 25
    Fedora 26
    Fedora 27
    Fedora 28
    Fedora 29
    Fedora 30
    Fedora 31
    Fedora 32
    Fedora 33
    Fedora 34
    Fedora 35
    Fedora 36

    Red Hat Enterprise Linux 7.0 (LTS)
    Red Hat Enterprise Linux 7.1 (LTS)
    Red Hat Enterprise Linux 7.2 (LTS)
    Red Hat Enterprise Linux 7.3 (LTS)
    Red Hat Enterprise Linux 7.4 (LTS)
    Red Hat Enterprise Linux 7.5 (LTS)
    Red Hat Enterprise Linux 7.6 (LTS)
    Red Hat Enterprise Linux 7.7 (LTS)
    Red Hat Enterprise Linux 8.0 (LTS)
    Red Hat Enterprise Linux 8.1 (LTS)
    Red Hat Enterprise Linux 8.2 (LTS)
    Red Hat Enterprise Linux 8.3 (LTS)
    Red Hat Enterprise Linux 8.4 (LTS)
    Red Hat Enterprise Linux 8.5 (LTS)
    Red Hat Enterprise Linux 8.6 (LTS)
    Red Hat Enterprise Linux 9.0 (LTS)

    CentOS 7.0 (LTS)
    CentOS 7.1 (LTS)
    CentOS 7.2 (LTS)
    CentOS 7.3 (LTS)
    CentOS 7.4 (LTS)
    CentOS 7.5 (LTS)
    CentOS 7.6 (LTS)
    CentOS 7.7 (LTS)
    CentOS 8.0 (LTS)
    CentOS 8.1 (LTS)
    CentOS 8.2 (LTS)
    CentOS 8.3 (LTS)
    CentOS 8.4 (LTS)
    CentOS 8.5 (LTS)
    CentOS 8.6 (LTS)
    CentOS 9.0 (LTS)

AlmaLinux and Rocky Linux versions that match above CentOS should work fine but are not specifically tested.

Arch is also supported, but tends to break each time the kernel is bumped up a minor version (like 3.13.x to 3.14.x). I try to fix the breakage quickly but this is not how I support my family ;-)

Other RealTek cards, kernel releases, and Linux flavors/releases are supported, but not tested by me (since I don't have them/use them). From the original readme file:

--This driver supports following RealTek PCIE Wireless LAN NICs:

    RTL8188CE/RTL8192CE
    RTL8191SE/RTL8192SE
    RTL8192DE
    RTL8723AE
    RTL8188EE

--This driver supports following Linux OSes:

    Fedora Core
    Debian
    Mandriva
    Open SUSE
    Gentoo
    MeeGo
    android 2.2 (froyo-x86), etc.

Please note that I have only tested the driver on Ubuntu and Fedora (the well supported releases). If you are NOT using Ubuntu, pay close attention to your kernel version when selecting branches. You also need to substitute your package manager whenever you see apt-get install, so Fedora would be dnf install xxx. Most package names are the same but there may be some difference.

Automatic Installation:

There is an install script called install.sh which attempts to automate the manual steps. If the script fails to build and install the driver, you should follow the steps for manual installation.

After cloning this repo, if you want to run the install script, simply run:

./install.sh

If you already have git installed, you can run this one-liner to clone the repo and kick of the automatic install script:

git clone https://github.com/FreedomBen/rtl8188ce-linux-driver.git && cd rtl8188ce-linux-driver && ./install.sh

You may wish to register the modules with DKMS for automatic rebuild when your kernel changes. For that, see the steps for Semi-Automatic Installation (DKMS).

Semi-Automatic Installation (DKMS):

Thanks to saiarcot895 for the initial effort getting this working

You can alternatively use DKMS, so that when a new patch-release of the kernel is released by your distro, you don't have to manually recompile the driver. However, there are a few drawbacks with this method:

  1. You need to know what kernel version you are on.

  2. You need to change the branch when you change the minor version of the kernel (e.g. 3.13.x to 3.15.x).

To use DKMS:

  1. Follow steps 0-2 in the "Manual Installation" section below.

  2. Copy the repo cp -rv . /usr/src/rtlwifi-1.0.0

  3. Run the following command to register the sources with DKMS (the 1.0.0 can be any numbers): (note the period at the end!)

    sudo dkms add rtlwifi/1.0.0 .

  4. Run the following command to build and install the modules:

    sudo dkms install rtlwifi/1.0.0

  5. DKMS should automatically switch you onto the new modules. To verify this, run ./am_i_using_this_driver.sh.

To uninstall and remove the modules from DKMS, run the following command:

sudo dkms remove rtlwifi/1.0.0 --all

Manual Installation:

To check your kernel version:

uname -r

These commands should be typed in an open terminal. I recommend you start in your home directory by typing cd

0. Clone this git repository:

Install git if necessary:

sudo apt-get install git

or

dnf install git

Clone the repo (Basically it makes a copy of the current source code)

git clone https://github.com/FreedomBen/rtl8188ce-linux-driver.git

1. Install build dependencies:

Ubuntu:

apt-get install gcc build-essential linux-headers-generic linux-headers-$(uname -r)

Fedora:

dnf install kernel-devel kernel-headers
dnf groupinstall "Development Tools"
dnf groupinstall "C Development Tools and Libraries"

Arch:

sudo pacman -S git 
sudo pacman -S linux-headers
sudo pacman -S base-devel

2. (Skip unless your first build attempt fails) -> Make sure you are on the correct branch for your kernel version. The branches are named after Ubuntu releases to which they commonly apply, but the most important factor is not the version of Ubuntu, it is the kernel version. There is a script called verify_branch that will help you find the right branch based on your kernel version. When you run "make", the script verify_branch will be automatically called for you. It will recommend to you the best branch for your kernel version. If you tried the recommended branch and your build failed, you may need to try a different one. If so, decline the offer to automatically switch branches for you.

If you need to, you can switch to the correct branch with:

git checkout <branch>

Ex: "git checkout ubuntu-13.04"

Release ver. | *Kernel ver.  | Branch Name
--------------------------------------------
Ubuntu 12.04 | Kernel 3.2.x  | ubuntu-12.04
Ubuntu 13.04 | Kernel 3.8.x  | ubuntu-13.04
Ubuntu 13.10 | Kernel 3.11.x | ubuntu-13.10
Ubuntu 14.04 | Kernel 3.13.x | ubuntu-14.04
Ubuntu 14.10 | Kernel 3.16.x | ubuntu-14.10
Ubuntu 15.04 | Kernel 3.19.x | ubuntu-15.04
Ubuntu 15.10 | Kernel 4.2.x  | ubuntu-15.10
Ubuntu 16.04 | Kernel 4.4.x  | ubuntu-16.04
Ubuntu 16.10 | Kernel 4.8.x  | ubuntu-16.10
Ubuntu 17.04 | Kernel 4.10.x | ubuntu-17.04
Ubuntu 17.10 | Kernel 4.13.x | ubuntu-17.10
Ubuntu 18.04 | Kernel 4.15.x | ubuntu-18.04
Ubuntu 20.04 | Kernel 5.4.x  | ubuntu-20.04
Ubuntu 22.04 | Kernel 5.15.x | ubuntu-22.04
Mint 17      | Kernel 3.13.x | mint-17
--------------------------------------------
Any 3.13.x   | Kernel 3.13.x | generic-3.13.x
Any 3.14.x   | Kernel 3.14.x | generic-3.14.x
Any 3.15.x   | Kernel 3.14.x | generic-3.14.x
Any 3.16.x   | Kernel 3.16.x | generic-3.16.x
Any 3.17.x   | Kernel 3.17.x | generic-3.17.x
Any 3.18.x   | Kernel 3.18.x | generic-3.18.x
Any 3.19.x   | Kernel 3.19.x | generic-3.19.x
Any 4.0.x    | Kernel 4.0.x  | generic-4.0.x
Any 4.1.x    | Kernel 4.1.x  | generic-4.1.x
Any 4.2.x    | Kernel 4.2.x  | generic-4.2.x
Any 4.3.x    | Kernel 4.3.x  | generic-4.3.x
Any 4.4.x    | Kernel 4.4.x  | generic-4.4.x
Any 4.5.x    | Kernel 4.5.x  | generic-4.5.x
Any 4.6.x    | Kernel 4.6.x  | generic-4.6.x
Any 4.7.x    | Kernel 4.7.x  | generic-4.7.x
Any 4.8.x    | Kernel 4.8.x  | generic-4.8.x
Any 4.9.x    | Kernel 4.9.x  | generic-4.9.x
Any 4.10.x   | Kernel 4.10.x | generic-4.10.x
Any 4.11.x   | Kernel 4.11.x | generic-4.11.x
Any 4.12.x   | Kernel 4.12.x | generic-4.12.x
Any 4.13.x   | Kernel 4.13.x | generic-4.13.x
Any 4.14.x   | Kernel 4.14.x | generic-4.14.x
Any 4.15.x   | Kernel 4.15.x | generic-4.15.x
Any 4.16.x   | Kernel 4.16.x | generic-4.16.x
Any 4.17.x   | Kernel 4.17.x | generic-4.17.x
Any 4.18.x   | Kernel 4.18.x | generic-4.18.x
Any 4.19.x   | Kernel 4.19.x | generic-4.19.x
Any 4.20.x   | Kernel 4.20.x | generic-4.20.x
Any 5.0.x    | Kernel 5.0.x  | generic-5.0.x
Any 5.1.x    | Kernel 5.1.x  | generic-5.1.x
Any 5.2.x    | Kernel 5.2.x  | generic-5.2.x
Any 5.3.x    | Kernel 5.3.x  | generic-5.3.x
Any 5.4.x    | Kernel 5.4.x  | generic-5.4.x
Any 5.5.x    | Kernel 5.5.x  | generic-5.5.x
Any 5.6.x    | Kernel 5.6.x  | generic-5.6.x
Any 5.7.x    | Kernel 5.7.x  | generic-5.7.x
Any 5.8.x    | Kernel 5.8.x  | generic-5.8.x
Any 5.9.x    | Kernel 5.9.x  | generic-5.9.x
Any 5.10.x   | Kernel 5.10.x | generic-5.10.x
Any 5.11.x   | Kernel 5.11.x | generic-5.11.x
Any 5.12.x   | Kernel 5.12.x | generic-5.12.x
Any 5.13.x   | Kernel 5.13.x | generic-5.13.x
Any 5.14.x   | Kernel 5.14.x | generic-5.14.x
Any 5.15.x   | Kernel 5.15.x | generic-5.15.x
Any 5.16.x   | Kernel 5.16.x | generic-5.16.x
Any 5.17.x   | Kernel 5.17.x | generic-5.17.x
Any 5.18.x   | Kernel 5.18.x | generic-5.18.x
Any 5.19.x   | Kernel 5.19.x | generic-5.19.x
Any 6.0.x    | Kernel 6.0.x  | generic-6.0.x

* Note, if the Ubuntu/Mint release version and your kernel version conflict,
  go with the branch corresponding to your *kernel version* as
  that is what really matters!

3. Compile:

make

4. Unload the existing rtl kernel modules.

lsmod | grep ^rtl | awk '{print $1}'                             // to list the modules
sudo modprobe -r $(lsmod | grep ^rtl | awk '{print $1}' | xargs) // To unload them

4.5. (Optional) Backup stock drivers

You may wish to make a backup of your stock drivers in case you need to restore them. This is done for you automatically by the install script but the truly paranoid may wish to do it themselves as well.

cp -r /lib/modules/$(uname -r)/kernel/drivers/net/wireless/rtlwifi ~/

Or tarball it up:

tar -czf "~/rtlwifi.tar.gz" -C "/lib/modules/$(uname -r)/kernel/drivers/net/wireless/rtlwifi" .

Important: When restoring this backup manually, make absolutely sure you are putting it back in to the exact same kernel version. Failure to do this properly may result in an unbootable system. I suggest you let the script do your backups automatically and use this as a last resort.

5. Install:

sudo make install

6. Modprobe in the new driver (if you're not using an RTL8188CE or RTL8192CE, adjust accordingly):

sudo modprobe rtl8192ce 

(rtl8192ce is the driver for the RTL8188CE card also)

7. The rtl8192ce should load all modules it depends on (rtlwifi, rtl8192c_common, mac80211, cfg80211, etc.), but if it doesn't work you may need to modprobe back in the other modules too. Common modules:

rtl8192ce, rtlwifi, rtl8192c_common, mac80211, cfg80211

NOTE: Unlike the stock driver, rtl8192c_common is only required with kernel >= 3.14

8. Make persistent by adding this to the end of /etc/modules (for Ubuntu), or /etc/rc.modules (for Fedora) (if Fedora make sure /etc/rc.modules is executable), or /etc/modules-load.d/rtlwifi.conf (for Arch). If you don't have an RTL8188CE or RTL8192CE, then substitute the correct kernel module in place of rtl8192ce:

rtl8192ce

NOTE: By "make persistent", I mean making the loading of the RLT8192CE kernel modules happen automatically at boot time so you don't have to modprobe them in yourself. If udev is seeing your Realtek card (which is usually the case), then it will load the kernel modules for you without this, but putting this in hurts nothing.

You may want to verify your CRDA domain. For example if you were in Bolivia it would be: iw reg set BO There is more information about CRDA available at: http://ttys1.wordpress.com/2012/04/12/fixing-regulatory-domain-crda-of-realtec-wireless-device-drivers/

Troubleshooting:

0. To check whether you are running this driver or not, run the script:

./am_i_using_this_driver.sh

1. If you have loaded the kernel modules (with modprobe) and you are using this driver (check with the script in step 0), and you still have no connection, try restarting wpa_supplicant. If you use systemd:

sudo systemctl restart wpa_supplicant

2. If you get the following error:

FATAL: Error inserting rtl8192ce (/lib/modules/3.8.0-34-generic/kernel/drivers/net/wireless/rtlwifi/rtl8192ce/rtl8192ce.ko): Invalid argument

After running:

modprobe rtl8192ce 

You may have invalid configuration options in /etc/modprobe.d/rtl8192ce.conf. You can either remove the file or remove any options that are not supported.

3. If your connection seems unstable:

This driver has been modified to allow up to 33 dBm Tx power (instead of the stock driver limit of 20). This allows you to crank up the Tx power, which vastly improves performance for me.

To do this, your CRDA regulatory domain must allow it. You need to be aware of the laws that govern your local area so you are not in violation. If you do this, you assume all legal liability for your actions. Also, don't crank your Tx power up to 33 dBm when you're sitting right next to your router. Almost all wireless routers have AGC built-in that will save them from hot transmitters, but it is better to try not to fry the receiver. Keep in mind that you're hacking your wi-fi card to bypass the normal safety net(s) that prevent us from doing cool stuff.

A very lenient CRDA domain is Bolivia (BO) that will let you up to 33 dBm. To set Bolivia, run the following:

sudo iw reg set BO

To turn up the Tx power, run this (substitute your wireless interface name for and desired power level for ):

sudo iwconfig <if-name> txpower <value>

E.g.:

sudo iwconfig wlan0 txpower 33

To check the current Tx power, run:

iwconfig <if-name> | grep "Tx-Power"

The current Tx power will be listed as Tx-Power=xx dBm

4. If you're getting power drops*:

You may have better luck fixing your data rate. The best rate will vary depending on your Tx power, Rx power, and distance from the router. You may want to set the rate to be fixed at a speed similar to your internet connection speed unless you're doing other stuff on your LAN. Basgoosen found his sweet spot to be 24M. You can set the fixed rate as follows (substitute your wireless interface for <wlan>, so for example wlan0):

sudo iwconfig <wlan> rate fixed
sudo iwconfig <wlan> rate 24M
sudo iwconfig <wlan> bit fixed
sudo iwconfig <wlan> bit 24M

To make this persistent, create a file in /etc/network/if-up.d containing the following (substitute your wireless interface for <wlan>!):

#!/bin/sh

if [ "$IFACE" = "<wlan>" ]; then
    sudo iwconfig <wlan> rate fixed
    sudo iwconfig <wlan> rate 24M
    sudo iwconfig <wlan> bit fixed
    sudo iwconfig <wlan> bit 24M
fi

*Thanks to basgoosen for this suggestion

5. My kernel package was updated by my distro and now I'm stuck back on the stock driver!

Yeah unfortunately this does currently happen anytime your kernel package is updated by your distro. The solution is to rebuild and reinstall this driver. On the plus side that gives you a chance to pull down the latest changes so that you're up to date.

Please don't save a copy of the drivers compiled under a different version of the kernel to copy back in after the kernel update. While a clever solution, this could cause undefined and potentially disastrous results if the ABI changes (which it does frequently). The drivers need to be rebuilt using the new kernel headers to ensure they are compiled correctly. It may work fine for a few upgrades, but eventually it will leave your system unbootable.

You can run this command to automatically clone this repo and kick off the installer (git must be installed already):

git clone https://github.com/FreedomBen/rtl8188ce-linux-driver.git && cd rtl8188ce-linux-driver && ./install.sh

You might also consider using DKMS if your kernel changes often. There are instructions near the top of this README.

6. I think this driver broke something. How do I get back to the stock driver?

You basically have two choices. Either will get the job done. When you run sudo make uninstall, the make script will try to restore your backup from when you installed. The system works like this:

  • When you run sudo make install, the existing drivers are backed up to ~/.rtlwifi-backups as a precaution (this is new as of 29-May-2014, so if you installed before then, you have no backups. Sorry)
  • When you run sudo make uninstall, this location is checked for a backup that matches your current kernel version. If one cannot be found, then you are stuck with choice #2. If a suitable backup is found, the script will offer to restore it for you.

Choice #1 - Use the backup that the install script made for you:*

sudo make uninstall

or

./restore_backup.sh
  • Note that this will look in the home directory of whichever user you are when you run it, so if it doesn't see a backup, try it again with sudo so that it will check root's home directory, or as a regular user so it will check that user's directory.*

Choice #2 - Reinstall your distro's kernel package:

This obviously varies by distro. For Ubuntu, try:

sudo apt-get install --reinstall linux-image-extra-$(uname -r)

Please consider reporting the failure (or even better, send a pull request), so I can try to fix it.

More Repositories

1

awk-hack-the-planet

Source code repo for Ben Porter (FreedomBen)'s free course on Awk (originally a talk at Linux Fest Northwest 2019 and 2020)
Ruby
185
star
2

dory

Your development proxy for docker
Ruby
152
star
3

screen-for-OSX

A version of screen that supports vertical splitting, ready for building on OSX
C
46
star
4

clipgrab

Customized version of ClipGrab (http://clipgrab.org/)
C++
38
star
5

canvas-development-tools

Some handy scripts that I use to make life better while working on Canvas by Instructure
Shell
36
star
6

handy-bash-scripts

Collection of some handy Bash scripts for doing common tasks
Shell
19
star
7

slackbot_frd

The source code for the slackbot_frd gem
Ruby
10
star
8

outcomes-import-tool

A simple command line client to facilitate the scheduling of outcomes imports
Go
6
star
9

metals

Drop-in mTLS solution for any HTTP service running in a Pod!
Shell
6
star
10

findref

findref is a grep-like program that helps you find strings in files using regexes
Go
5
star
11

malan

An "authentication" service which you can add to your eco-system and use via API, or you can fork and use as the basis of a new Phoenix application
Elixir
5
star
12

docker-janitor

Ruby
5
star
13

angelbot

Angelbot!
Ruby
4
star
14

terminator

This is a branch of the official Terminator release 0.97
Python
4
star
15

nexy

Source code for nexy, the Simple Nexus Slack bot
Ruby
4
star
16

arch-linux-install-scripts

Contains a series of Bash scripts to automate the setup of an Arch Linux system
Shell
3
star
17

slack_proxy3

Elixir
3
star
18

slack_proxy

A simple proxy for posting messages to slack
Elixir
2
star
19

openshift-install-checklists

Some handy checklists to use when installing OpenShift or OKD
2
star
20

nginx-docker

Adds autoindex to the official nginx image
Dockerfile
2
star
21

gimme-dat-canvas

A stupid-easy Canvas Appliance, dockerized no less
Shell
2
star
22

2048-docker

C
2
star
23

digall

Shell
2
star
24

lds-quotes

Get inspirational LDS quotes in your terminal!
HTML
2
star
25

privatebin-setup

Handy scripts to help set up privatebin on a VPS
Shell
1
star
26

metals-example

Example HTTP Service that uses MeTaLS for drop-in mTLS
Shell
1
star
27

kdbook

Source code for the kdbook gem
Ruby
1
star
28

rafflebot

This is a raffle bot built on top of the slackbot_frd gem
Ruby
1
star
29

privatebin-nginx-proxy

Shell
1
star
30

tls-cert-generator

Ruby
1
star
31

rtlwifi-freedom-tool

This tool allows for simplified configuration and troubleshooting of RealTek cards
Python
1
star
32

http-echo-server-docker

Dockerfile
1
star
33

basic-ocp-demo

Sample app that can be easily deployed to OpenShift either as a training exercise or demonstration.
Shell
1
star
34

infa719-game-tracker

The repository housing the code for the web app developed by Team Farfan-Quiroz, Anderson, and Porter
Python
1
star
35

hash-dot-evil

A version of the hash-dot gem that warns you about exposed AWS creds
Ruby
1
star
36

aescrypt

This repository houses the source code for AES Crypt. This is not an official AES Crypt repository. Please visit http://www.aescrypt.com/ for more information.
C
1
star