20171104

Logitech G920 Steering Wheel on Linux - Ubuntu 16.04, Linux Mint 18

Yes, it works.  And...well, it's not terrible to make it work, but it was a bitch to find all the missing pieces.

For the search engines... think Euro Truck Simulator 2.  Linux.  Ubuntu and Mint.  This information won't be relevant for too much longer, but for my own sanity I'm writing it down anyway.

For starters, Ubuntu 17 already has the necessary changes to the UDEV rules file.  Mint 18 is based on Ubuntu 16, so you're stuck there without the following.

Upgrading the Kernel Version

Kernel series 4.4 does not have the necessary improvements to the hid_logitech_hidpp.ko module.  The 4.8 and later series kernels (supposedly also 4.6) have it.  Check Linus' kernel git and locate the module source if you want to enjoy a front-row seat in the time-machine.  I pushed my Mint 18 install to 4.10, partly for kicks; I figured it was a good compromise between new and working, although I have virtually no other experience and can't say what else might be fixed/broken over the 4.4 kernel that my Mint install was running...

Now, if you have a clean install of Mint, it might already be on a newer release.  My work computer was on 4.8; I had done upgrades to my home PC, however, and so the kernel version seemed to lag.  USE THE UPDATE MANAGER TO SELECT A NEW KERNEL VERSION!  


Also be careful /boot doesn't run out of space.  That is very annoying.

Once you have the newest kernel installed, you can move on to the UDEV system and the usb_modeswitch updates.

UDEV and usb_modeswitch


It's probably a good idea to start with the usb_modeswitch.  Again, newer versions of Ubuntu have this fix already loaded.  You'll need to create a file in /etc/usb_modeswitch.d/ called "046d:c261".  Inside, dump the following:


# Logitech G920 Racing Wheel
DefaultVendor=046d
DefaultProduct=c261
MessageEndpoint=01
ResponseEndpoint=01
TargetClass=0x03
MessageContent="0f00010142"

The next step is to insert the following rule into udev.  I stuffed mine into the rules file: /lib/udev/rules.d/40-usb_modeswitch.rules, however you might want to try using the /etc/udev/rules.d/ folder instead.  If the latter doesn't work, the former certainly does...you just run the slight risk of future upgrades wreaking havoc when they get to this file.


ATTR{idVendor}=="046d", ATTR{idProduct}=="c261", RUN+="usb_modeswitch '%b/%k'"


Why is this necessary?

As explained in the latter link, the steering wheel powers up in XBOX mode.  A command must be sent to switch the wheel over to PC mode, or there is no PC goodness.  usb_modeswitch does this.

Hazards

On these "older" versions of Ubuntu (ahem...Mint), you might run into a problem with usb_modeswitch if you're using USB hubs.  Evidently the older versions of usb_modeswitch might have trouble dealing with cascaded hubs, which could explain why I was able to get this to work on my Mint PC (a laptop I plugged directly into) and not my Xubuntu desktop (where I plugged into my USB KVM switch).  Newer versions of usb_modeswitch, such as that which ships with Ubuntu 17, supposedly do not suffer from this deficiency.  Now, I state this only to help debug, I haven't verified it, and YMMV.  Every time I pull out the steering wheel, I have to do it under cover of closed and locked door because it's a gift for my son (yeah, the kids get all the cool toys).

Also, you CAN actually get the wheel talking to Ubuntu/Mint without the newer kernel, BUT THE FORCE-FEEDBACK WILL NOT WORK!  That component is contingent on the kernel module, and if it doesn't talk to the G920, then you will have nothing more than a very expensive set of potentiometers.  That said, it is reassuring that to find that your wheel IS appearing to the system as a valid device of some sort, just to let you know that you're on the right track.  You'll also note that the incorrect version of the kernel module will not auto-load; the correct version will.  Watch lsmod and grep on "hid" to see the action.

Euro Truck Simulator 2!!!!!!

On my laptop, which is technically a work laptop, I have a shitty Intel graphics chipset, so ETS2 ran basically without textures.  So that's what that looks like....  But it ran enough to let me test the wheel and get everything working without borking my wife's (significantly better) system.  (Yeah, the tech guy who makes old hardware work for a long time suffers with old hardware for a long time...).  Once the correct kernel module was loaded, and the udev rules were in place, I watched the syslog and observed the correct initialization sequence via usb_modeswitch occurring.  On to ETS2, and enable force-feedback, and HOLY DAMN!  Engine rumble, dampening, response... I even crashed on purpose to see how it would feel.  Everything was solid gold.

Torcs gives some minor feedback also; I don't know much about configuring it, though, so I suppose it could be better.  If anyone else has Linux racing sims they'd like to share, that support wheels and force-feedback, I'm all ears!  Never thought I'd honestly buy one of these, but with the newer kernels, it is definitely a good buy.

A Side Note: the Brake Pedal

There are reports that the G29 and G920 both suffer from Logitech trying to, *cough* improve *couch* their brake pedal by inserting a rather rigid piece of rubber into the spring.  You have three choices, two of which involve voiding the 1 year warranty (and mine is already like 6 months gone because the damn things has been sitting in a closet after I bought it on sale)...

  1. Do nothing (and keep your warranty...and possibly suffer with a very stiff brake)
  2. Open the device and remove the rubber insert - this reportedly returns the unit to G27 performance.
  3. Open the device and replace the springs with a SPRING UPGRADE!!!  I totally want to do this...
This set looks pretty cool, and the reviews I have seen tend to be very positive:


The set works in the G920, and now all I need to do is to talk my wife into letting me buy it...um...for my son's steering wheel and pedal set.... ;-)





3 comments:

  1. Anonymous29/9/19 21:07

    This worked great, thank you for writing it and submitting it online for the world to know. :)

    ReplyDelete
  2. Anonymous27/1/20 15:49

    Thanks for this awesome write up! This has been really helpful

    ReplyDelete
  3. This pointed me in the right direction, but usb_modeswitch did not find the file and I could not connect to a hub (Yes, I am on Mint). What I ended up doing was to add a file /etc/udev/rules.d/10-logitech-g920.rules containing only one line:

    ATTR{idVendor}=="046d", ATTR{idProduct}=="c261", MODE:="0666", RUN+="/usr/sbin/usb_modeswitch --default-vendor 046d --default-product c261 --message-endpoint 1 --response-endpoint 1 --target-class 3 --message-content 0f00010142"

    That way I don't even need the file in /etc/usb_modeswitch.d/. And setting the MODE solves the issue where the steering wheel is not found when connected to a hub on Mint.

    ReplyDelete