Realtek Rtl8139 Linux Driver Download

RealTek RTL8101E Free Driver Download for Linux - r1000_v1.05.tgz (850286). World's most popular driver download site. Download the latest version of Realtek RTL8139 810x Family Fast Ethernet NIC drivers according to your computer's operating system.

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:

Well supported kernel releases:

Realtek drivers

Well supported Ubuntu (and Ubuntu-based) releases:

Well supported Fedora (and Fedora based) releases:

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:

--This driver supports following Linux OSes:

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:

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

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):

Realtek 8139 driver

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:

Manual Installation:

To check your kernel version:

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:

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

1. Install build dependencies:

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:

Ex: 'git checkout ubuntu-13.04'

3. Compile:

4. Unload the existing rtl kernel modules.

Realtek Rtl8139 Linux Driver Download

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.

Or tarball it up:

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:

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

(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:

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:

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 BOThere 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:

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:

2. If you get the following error:

After running:

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 you're 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:

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

To check the current Tx power, run:

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):

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

*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):

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:*

or

  • 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:

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

Active5 years, 5 months ago

I'm trying to write driver for rtl8139 for linux 2.6 from scratch. I've already written TX path, but I have some problems with RX.

I put RX into promiscous mode and receiving RX irqs. I set RBSTART into physical address of allocated memory by kmalloc.

I don't know how to find out how many received packets there are and how long they are. I thought that ERBCR, CAPR, CBR registers tell it, but they are 0.

Linux Printer Driver Download

Maybe I'm doing something wrong? How to find out anything about received packets?

user2699113
user2699113user2699113
2,2622 gold badges14 silver badges26 bronze badges

2 Answers

I answer to my question myself.

The received packets are located starting at RBSTART. The first two bytes of rx-ed packet are status bytes, and the next 2 are length of the frame + 4 bytes of crc.

Maybye someone find this info helpful.

Realtek Rtl8139 810x

user2699113user2699113
2,2622 gold badges14 silver badges26 bronze badges

Realtek 8139 Driver

On receiving a packet, the data received from the line is stored in the receive FIFO. When Early Receive Threshold is met, the data is moved from FIFO to Recieve Buffer.

So, once you get an interrupt. You need to check the Interrupt Status Register for ROK. Then check the Early Rx status register which gives you the status of the packet received. If EROK is set, then check the Receive buffer status for ROK. Check for are any errors in the ISR and ERSR. Also check your Rx Configuration register for the threshold configuration for Rx FIFO, RX buf length.

Realtek Drivers

Asha MVAsha MV

Realtek Rtl8161 Driver

Not the answer you're looking for? Browse other questions tagged linuxlinux-kernellinux-device-driver or ask your own question.