2149 lines
80 KiB
XML
2149 lines
80 KiB
XML
<?xml version="1.0" standalone="no"?>
|
|
<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
|
|
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [
|
|
<!ENTITY % xboxdrvstuff SYSTEM "xboxdrv.ent">
|
|
%xboxdrvstuff;
|
|
]>
|
|
<refentry id="xboxdrv">
|
|
<refentryinfo>
|
|
<date>2010-05-05</date>
|
|
</refentryinfo>
|
|
|
|
<refmeta>
|
|
<refentrytitle>
|
|
<application>xboxdrv</application>
|
|
</refentrytitle>
|
|
<manvolnum>1</manvolnum>
|
|
<refmiscinfo class="version">&xboxdrv_version;</refmiscinfo>
|
|
<refmiscinfo class="author">&xboxdrv_version;</refmiscinfo>
|
|
<refmiscinfo class="manual">User Commands</refmiscinfo>
|
|
<refmiscinfo class="source">xboxdrv</refmiscinfo>
|
|
</refmeta>
|
|
|
|
<refnamediv>
|
|
<refname>
|
|
<application>xboxdrv</application>
|
|
</refname>
|
|
<refpurpose>
|
|
A Xbox/Xbox360 gamepad driver that works in userspace
|
|
</refpurpose>
|
|
</refnamediv>
|
|
|
|
<refsynopsisdiv>
|
|
<cmdsynopsis>
|
|
<command>xboxdrv</command>
|
|
<arg rep="repeat"><option>OPTION</option></arg>
|
|
<arg><option>--</option></arg>
|
|
<arg><option>COMMAND</option></arg>
|
|
<arg><option>ARGUMENTS</option></arg>
|
|
</cmdsynopsis>
|
|
</refsynopsisdiv>
|
|
|
|
<refsect1>
|
|
<title>Description</title>
|
|
<para>
|
|
<command>xboxdrv</command> is a driver for Xbox and Xbox360
|
|
gamepads. It works by reading the raw data from the controller
|
|
with the userspace library libusb and then passes the
|
|
interpreted data to the kernel via uinput. This
|
|
allows <command>xboxdrv</command> to provide regular joystick
|
|
and event devices, which makes it compatible with all Linux
|
|
software.
|
|
</para>
|
|
<para>
|
|
Aside from the pure driver, <command>xboxdrv</command> also
|
|
includes a rich set of configuration options that allow you to
|
|
tweak the abilities of the virtual input devices that xboxdrv
|
|
will create. This includes basic button and axis remapping, as
|
|
well as more complicated things like mouse and keyboard emulation,
|
|
auto-fire and throttle control emulation.
|
|
</para>
|
|
<para>
|
|
It is also possible for <command>xboxdrv</command> to read input
|
|
data directly from an event device, this allows to use the
|
|
configurability of <command>xboxdrv</command> on regular PC
|
|
joysticks, keyboards and mice and thus
|
|
lets <command>xboxdrv</command> serve a similar purpose
|
|
as <command>joy2key</command>. See the
|
|
option <option>--evdev</option> below for more information.
|
|
</para>
|
|
<para>
|
|
When a <option>COMMAND</option> is provided xboxdrv will launch
|
|
that application and be running till that application exits.
|
|
This is a convenience function to make it easier to use xboxdrv
|
|
in wrapper scripts.
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Options</title>
|
|
<refsect2>
|
|
<title>General Options</title>
|
|
<variablelist>
|
|
|
|
<varlistentry>
|
|
<term><option>-h</option>, <option>--help</option></term>
|
|
<listitem>
|
|
<para>Display help text and exit.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term>-V, --version</term>
|
|
<listitem>
|
|
<para>
|
|
Print the version number and exit.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-v</option>, <option>--verbose</option></term>
|
|
<listitem>
|
|
<para>Print verbose messages.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--help-led</option></term>
|
|
<listitem>
|
|
<para>List possible values for the led.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--help-devices</option></term>
|
|
<listitem>
|
|
<para>List supported devices.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-s</option>, <option>--silent</option></term>
|
|
<listitem>
|
|
<para>
|
|
Do not display events on console.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--quiet</option></term>
|
|
<listitem>
|
|
<para>
|
|
Do not display startup text.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-L</option>, <option>--list-controller</option></term>
|
|
<listitem>
|
|
<para>
|
|
List available controllers on the system.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--list-supported-devices</option></term>
|
|
<listitem>
|
|
<para>
|
|
List supported devices (used by xboxdrv-daemon.py).
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--list-supported-devices-xpad</option></term>
|
|
<listitem>
|
|
<para>
|
|
List supported devices in <filename>xpad.c</filename> style.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-R</option>, <option>--test-rumble</option></term>
|
|
<listitem>
|
|
<para>
|
|
Pressing LT will move the left rumble motor and pressing
|
|
RT will move the right one. Rumble motor strength
|
|
depends on how hard you press. This is useful for
|
|
testing the rumble motors.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--no-uinput</option></term>
|
|
<listitem>
|
|
<para>
|
|
Do not try to start uinput event dispatching, useful for debugging.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--config</option> <replaceable class="parameter">FILE</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Reads configuration information from <replaceable class="parameter">FILE</replaceable>.
|
|
Configurations from file are handling as if they would
|
|
be command line options at the position
|
|
of <option>--config</option> <replaceable class="parameter">FILE</replaceable>.
|
|
</para>
|
|
<para>
|
|
The syntax
|
|
of <replaceable class="parameter">FILE</replaceable> is
|
|
the familiar INI syntax used for many configuration
|
|
files. Regular key/value pairs must go into the
|
|
[xboxdrv] section. '#' and ';' can be used for comments.
|
|
Key names have for most part the same name as command
|
|
line options. Command line options that take a list of
|
|
input mappings (--ui-buttonmap, --ui-axismap,
|
|
--evdev-absmap, ...) can be split of into their own
|
|
section for better readability.
|
|
</para>
|
|
<para>
|
|
The <filename>examples/</filename> directory contains
|
|
some example configuration files.
|
|
</para>
|
|
<programlisting><![CDATA[[xboxdrv]
|
|
silent=true
|
|
deadzone=6000
|
|
dpad-as-button=true
|
|
trigger-as-button=true
|
|
|
|
[ui-axismap]
|
|
x2=REL_X:10
|
|
y2=REL_Y:-10
|
|
x1=KEY_A:KEY_D
|
|
y1=KEY_W:KEY_S
|
|
|
|
[ui-buttonmap]
|
|
a=KEY_LEFTSHIFT
|
|
b=BTN_C
|
|
x=BTN_EXTRA
|
|
y=KEY_C
|
|
|
|
[ui-buttonmap]
|
|
lb=BTN_RIGHT
|
|
rb=KEY_SPACE
|
|
|
|
[ui-buttonmap]
|
|
lt=KEY_Z
|
|
rt=BTN_LEFT
|
|
|
|
[ui-buttonmap]
|
|
dl=KEY_4
|
|
dr=KEY_2
|
|
du=REL_WHEEL:-1:150
|
|
dd=REL_WHEEL:1:150
|
|
|
|
[ui-buttonmap]
|
|
back=KEY_TAB
|
|
start=KEY_ESC
|
|
|
|
# EOF #]]></programlisting>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--mimic-xpad</option></term>
|
|
<listitem>
|
|
<para>
|
|
Causes xboxdrv to use the same axis and button names as the xpad kernel driver.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-D</option>, <option>--daemon</option></term>
|
|
<listitem>
|
|
<para>
|
|
Run as daemon. In most situations this is not very
|
|
useful, as <command>xboxdrv</command> will fail when the
|
|
pad is removed or plugged in. See xboxdrv-daemon(1) for
|
|
a way to launch <command>xboxdrv</command>
|
|
automatically.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Device Options</title>
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><option>-d</option>, <option>--detach-kernel-driver</option></term>
|
|
<listitem>
|
|
<para>
|
|
Detaches the kernel driver that is currently associated
|
|
with the given device. This is useful when you have the
|
|
xpad module loaded and want to use xboxdrv without
|
|
unloading it.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-i</option>, <option>--id</option> <replaceable class="parameter">N</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Use controller with id N (default: 0),
|
|
use <option>--list-controller</option> to obtain a list
|
|
of available controller.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-w</option>, <option>--wid</option> <replaceable class="parameter">N</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Use wireless controller with wid N (default: 0).
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--device-by-path</option> <replaceable class="parameter">BUS:DEV</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Use device BUS:DEV, do not do any scanning
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--device-by-id</option> <replaceable class="parameter">VENDOR:PRODUCT</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Use device that matches VENDOR:PRODUCT (as returned by <command>lsusb</command>)
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--type</option> <replaceable class="parameter">TYPE</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Ignore autodetection and enforce the controller type. Possible values for <replaceable class="parameter">TYPE</replaceable>:
|
|
</para>
|
|
<itemizedlist>
|
|
<listitem><para>xbox</para></listitem>
|
|
<listitem><para>xbox-mat</para></listitem>
|
|
<listitem><para>xbox360</para></listitem>
|
|
<listitem><para>xbox360-wireless</para></listitem>
|
|
<listitem><para>xbox360-guitar</para></listitem>
|
|
</itemizedlist>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--evdev</option> <replaceable class="parameter">DEVICE</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Allows you to read input data from a regular event
|
|
device. This allows you to
|
|
use <command>xboxdrv</command> on regular PC
|
|
joysticks. The data that is read from the event device
|
|
is converted internally into a XboxMsg object and then
|
|
passed through the same configuration pipeline as it
|
|
would be for a regular Xbox360 controller. This allows
|
|
you to make use of all the regular configurability, but
|
|
limits you to the number of axis and buttons that an
|
|
Xbox360 controller provides.
|
|
</para>
|
|
<para>
|
|
As a regular PC joystick will most likely already create
|
|
a <filename>/dev/input/jsX</filename> device by itself,
|
|
you might need to get rid of that so that a game will
|
|
properly detect the joystick device created
|
|
by <command>xboxdrv</command>. The easiest way to
|
|
accomplish that is to simply delete the old joystick and
|
|
rename the device that <command>xboxdrv</command>
|
|
created to <filename>/dev/input/js0</filename>. When you
|
|
use udev, this operation should be harmless and
|
|
automatically reverse itself when you remove the
|
|
controller and plug it back in or when you reboot the
|
|
computer.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--evdev-debug</option></term>
|
|
<listitem>
|
|
<para>
|
|
The evdev event handler will print all received events
|
|
to stdout, this makes it easy to see which events a
|
|
given controller sends.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--evdev-no-grab</option></term>
|
|
<listitem>
|
|
<para>
|
|
By default the evdev driver will grab the device, thus
|
|
making it impossible for other applications to receive
|
|
events from that device. This is done to avoid confusing
|
|
applications, as otherwise an app would receive every
|
|
event twice, once from the original device and once from
|
|
the virtual xboxdrv one. In some cases this behaviour is
|
|
undesired, such when mapping only an other wise
|
|
unhandled subset of keys of an device, i.e. mapping the
|
|
multimedia keys on a keyboard, so this option turns the
|
|
grab off.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--evdev-absmap</option> <replaceable class="parameter">ABSMAP,...</replaceable></term>
|
|
<listitem>
|
|
<programlisting><![CDATA[ABSMAP = EVDEV_ABS [ "+", "-" ] "=" XBOXAXIS ;]]></programlisting>
|
|
<para>
|
|
Sets how evdev events are mapped to Xbox axis
|
|
events. An example configuration would look like this:
|
|
</para>
|
|
<programlisting>--evdev-absmap ABS_X=x1,ABS_Y=y1,ABS_RZ=x2,ABS_THROTTLE=y2,ABS_HAT0X=dpad_x,ABS_HAT0Y=dpad_y</programlisting>
|
|
<para>
|
|
<command>xboxdrv</command> will output on startup a full
|
|
list of event names that the given event device
|
|
supports and that can be used in place of <replaceable>EVDEV_ABS</replaceable>.
|
|
</para>
|
|
<para>
|
|
It is also possible to map half-axis with a command like:
|
|
</para>
|
|
<programlisting>--evdev-absmap ABS_Y+=LT,ABS_Y-=RT</programlisting>
|
|
<para>
|
|
This will map the upward movement of the Y axis to the
|
|
left trigger and the downward movement to the right
|
|
trigger. <!-- FIXME: directions might be wrong -->
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--evdev-keymap</option> <replaceable class="parameter">KEYMAP</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Sets how evdev events are mapped to Xbox controller
|
|
events. An example configuration would look like this:
|
|
</para>
|
|
<programlisting>--evdev-keymap BTN_TRIGGER=a,BTN_THUMB=b,BTN_THUMB2=x</programlisting>
|
|
<para>
|
|
<command>xboxdrv</command> will output on start a full
|
|
list of event names that the given event device
|
|
supports.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--chatpad</option></term>
|
|
<listitem>
|
|
<para>
|
|
Enables the support for the Xbox360 Chatpad. WARNING:
|
|
This is preliminary code, it will crash your gamepad
|
|
when xboxdrv is started multiple times and won't provide
|
|
proper keymapping for any of the umlauts and special
|
|
characters.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Status Options</title>
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><option>-l</option>, <option>--led</option> <replaceable class="parameter">NUM</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Set LED status. Possible values for <replaceable class="parameter">NUM</replaceable> are:
|
|
</para>
|
|
<table>
|
|
<title>LED Status Codes</title>
|
|
<tgroup cols="2">
|
|
<colspec align="right" colwidth="1*" />
|
|
<colspec align="left" colwidth="1*" />
|
|
<thead>
|
|
<row>
|
|
<entry>Num</entry>
|
|
<entry>Behaviour</entry>
|
|
</row>
|
|
</thead>
|
|
<tbody>
|
|
<row><entry>0</entry> <entry> off</entry></row>
|
|
<row><entry>1</entry> <entry> all blinking</entry></row>
|
|
<row><entry>2</entry> <entry> 1/top-left blink, then on</entry></row>
|
|
<row><entry>3</entry> <entry> 2/top-right blink, then on</entry></row>
|
|
<row><entry>4</entry> <entry> 3/bottom-left blink, then on</entry></row>
|
|
<row><entry>5</entry> <entry> 4/bottom-right blink, then on</entry></row>
|
|
<row><entry>6</entry> <entry> 1/top-left on</entry></row>
|
|
<row><entry>7</entry> <entry> 2/top-right on</entry></row>
|
|
<row><entry>8</entry> <entry> 3/bottom-left on</entry></row>
|
|
<row><entry>9</entry> <entry> 4/bottom-right on</entry></row>
|
|
<row><entry>10</entry> <entry> rotate</entry></row>
|
|
<row><entry>11</entry> <entry> blink</entry></row>
|
|
<row><entry>12</entry> <entry> blink slower</entry></row>
|
|
<row><entry>13</entry> <entry> rotate with two lights</entry></row>
|
|
<row><entry>14</entry> <entry> blink</entry></row>
|
|
<row><entry>15</entry> <entry> blink once</entry></row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-r</option>, <option>--rumble</option> <replaceable class="parameter"> L,R</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Set the speed for both rumble motors. Values from 0 to 255 are accepted, the default is 0,0.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Configuration Options</title>
|
|
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><option>--deadzone <replaceable class="parameter">NUM</replaceable></option></term>
|
|
<listitem>
|
|
<para>
|
|
The deadzone is the area at which the sticks do not report any
|
|
events. The default is zero, which gives the best sensitifity but
|
|
might also cause trouble in some games in that the character or camera
|
|
might move without moving the stick. To fix this one has to set the
|
|
value to something higher:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --deadzone 4000</programlisting>
|
|
|
|
<para>A value of 4000 works quite well for most games.</para>
|
|
|
|
<para>You can also give the deadzone in percentage:</para>
|
|
|
|
<programlisting>$ xboxdrv --deadzone 15%</programlisting>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--deadzone-trigger <replaceable class="parameter">NUM</replaceable></option></term>
|
|
<listitem>
|
|
<para>
|
|
The left and right trigger have a separate deadzone value which can be
|
|
specified with:
|
|
</para>
|
|
<programlisting>$ xboxdrv --deadzone-trigger 15% </programlisting>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--trigger-as-button</option></term>
|
|
<listitem>
|
|
<para>LT and RT send button instead of axis events</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--trigger-as-zaxis</option></term>
|
|
<listitem>
|
|
<para>Combine LT and RT to form a zaxis instead</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--dpad-as-button</option></term>
|
|
<listitem>
|
|
<para>The DPad sends button instead of axis events.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--dpad-only</option></term>
|
|
<listitem>
|
|
<para>
|
|
Both sticks are ignored, only the DPad sends out axis
|
|
events. Useful for games that might get confused by
|
|
additional analog axis. Combining this option
|
|
with <option>--trigger-as-button</option> is recommend
|
|
in most situations.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-b, --buttonmap BUTTON=BUTTON,...</option></term>
|
|
<listitem>
|
|
<para>
|
|
Button remapping is available via the <option>--buttonmap</option> option. If you want
|
|
to swap button A and B start with:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --buttonmap A=B,B=A</programlisting>
|
|
|
|
<para>If you want all face buttons send out A button events:</para>
|
|
|
|
<programlisting>$ xboxdrv --buttonmap B=A,X=A,Y=A</programlisting>
|
|
|
|
<para>Possible button names are (aliases are in parenthesis):</para>
|
|
|
|
<table frame="all">
|
|
<title>Button Names</title>
|
|
<tgroup cols="2">
|
|
<thead>
|
|
<row>
|
|
<entry>Name</entry>
|
|
<entry>Description</entry>
|
|
</row>
|
|
</thead>
|
|
<tbody>
|
|
<row>
|
|
<entry>start, back</entry>
|
|
<entry>start, back buttons</entry>
|
|
</row>
|
|
|
|
<row>
|
|
<entry>guide</entry>
|
|
<entry>big X-button in the middle (Xbox360 only)</entry>
|
|
</row>
|
|
|
|
<row>
|
|
<entry>a(1), b(2), x(3), y(4)</entry>
|
|
<entry>face buttons</entry>
|
|
</row>
|
|
|
|
<row>
|
|
<entry>black, white</entry>
|
|
<entry>black, white buttons (Xbox1 only, mapped to lb, rb on Xbox360)</entry>
|
|
</row>
|
|
|
|
<row>
|
|
<entry>lb(5), rb(6)</entry>
|
|
<entry>shoulder buttons (Xbox360 only, mapped to black, white on Xbox1)</entry>
|
|
</row>
|
|
|
|
<row>
|
|
<entry>lt(7), rt(8)</entry>
|
|
<entry>analog trigger (needs --trigger-as-button option)</entry>
|
|
</row>
|
|
|
|
<row>
|
|
<entry>tl, tr</entry>
|
|
<entry>pressing the left or right analog stick</entry>
|
|
</row>
|
|
|
|
<row><entry>du(up), dd(down), dl(left), dr(right)</entry>
|
|
<entry>dpad directions (needs --dpad-as-button option)</entry>
|
|
</row>
|
|
|
|
<row>
|
|
<entry>green, red, yellow, blue, orange</entry>
|
|
<entry>guitar buttons</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--axismap</option> <replaceable class="parameter">AXIS=MAPPING,...</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Axis remapping is available via --axismap and works the same as button
|
|
mapping. In addition you can supply a sign to indicate that an axis
|
|
should be inverted. So if you want to invert the y1 axis start with:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --axismap -Y1=Y1</programlisting>
|
|
|
|
<para>
|
|
If you want to swap the left and right stick start with:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --axismap X2=X1,Y2=Y1,X1=X2,Y1=Y2</programlisting>
|
|
|
|
<para>
|
|
Possible axis names are: x1, y1, x2, y2, lt, rt
|
|
</para>
|
|
|
|
<para>
|
|
Swaping lt or rt with x1, y1, x2, y2 will not work properly, since
|
|
their range is different.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--ui-buttonmap</option> <replaceable class="parameter">UIBUTTONSPEC,...</replaceable></term>
|
|
<listitem>
|
|
<programlisting><![CDATA[UIBUTTONSPEC = XBOXBUTTON [ "+" XBOXBUTTON ] [ "^" FILTER ] ... "=" ( RELSPEC | BTNSPEC | EXECSPEC ) ;
|
|
RELSPEC = [ DEVICEID "-" ] "REL_" [ ":" [ VALUE ] [ ":" REPEAT ] ] ;
|
|
BTNSPEC = [ DEVICEID "-" ] ( ( "BTN_" NAME ) | ( "KEY_" NAME ) ) { "+" BTNSPEC } ;
|
|
EXECSPEC = PROGRAM { ":" ARGUMENT } ;
|
|
XBOXBUTTON = "a" | "b" | "x" | "y" | "lb" | "rb" | "lt" | "rt" |
|
|
"tl" | "tr" | "start" | "select" | "back" | "guide" | "black" | "white" ;
|
|
FILTER = "toggle" | "invert" | "autofire" [ ":" RATE ] [ ":" DELAY ] | log [ ":" STRING ] ;
|
|
NAME = STRING ;
|
|
VALUE = NUMBER ;
|
|
REPEAT = NUMBER ;
|
|
DEVICEID = NUMBER ;]]></programlisting>
|
|
<para>
|
|
Allows you to change the event code that is send to the
|
|
kernel for buttons. The usage is similar to the normal button
|
|
mapping, except that the right hand side is an event name from
|
|
<filename>/usr/include/linux/input.h</filename>. You can
|
|
use all <keysym>KEY_</keysym> or <keysym>BTN_</keysym>
|
|
codes for <option>--ui-buttonmap</option>.
|
|
</para>
|
|
<para>
|
|
If the right hand side is left empty all the supplied
|
|
filters will be added to the already existing button
|
|
binding instead of a new one.
|
|
</para>
|
|
<para>
|
|
Aside from the named keys, you can also give the input
|
|
code directly as number via the
|
|
syntax <keysym>KEY_#<replaceable>NUM</replaceable></keysym>.
|
|
</para>
|
|
<para>
|
|
Instead of the low level <keysym>KEY_</keysym> names,
|
|
which represent keycodes, you can also use the higher
|
|
level X11 keysyms <keysym>XK_</keysym>, the keysyms have
|
|
the advantage that they map directly to the key you
|
|
expect, while a <keysym>KEY_</keysym> name gets mungled
|
|
by the X11 keymap and will often not report what you
|
|
expect in case you use a keymap that is different then
|
|
your keyboard (i.e. dvorak on a qwerty keyboard).
|
|
</para>
|
|
<para>
|
|
A full list of X11 keysyms is available at
|
|
<filename>/usr/include/X11/keysymdef.h</filename>, note that you can only use those that
|
|
are reachable by your current keymap. Keysyms that are reachable via
|
|
multiple keycodes might break the mapping from keysym to evdev code.
|
|
</para>
|
|
<para>
|
|
For joystick buttons there is in addition to the <keysym>BTN_JOYSTICK</keysym>, <keysym>BTN_X</keysym>,
|
|
etc. macros the special name <keysym>JS_$NUM</keysym>, which sets the given button to
|
|
the $NUMS joystick button, i.e.:
|
|
</para>
|
|
<programlisting>$ xboxdrv --ui-clear --ui-buttonmap A=JS_0,B=JS_1</programlisting>
|
|
<para>
|
|
Note that this will only work if no other joystick
|
|
button ids are in the way.
|
|
</para>
|
|
<para>
|
|
You can also map a button to a <keysym>REL_</keysym>
|
|
event. In that case you can supply additional paramaters in the form of:
|
|
</para>
|
|
<programlisting>$ xboxdrv --ui-buttonmap X=REL_???:VALUE:REPEAT</programlisting>
|
|
<para>
|
|
<replaceable class="parameter">VALUE</replaceable> gives the value of the event (default: 10)
|
|
</para>
|
|
<para>
|
|
<replaceable class="parameter">REPEAT</replaceable>
|
|
gives the number of milisecond to pass before the event
|
|
is fired again (default: 5)
|
|
</para>
|
|
<para>
|
|
The special 'void' event allows you to clear any
|
|
existing bindings for a given button, which can be
|
|
useful in cases when a game only supports a limited
|
|
number of buttons.
|
|
</para>
|
|
<para>
|
|
You can also prepend a device_id to the UIBUTTONSPEC
|
|
which allows you to create multiple uinput devices. By
|
|
default 'auto' is assumed as device_id which
|
|
automatically try to do the right thing, sending
|
|
keyboard events to a keyboard device and mouse events to
|
|
a mouse device. Other possible values are 'mouse' and
|
|
'keyboard'. A device_id of '0' refers to the first
|
|
joystick device, values larger then 0 to the second,
|
|
third, etc.
|
|
</para>
|
|
<para>
|
|
Note that the 'mouse' and 'keyboard' device_id names do
|
|
not give you a mouse or keyboard device, these are just
|
|
symbolic names for the devices into which xboxdrv will
|
|
sort events that look like a mouse or keyboard
|
|
event. The final determination of which device gets
|
|
handled as what will be done by the Kernel or Xorg
|
|
depending on what events a device provides.
|
|
</para>
|
|
<para>
|
|
An example configuration makeing use of device_id would look like this:
|
|
</para>
|
|
<programlisting><![CDATA[xboxdrv -s \
|
|
--ui-clear \
|
|
--ui-buttonmap A=0-JS_0,B=0-JS_1 --ui-axismap X2=1-ABS_X,Y2=1-ABS_Y
|
|
--ui-buttonmap X=1-JS_0,Y=1-JS_1 --ui-axismap X2=1-ABS_X,Y2=1-ABS_Y]]></programlisting>
|
|
<para>
|
|
In this example the left stick creates a joystick device
|
|
and the right stick creates a separate joystick device.
|
|
</para>
|
|
<para>
|
|
Instead of giving just a single button, it is also
|
|
possible to give two buttons
|
|
to <option>--ui-buttonmap</option> to allow shifting:
|
|
</para>
|
|
<programlisting><![CDATA[xboxdrv -s \
|
|
--ui-clear \
|
|
--ui-buttonmap A=JS_0,B=JS_1,LB+A=JS_2,LB+B=JS_3]]></programlisting>
|
|
<para>
|
|
In this example LB acts as shift button, if A is pressed
|
|
without LB it will send out a JS_0 event, but if LB is
|
|
pressed it will send a JS_2 event instead. This allows
|
|
you to multiply the number of available buttons on the
|
|
controller.
|
|
</para>
|
|
<para>
|
|
See the section KEYBOARD EMULATION below on how to
|
|
resolve issues with Xorg not detecting the virtual
|
|
keyboard that xboxdrv creates.
|
|
</para>
|
|
<para>
|
|
You can also apply filters to button events:
|
|
</para>
|
|
<programlisting><![CDATA[xboxdrv -s \
|
|
--ui-buttonmap A^toggle=JS_0]]></programlisting>
|
|
|
|
<bridgehead renderas="sect3">Hold Button</bridgehead>
|
|
<para>
|
|
You can send different events depending on how long a
|
|
button was pressed by:
|
|
</para>
|
|
<programlisting><![CDATA[xboxdrv \
|
|
--ui-buttonmap A=JS_0:JS_1:500]]></programlisting>
|
|
<para>
|
|
This will send JS_0 events when the button is pressed
|
|
and switch to JS_1 events when the button was hold for
|
|
500 miliseconds.
|
|
</para>
|
|
|
|
<bridgehead renderas="sect3">Exec Button</bridgehead>
|
|
<para>
|
|
You can bind a button to an application, so that the
|
|
application will be launched when the button was
|
|
pressed:
|
|
</para>
|
|
<programlisting><![CDATA[xboxdrv \
|
|
--ui-buttonmap A=exec:/home/juser/local/bin/screenshot.sh]]></programlisting>
|
|
|
|
<bridgehead renderas="sect3">Macro Button</bridgehead>
|
|
<para>
|
|
A button can be bound to a macros via:
|
|
</para>
|
|
<programlisting><![CDATA[xboxdrv \
|
|
--ui-buttonmap A=macro:/home/juser/.xboxdrv/somefile.macro]]></programlisting>
|
|
<para>
|
|
The <filename>.macro</filename> file has the form of:
|
|
</para>
|
|
<programlisting><![CDATA[
|
|
send KEY_LEFTSHIFT 1
|
|
wait 500
|
|
send KEY_LEFTSHIFT 0]]></programlisting>
|
|
<para>
|
|
All abs, rel and key events can be send from a macro file.
|
|
</para>
|
|
<para>
|
|
For documentation on the filters you can apply to events
|
|
see <link linkend="buttonfilter" endterm="buttonfilter.title" />.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--ui-axismap</option> <replaceable class="parameter">UIAXISSPEC,...</replaceable></term>
|
|
<listitem>
|
|
<programlisting><![CDATA[UIAXISSPEC = [ XBOXBTN "+" ] XBOXAXIS { "^" FILTER } "=" ( RELSPEC | BTNSPEC | ABSSPEC ) ;
|
|
BTNSPEC = "KEY_" NAME ":" "KEY_" NAME ":" THRESHOLD ;
|
|
RELSPEC = "REL_" NAME ":" VALUE ":" REPEAT ;
|
|
ABSSPEC = "ABS_" NAME ;
|
|
FILTER = ( "calibration" | "cal" ) ":" MIN ":" CENTER ":" MAX |
|
|
( "sensitifity" | "sen" ) ":" SENSITIFITY |
|
|
( "deadzone" | "dead" ) ":" MIN ":" MAX ":" SMOOTH |
|
|
( "relative" | "rel" ) ":" SPEED |
|
|
( "responsecurve" | "response" | "resp" ) { ":" VALUE }
|
|
XBOXBTN = "a" | "b" | "x" | "y" | "start" | "back" | "guide" | "lb" | "rb" | ...
|
|
XBOXAXIS = "x1" | "y1" | "x2" | "y2" | "z" | "lt" | "rt" | "dpad_x" | "dpad_y" ;
|
|
VALUE = NUMBER ;
|
|
REPEAT = NUMBER ;
|
|
THRESHOLD = NUMBER ;
|
|
NAME = STRING ;]]></programlisting>
|
|
<para>
|
|
Similar to <option>--ui-buttonmap</option> this option
|
|
allows you to change the event code that is send to the
|
|
kernel for axes. The events that are available are the
|
|
same as for <option>--ui-buttonmap</option>.
|
|
</para>
|
|
<programlisting>$ xboxdrv --ui-axismap X1=REL_???:VALUE:REPEAT</programlisting>
|
|
<para>
|
|
<replaceable class="parameter">VALUE</replaceable> gives the maximum value of the event (default: 10)
|
|
</para>
|
|
<para>
|
|
<replaceable class="parameter">REPEAT</replaceable>
|
|
gives the number of milisecond to pass before the event
|
|
is fired again (default: 5)
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --ui-axismap X1=KEY_UP:KEY_DOWN:THRESHOLD</programlisting>
|
|
<para>
|
|
<replaceable class="parameter">KEY_UP</replaceable> gives the keycode to be send when the axis is moved up
|
|
</para>
|
|
<para>
|
|
<replaceable class="parameter">KEY_DOWN</replaceable> gives the keycode to be send when the axis is moved down
|
|
</para>
|
|
<para>
|
|
<replaceable class="parameter">THRESHOLD</replaceable> gives the threshold that triggers the sending of an event
|
|
</para>
|
|
|
|
<para>
|
|
Just like <option>--ui-buttonmap</option>, you can
|
|
also use shift keys in place of the XBOXAXIS:
|
|
</para>
|
|
<programlisting>$ xboxdrv --ui-axismap X1=ABS_X,LB+X1=ABS_RX</programlisting>
|
|
<para>
|
|
This allows you to send ABS_X events normally and ABS_RX
|
|
events when the LB button is held down.
|
|
</para>
|
|
|
|
<para>
|
|
For information on how to use axis filters, see <link linkend="axisfilter" endterm="axisfilter.title" />.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--alt-config</option> <replaceable class="parameter">FILE</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
A shortcut for writing <option>--ui-new</option> <option>--config</option> <replaceable class="parameter">FILE</replaceable>.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--ui-clear</option></term>
|
|
<listitem>
|
|
<para>
|
|
Removes all uinput mappings and will leave the driver in
|
|
a blank state and only map those things you added
|
|
yourself. If you only want to get rid of individual
|
|
buttons you can use the 'void' event.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--ui-new</option></term>
|
|
<listitem>
|
|
<para>
|
|
Allows the creation of an alternative uinput
|
|
configuration to which one can toggle at runtime by
|
|
pressing the ui-toggle button (defaults to guide).
|
|
</para>
|
|
<programlisting><![CDATA[$ xboxdrv \
|
|
--mouse \
|
|
--ui-new
|
|
--ui-axismap X1=ABS_X,Y1=ABS_Y \
|
|
--ui-buttonmap A=JS_0,B=JS_1]]></programlisting>
|
|
<para>
|
|
The above configuration would install mouse emulation as
|
|
first configuration and a simple joystick emulation as
|
|
second configuration. Allowing toggling between mouse
|
|
emulation and joystick handling by pressing the guide
|
|
button.
|
|
</para>
|
|
<para>
|
|
Not that <option>--ui-new</option> is currently limited
|
|
to only configurations done
|
|
with <option>--ui-buttonmap</option>
|
|
and <option>--ui-axismap</option>, autofire, throttle
|
|
emulation, deadzones and all other things can currently
|
|
not be switched at runtime.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--ui-toggle</option> <replaceable class="parameter">XBOXBTN</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Sets the button that will be used to toggle between
|
|
different uinput configurations.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--guitar</option></term>
|
|
<listitem>
|
|
<para>
|
|
Sets a predefined button and axis mapping for use with
|
|
guitar controllers. This mainly gets rid of a few
|
|
unnecesary buttons and axis not used by a guitar
|
|
controller.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>-m, --mouse</option></term>
|
|
<listitem>
|
|
<para>
|
|
Lets the controller act as a mouse. It is indendical to:
|
|
</para>
|
|
<programlisting><![CDATA[$ xboxdrv \
|
|
--dpad-as-button
|
|
--deadzone 4000
|
|
--trigger-as-zaxis
|
|
--axismap "-y2=y2,-trigger=trigger"
|
|
--ui-axismap "x1=REL_X:15:20,y1=REL_Y:15:20,y2=REL_WHEEL:5:100,x2=REL_HWHEEL:5:100,trigger=REL_WHEEL:5:100"
|
|
--ui-buttonmap "a=BTN_LEFT,b=BTN_RIGHT,x=BTN_MIDDLE,y=KEY_ENTER,rb=KEY_PAGEDOWN,lb=KEY_PAGEUP,"
|
|
--ui-buttonmap "dl=KEY_LEFT,dr=KEY_RIGHT,du=KEY_UP,dd=KEY_DOWN,"
|
|
--ui-buttonmap "start=KEY_FORWARD,back=KEY_BACK,guide=KEY_ESC,tl=void,tr=void"]]></programlisting>
|
|
<para>
|
|
You can customize it by the usual means, just make sure
|
|
that <option>--mouse</option> comes before you
|
|
customization options on the command line.
|
|
</para>
|
|
<para>
|
|
Note that if you have your mouse buttons switched you must
|
|
adjust the above to match your mouse configuration or the
|
|
button events will come out wrong.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--name DEVNAME</option></term>
|
|
<listitem>
|
|
<para>
|
|
Changes the descriptive name the device will have
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--square-axis</option></term>
|
|
<listitem>
|
|
<para>
|
|
The Xbox360 gamepad, as most other current day gamepads,
|
|
features a circular movement range, which restricts the
|
|
movement so that the distance to the center never gets
|
|
beyond 1. This means that when you have the controller
|
|
at the top/left the value reported is (0.7, 0.7)
|
|
(i.e. length 1, angle 45) instead of (1,1). This
|
|
behaviour is different then most classic PC joysticks,
|
|
which had a square range and would report (1,1) when
|
|
hold in the top/left corner.
|
|
</para>
|
|
|
|
<para>Some old games (i.e. mostly DOS stuff) require a
|
|
square movement range and will not function properly
|
|
with the Xbox360 gamepad. Via the
|
|
<option>--square-axis</option> option you can work around this issue and diagonals will
|
|
be reported as (1,1).</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--four-way-restrictor</option></term>
|
|
<listitem>
|
|
<para>
|
|
The <option>--four-way-restrictor</option> option allows to
|
|
limit the movement on both analogsticks to only four
|
|
directions (up, down, left, right), the diagonals (up/left,
|
|
up/right, down/left, down/right) are filtered out from the
|
|
output. This option is useful for games such as Tetris, that
|
|
don't need diagonals and where you don't want to accidently
|
|
trigger the down-move while trying to do a left/right move.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--dpad-rotation</option> <replaceable class="parameter">DEGREE</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
Allows you to rotate the
|
|
dpad. <replaceable class="parameter">DEGREE</replaceable>
|
|
must be a multiple of 45. This can be useful in
|
|
isometric games where the playfield itself is rotated,
|
|
thus a:
|
|
</para>
|
|
<programlisting>xboxdrv --dpad-rotation 45</programlisting>
|
|
<para>
|
|
Will give you controls that are relative to your
|
|
character instead of your viewpoint.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--axis-sensitivty <replaceable class="parameter">AXIS=SENSITIVITY</replaceable></option>,...</term>
|
|
<listitem>
|
|
<para>The sensitive of an axis can be adjusted via --axis-sensitivty:</para>
|
|
|
|
<programlisting>$ xboxdrv --axis-sensitivty X1=-1.0,Y1=-1.0</programlisting>
|
|
|
|
<para>
|
|
A value of 0 gives you the default linear sensitivity,
|
|
values larger then 0 will give you higher sensitivity,
|
|
while values smaller then 0 will give you lower
|
|
sensitivity. Sensitivity values in the range of [-1, 1]
|
|
will generally give good results, everything beyond that
|
|
won't be of much practical use.
|
|
</para>
|
|
|
|
<para>Sensitivity works by applying:</para>
|
|
|
|
<programlisting><![CDATA[t = 2 ** sensitivity;
|
|
pos = (1.0f - (1.0f - pos) ** t) ** (1 / t);]]></programlisting>
|
|
|
|
<para>
|
|
To the value of the axis, this means that both the
|
|
minimum value and the maximum value of the axis will
|
|
always stay the same, just the response inbetween
|
|
changes.
|
|
</para>
|
|
<para>
|
|
For a complete freeform way to change the axis response
|
|
see the <option>Response Curve Filter</option>.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--relative-axis AXIS=NUM,...</option></term>
|
|
<listitem>
|
|
<para>
|
|
The function <option>--relative-axis</option> allows you
|
|
to change the behaviour of an axis so that your movement
|
|
of it moves its value up or down instead of applying it
|
|
directly. This allows you to simulate throttle control
|
|
for flightsim games.
|
|
</para>
|
|
<para>
|
|
Since the axis might be upside down, you might want to use
|
|
the <option>--axismap</option> function to reverse it.
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --relative-axis y2=64000 --axismap -y2=y2</programlisting>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--autofire BUTTON=FREQUENCY</option></term>
|
|
<listitem>
|
|
<para>Autofire mapping allows you to let a button automatically fire with a
|
|
given frequency in miliseconds:</para>
|
|
|
|
<programlisting>$ xboxdrv --autofire A=250</programlisting>
|
|
|
|
<para>Combining <option>--autofire</option> with button map allows you to have one button act
|
|
as autofire while another one, emitting the same signal, acts normally.</para>
|
|
|
|
<programlisting>$ xboxdrv --autofire B=250 --buttonmap B=A</programlisting>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--calibration <replaceable class="parameter">CALIBRATIONSPEC</replaceable></option></term>
|
|
<listitem>
|
|
<para>
|
|
If your gamepad for some reason can't reach the maximum value or isn't
|
|
centered properly you can fix that via the calibration options:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --calibration X2=-32768:0:32767</programlisting>
|
|
|
|
<para>X2 is the axis name and the three values that follow are min, center
|
|
and max. Simply insert the values that jstest reports when your axis
|
|
is in the respective positions.</para>
|
|
|
|
<para>You can also use the calibration option if you want to make your
|
|
joystick more sensitive. A setting of:</para>
|
|
|
|
<programlisting>xboxdrv --calibration AXIS=MIN:CENTER:MAX,...</programlisting>
|
|
|
|
<para>Will cause the joystick device report maximum position when your
|
|
stick is only moved half the way.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--axis-sensitivty <replaceable class="parameter">AXIS=SENSITIVITY</replaceable></option>,...</term>
|
|
<listitem>
|
|
<para>The sensitive of an axis can be adjusted via --axis-sensitivty:</para>
|
|
|
|
<programlisting>$ xboxdrv --axis-sensitivty X1=-2.0,Y1=-2.0</programlisting>
|
|
|
|
<para>A value of 0 gives you the default linear sensitivity, values larger
|
|
then 0 will give you heigher sensitivity, while values smaller then 0
|
|
will give you lower sensitivity.</para>
|
|
|
|
<para>Sensitivity works by applying:</para>
|
|
|
|
<programlisting><![CDATA[t = 2 ** sensitivity;
|
|
pos = (1.0f - (1.0f - pos) ** t) ** (1 / t);]]></programlisting>
|
|
|
|
<para>To the value of the axis, thus both the min and max position will
|
|
always stay the same, only the values inbetween change.</para>
|
|
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--force-feedback</option></term>
|
|
<listitem>
|
|
<para>
|
|
Enables the standard kernel force feedback interface. It
|
|
is disabled by default as it causes trouble with some
|
|
applications running in Wine.
|
|
</para>
|
|
<para>
|
|
Since the Xbox360 controller supports just rumble not full force
|
|
feedback, xboxdrv tries to emulate other effects. This emulation
|
|
hasn't been tested much and might not always work as expected. Bug
|
|
reports and test cases are welcome.
|
|
</para>
|
|
<para>
|
|
Note that you must close the application that is using force feedback
|
|
always before you close the xboxdrv driver, else you might end up with
|
|
a hanging non-interruptable xboxdrv process that will require a reboot
|
|
to get rid of.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>--rumble-gain</option> <replaceable class="parameter">AMOUNT</replaceable></term>
|
|
<listitem>
|
|
<para>You can change the rumble strength via:</para>
|
|
|
|
<programlisting>$ xboxdrv --rumble-gain 50%</programlisting>
|
|
|
|
<para>Values larger then 100% are possible as well.</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect2>
|
|
</refsect1>
|
|
|
|
<refsect1 id="inputfilter">
|
|
<title id="inputfilter.title">Input Filter</title>
|
|
<para>
|
|
Input filter allow to manipulate the events that come from the
|
|
controller. They can be used
|
|
on <option>--buttonmap</option>, <option>--axismap</option>, <option>--ui-buttonmap</option>
|
|
and <option>--ui-axismap</option>. The difference between the
|
|
two is that the <option>--ui-...</option> versions applies to
|
|
the uinput events, while the other version applies to Xbox360
|
|
controller events.
|
|
</para>
|
|
<refsect2 id="buttonfilter">
|
|
<title id="buttonfilter.title">Button Filter</title>
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><option>tog</option>, <option>toggle</option></term>
|
|
<listitem>
|
|
<para>
|
|
The toggle filter will turn the button into a toggle
|
|
button, clicking the button will set it to pressed state
|
|
and pressing it again will unpress it. Useful for games
|
|
where you might want to permanently run or duck without
|
|
holding the button pressed.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>inv</option>, <option>invert</option></term>
|
|
<listitem>
|
|
<para>
|
|
The invert filter will keep the button in pressed state
|
|
when it is not pressed and in unpressed state when it is
|
|
pressed.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>auto</option>, <option>autofire</option>:<replaceable>RATE</replaceable>:<replaceable>DELAY</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
The autofire filter allows to repeatatly send button
|
|
press events when the button is held down. It takes two
|
|
optional parameters:
|
|
</para>
|
|
<para>
|
|
<replaceable>RATE</replaceable> is the number of
|
|
miliseconds between button press events.
|
|
</para>
|
|
<para>
|
|
<replaceable>DELAY</replaceable> the amount of
|
|
miliseconds till the autofire will start, before that
|
|
delay the button will act as normal.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>log</option>:<replaceable>STRING</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
The log filter will output everything to stdout that
|
|
goes through it to, this is useful for debugging the
|
|
filter. A <replaceable>STRING</replaceable> can be
|
|
provided as parameter that will be outputed before the
|
|
event.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect2>
|
|
|
|
<refsect2 id="axisfilter">
|
|
<title id="axisfilter.title">Axis Filter</title>
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term><option>cal</option>, <option>calibration</option></term>
|
|
<listitem>
|
|
<para>
|
|
See <option>--calibration</option>.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>sen</option>, <option>sensitivity</option>:<replaceable>SENSITIVITY</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
See <option>--axis-sensitivity</option>.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>dead</option>,
|
|
<option>deadzone</option>:<replaceable>VALUE</replaceable>,
|
|
<option>deadzone</option>:<replaceable>MIN</replaceable>:<replaceable>CENTER</replaceable>:<replaceable>MAX</replaceable>
|
|
</term>
|
|
<listitem>
|
|
<para>
|
|
Deadzone filter applies a deadzone to the current axis.
|
|
If only <replaceable>MIN</replaceable> is provided, the
|
|
parameter will be interpreted
|
|
as <replaceable>-MIN:MIN:1</replaceable>. If the
|
|
argument is 1, smooth filtering will be applied so that
|
|
the end of the deadzone is 0. Setting the argument to 0
|
|
will apply a simple cut-off filter, where all events
|
|
smaller then the threshold are ignored.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>rel</option>, <option>relative</option>:<replaceable>SPEED</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
See <option>--relative-axis</option>.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>resp</option>, <option>response</option>:<replaceable>VALUES</replaceable>:...</term>
|
|
<listitem>
|
|
<para>
|
|
The response curve filter allows you to completely
|
|
change the way an axis reacts. The filter takes a list
|
|
of <replaceable>VALUES</replaceable> that are then
|
|
linearly interpolated and spread across the full range
|
|
of the axis. An example would look like this:
|
|
</para>
|
|
<programlisting><![CDATA[xboxdrv \
|
|
--ui-axismap x1^resp:-32768:-4000:0:4000:32767]]></programlisting>
|
|
<para>
|
|
Here the X1 axis is manipulated so that it will have a
|
|
lower sensitivity in the center and a higher one on the
|
|
outside.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
|
|
<varlistentry>
|
|
<term><option>log</option>:<replaceable>STRING</replaceable></term>
|
|
<listitem>
|
|
<para>
|
|
The log filter will output everything to stdout that
|
|
goes through it to, this is useful for debugging the
|
|
filter. A <replaceable>STRING</replaceable> can be
|
|
provided as parameter that will be outputed before the
|
|
event.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect2>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Running xboxdrv</title>
|
|
<para>
|
|
Plug in your Xbox360 gamepad and then unload the xpad driver via:
|
|
</para>
|
|
|
|
<programlisting>$ rmmod xpad</programlisting>
|
|
|
|
<para>
|
|
If you want to permanently unload it add the following line to
|
|
<filename>/etc/modprobe.d/blacklist.conf</filename>:
|
|
</para>
|
|
|
|
<programlisting>blacklist xpad</programlisting>
|
|
|
|
<para>
|
|
Next you have to load the uinput kernel module which allows userspace
|
|
programms to create input devices and the joydev module which gives
|
|
you the <filename>/dev/input/jsX</filename> device:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ modprobe uinput
|
|
$ modprobe joydev]]></programlisting>
|
|
|
|
<para>
|
|
You also have to make sure that you have access rights to
|
|
/dev/input/uinput, either add yourself to the appropriate group,
|
|
adjust the permissions or run xboxdrv as root.
|
|
</para>
|
|
|
|
<para>
|
|
Once ensured that xpad is out of the way and everything is in place
|
|
start the userspace driver with:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv</programlisting>
|
|
|
|
<para>
|
|
Or in case you don't have the neccesary rights (being in group root
|
|
should often be enough) start the driver as root via:
|
|
</para>
|
|
|
|
<programlisting>$ sudo xboxdrv</programlisting>
|
|
|
|
<para>
|
|
This will create /dev/input/js0 and allow you to access the gamepad
|
|
from any game. To exit the driver press Ctrl-c.
|
|
If you have multiple wired controllers you need to start multiple instances
|
|
of the xboxdrv driver and append the -i argument like this:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv -i 1</programlisting>
|
|
|
|
<para>
|
|
If you have multiple wireless controller you need to start multiple
|
|
instances of the xboxdrv driver and append the --wid argument like
|
|
this:
|
|
</para>
|
|
|
|
<programlisting>$ xboxdrv --wid 1</programlisting>
|
|
|
|
<para>
|
|
You have to sync the wireless controller as usual.
|
|
</para>
|
|
|
|
<para>This will then use the second detected controller, see to see which id
|
|
your controller has:</para>
|
|
|
|
<programlisting>$ xboxdrv --list-controller</programlisting>
|
|
|
|
<para>When everything works as expected it is recomment that you run xboxdrv
|
|
with the silent option:</para>
|
|
|
|
<programlisting>$ xboxdrv --silent</programlisting>
|
|
|
|
<para>This will suppress the logging of events to the console and will
|
|
gurantee that no uneccesarry CPU cycles are wasted.</para>
|
|
|
|
<para>If you want to abuse the led or rumble of the gamepad for notification
|
|
in scripts you can do see via:</para>
|
|
|
|
<programlisting>$ xboxdrv --led 10 --rumble 30,30 --quit</programlisting>
|
|
|
|
<para>This will cause a mild rumble and the led to rotate, you can stop it
|
|
again via, which also happens to be the command you can use to stop
|
|
your Xbox360 controller from blinking:</para>
|
|
|
|
<programlisting>$ xboxdrv ---led 0 --rumble 0,0 --quit</programlisting>
|
|
|
|
<para>For rumble to work make sure you have connected the
|
|
controller to a USB port that has enough power, an unpowered USB
|
|
hub might not work.</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Testing</title>
|
|
<para>
|
|
Knowing how to test a xboxdrv configuration is absolutely crucial in
|
|
understanding what is wrong in a given setup. Testing the
|
|
configuration in a game is most often not helpful, since you won't see
|
|
the true cause beyond endless layers of abstraction between you and
|
|
the actual events. Luckily there are a few tools you can use to test,
|
|
all of these are command line based and it is recomment that you get
|
|
familar with them when you want to do any more complex configuration.
|
|
</para>
|
|
|
|
<refsect2>
|
|
<title>evtest</title>
|
|
<para>
|
|
evtest lets you read raw input events from <filename>/dev/input/eventX</filename>. The
|
|
event devices are the very core of all event handling, things like the
|
|
joystick devices are derived from the event device, so if you want to
|
|
fix some issue on the joystick device, you have to fix the event
|
|
device.
|
|
</para>
|
|
|
|
<para>
|
|
evtest is available in the tools/ directory, you might also find it in
|
|
your distribution.
|
|
</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>jstest</title>
|
|
<para>
|
|
jstest lets you read the output out of a joystick event device (/dev/input/js0).
|
|
</para>
|
|
|
|
<para>
|
|
jstest is available in the tools/ directory or as part of your
|
|
distribution.
|
|
</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>sdl-jstest</title>
|
|
<para>
|
|
sdl-jstest lets you see events as games using SDL see them. This is
|
|
very important when you want to set and test the SDL_LINUX_JOYSTICK
|
|
environment variables.
|
|
</para>
|
|
|
|
<para>
|
|
Currently available via:
|
|
</para>
|
|
|
|
<programlisting>$ svn co svn://svn.berlios.de/windstille/trunk/sdl-jstest</programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>xev</title>
|
|
<para>
|
|
xev lets you see the events that Xorg sees. Note however that you
|
|
might not see all events, since some will be grapped by your Window
|
|
manager before they reach xev, this is normal.
|
|
</para>
|
|
<para>
|
|
xev is part of every Linux distribution, on Ubuntu its available via:
|
|
</para>
|
|
|
|
<programlisting>$ apt-get install x11-utils</programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>jscalc</title>
|
|
<para>
|
|
Do not use this tool, for current day joysticks it doesn't do
|
|
anything useful, so don't touch it, it won't fix your problems.
|
|
</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>mouse</title>
|
|
<para>
|
|
No tools for testing the output on /dev/input/mouseX are known.
|
|
</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Note</title>
|
|
<para>
|
|
If the tools provide no output at all, this might not be due to a
|
|
wrong configuration, but due to Xorg grabbing your event device and
|
|
locking it, see Xorg section for possible fixes.
|
|
</para>
|
|
</refsect2>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>EXAMPLES</title>
|
|
<refsect2>
|
|
<title>Keyboard Emulation</title>
|
|
|
|
<para>The following configuration works for games that are
|
|
played with keyboard, like Flash games or games that don't
|
|
support a joystick. You might have to adjust the keybindings
|
|
to fit the game:</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv \
|
|
--ui-clear \
|
|
--ui-buttonmap a=XK_a,b=XK_b,x=XK_x,y=XK_y \
|
|
--ui-buttonmap dl=XK_Left,dr=XK_Right,du=XK_Up,dd=XK_Down]]></programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>
|
|
Prince of Persia or Tomb Raider Anniversary in Wine
|
|
</title>
|
|
|
|
<para>
|
|
Start <command>xboxdrv</command> with:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv --trigger-as-button -s ]]></programlisting>
|
|
|
|
<para>The triggers are not regonized in these games when they
|
|
are analog, so we have to handle them as buttons.</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Fighting games with Datel Arcade Pro Joystick:</title>
|
|
|
|
<para>The left and right trigger get turned into digital buttons. All axis
|
|
except the dpad are ignored. RB and RT are mapped to act as if buttons
|
|
1,2 and 3 are pressed simultaniously (useful for some special
|
|
attacks). Instead of using the native button names, the
|
|
1,2,3,... aliases are used, which makes things easier to edit:</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv --dpad-only \
|
|
--trigger-as-button \
|
|
--buttonmap lb=1,x=2,y=3,lt=4,a=5,b=6,rb=1,rb=2,rb=3,rt=4,rt=5,rt=6]]></programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>CH Flightstick emulation in Dosbox:</title>
|
|
<para>In <filename>dosbox.conf</filename> set:</para>
|
|
|
|
<programlisting><![CDATA[[joystick]
|
|
joysticktype = ch]]></programlisting>
|
|
|
|
<para>Start xboxdrv with:</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv -s \
|
|
--trigger-as-zaxis --square-axis \
|
|
--relative-axis y2=64000 --axismap -y2=x2,x2=y2]]></programlisting>
|
|
|
|
<para>Your right analog stick will act as trottle control, the trigger as
|
|
rudder.</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Sauerbraten</title>
|
|
<para>
|
|
First analogstick gets mapped te cursor keys, second
|
|
analogstick gets mapped to mouse. Note: This is just an
|
|
incomplete example, not a perfectly playable configuration,
|
|
you have to do tweaking yourself.
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv \
|
|
--ui-axismap x2=REL_X:10,y2=REL_Y:-10,x1=KEY_LEFT:KEY_RIGHT,y1=KEY_UP:KEY_DOWN \
|
|
--ui-buttonmap a=BTN_RIGHT,b=BTN_LEFT,x=BTN_EXTRA \
|
|
--ui-buttonmap rb=KEY_5,lb=KEY_6,lt=BTN_LEFT,rt=BTN_RIGHT \
|
|
--ui-buttonmap y=KEY_ENTER,dl=KEY_4,dr=KEY_2,du=KEY_1,dd=KEY_3,back=KEY_TAB,start=KEY_ESC \
|
|
-s --deadzone 6000 --dpad-as-button --trigger-as-button]]></programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Warsow</title>
|
|
|
|
<para>
|
|
Note: This is just an incomplete example, not a perfectly playable
|
|
configuration, you have to do tweaking yourself.
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv \
|
|
--ui-axismap x2=REL_X:10,y2=REL_Y:-10,x1=KEY_A:KEY_D,y1=KEY_W:KEY_S \
|
|
--ui-buttonmap a=KEY_LEFTSHIFT,b=BTN_C,x=BTN_EXTRA,y=KEY_C \
|
|
--ui-buttonmap lb=BTN_RIGHT,rb=KEY_SPACE \
|
|
--ui-buttonmap lt=KEY_Z,rt=BTN_LEFT \
|
|
--ui-buttonmap dl=KEY_4,dr=KEY_2,du=REL_WHEEL:-1:150,dd=REL_WHEEL:1:150 \
|
|
--ui-buttonmap back=KEY_TAB,start=KEY_ESC \
|
|
-s --deadzone 6000 --dpad-as-button --trigger-as-button]]></programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Using mouse emulation and joystick at the same time</title>
|
|
<para>
|
|
To use mouse emulation and joystick at the same time you have
|
|
to register two uinput configuration with xboxdrv, this works
|
|
via:
|
|
</para>
|
|
<programlisting><![CDATA[$ xboxdrv \
|
|
--ui-new --mouse
|
|
]]></programlisting>
|
|
<para>
|
|
The <option>--ui-new</option> option will open up a second
|
|
configuration and all configuration options on the right side
|
|
of it will go there, while everything on the left side of it
|
|
will go into the first configuration. Toggling between the
|
|
configurations works with the guide button, you can have as
|
|
many configuratios as you want.
|
|
</para>
|
|
</refsect2>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>SDL Notes</title>
|
|
<para>
|
|
To let SDL know which axis act as a hat and which act as normal axis
|
|
you have to set an environment variable:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[
|
|
$ SDL_LINUX_JOYSTICK="'Xbox Gamepad (userspace driver)' 6 1 0"
|
|
$ export SDL_LINUX_JOYSTICK]]></programlisting>
|
|
|
|
<para>
|
|
You might also need in addition use this (depends on the way SDL was compiled):
|
|
</para>
|
|
|
|
<programlisting><![CDATA[
|
|
$ SDL_JOYSTICK_DEVICE="/dev/input/js0"
|
|
$ export SDL_JOYSTICK_DEVICE]]></programlisting>
|
|
|
|
<para>
|
|
This will let the DPad act as Hat in SDL based application. For
|
|
many games the driver will work without this, but especially in
|
|
Dosbox this variable is very important.
|
|
</para>
|
|
|
|
<para>
|
|
If you use options in xboxdrv that change the number of axis you
|
|
have to adjust the variable accordingly, see:
|
|
</para>
|
|
|
|
<itemizedlist>
|
|
<listitem>
|
|
<para><ulink url="ftp://ptah.lnf.kth.se/pub/misc/sdl-env-vars">ftp://ptah.lnf.kth.se/pub/misc/sdl-env-vars</ulink></para>
|
|
</listitem>
|
|
</itemizedlist>
|
|
|
|
<variablelist>
|
|
<varlistentry>
|
|
<term>SDL_LINUX_JOYSTICK</term>
|
|
<listitem>
|
|
<para>
|
|
Special joystick configuration string for linux. The format is
|
|
<option>"name numaxes numhats numballs"</option>
|
|
where name is the name string of the joystick (possibly in single
|
|
quotes), and the rest are the number of axes, hats and balls
|
|
respectively.
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
<varlistentry>
|
|
<term>SDL_JOYSTICK_DEVICE</term>
|
|
<listitem>
|
|
<para>
|
|
Joystick device to use in the linux joystick driver, in addition to the usual: <filename>/dev/js*</filename>, <filename>/dev/input/event*</filename>, <filename>/dev/input/js*</filename>
|
|
</para>
|
|
</listitem>
|
|
</varlistentry>
|
|
</variablelist>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Troubleshooting</title>
|
|
<refsect2>
|
|
<title>"No Xbox or Xbox360 controller found"</title>
|
|
<para>
|
|
This means that either your controller isn't plugged in or not
|
|
recognized by the driver. To fix this you need to know the idVendor
|
|
and the idProduct numbers, which you can find out via:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ lsusb -v]]></programlisting>
|
|
|
|
<para>Once done you can try to add them to this array in <filename>xpad_device.cpp</filename>:</para>
|
|
|
|
<programlisting><![CDATA[XPadDevice xpad_devices[] = { ... }]]></programlisting>
|
|
|
|
<para>
|
|
If you have success with that, send a patch
|
|
to <email>grumbel@gmx.de</email>, if not, contact me too, I
|
|
might be able to provide additional help.
|
|
</para>
|
|
|
|
<para>
|
|
As an alternative you can also use the --device and --type option to
|
|
enforce a USB device as well as a controller type an bypass any auto
|
|
detection.
|
|
</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>"Unknown data: bytes: 3 Data: ..."</title>
|
|
<para>
|
|
This means that your controller is sending data that isn't understood
|
|
by the driver. If your controller still works, you can just ignore it,
|
|
the Xbox360 controller seems to send out useless data every now and
|
|
then. If your controller does not work and you get plenty of those
|
|
lines when you move the sticks or press buttons it means that your
|
|
controller talks an un-understood protocol and some reverse
|
|
enginiering is required. Contact <email>grumbel@gmx.de</email> and include the output
|
|
of:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ lsusb -v]]></programlisting>
|
|
|
|
<para>Along with all the "Unknown data" lines you get. </para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Program starts and then just does nothing</title>
|
|
<para>
|
|
This is what the program is supposed to do. After you started it, it
|
|
will give you basically two devices, a new /dev/input/eventX and a
|
|
/dev/input/jsX. You can access and test your controller with jstest
|
|
and evtest applications (available from your distribution or in the
|
|
tools/ subdirectory). Or in case you want just see if your driver is
|
|
working correctly you can pass the -v option:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv -v]]></programlisting>
|
|
|
|
<para>
|
|
This will cause the driver to output all the events that it received
|
|
from the controller.
|
|
</para>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>"Error: No stuitable uinput device found"</title>
|
|
<para>
|
|
Make sure that uinput and joydev kernel modules are loaded. Make sure
|
|
that you have a /dev/input/uinput, /dev/uinput or /dev/misc/uinput and
|
|
permissions to access it.
|
|
</para>
|
|
<para>
|
|
Before reporting this as a bug make sure you have tested if the driver
|
|
itself works with:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ xboxdrv --no-uinput -v]]></programlisting>
|
|
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>The wireless controller doesn't work</title>
|
|
<para>
|
|
You have to sync the controller befor it can be used, restart of the
|
|
driver isn't needed and the driver should let you now when it recieves
|
|
a connection after you sync the controller.
|
|
</para>
|
|
</refsect2>
|
|
</refsect1>
|
|
|
|
<refsect1 id="keyboardemulation">
|
|
<title>Keyboard Emulation</title>
|
|
<para>
|
|
When you try to let xboxdrv send a keyboard events
|
|
via <option>--ui-buttonmap</option>
|
|
or <option>--ui-axismap</option> Xorg must register the device
|
|
as keyboard device to work properly. This seems to work
|
|
automatically when you bind more then two keyboard keys, if you
|
|
bind less you need to create the
|
|
file <filename>/etc/hal/fdi/preprobe/xboxdrv.fdi</filename>
|
|
containing:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[
|
|
<?xml version="1.0" encoding="UTF-8"?>
|
|
<deviceinfo version="0.2">
|
|
<device>
|
|
<match key="input.product" string="Xbox Gamepad (userspace driver) - Keyboard Emulation">
|
|
<addset key="info.capabilities" type="strlist">input.keys</addset>
|
|
</match>
|
|
</device>
|
|
</deviceinfo>]]></programlisting>
|
|
|
|
<para>
|
|
This will tell HAL and later Xorg that xboxdrv acts as keyboard.
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Xorg Trouble</title>
|
|
<para>
|
|
If you start xboxdrv and instead of having a fully working
|
|
joystick, you end up controlling the mouse that might be due to
|
|
recent changes in Xorg and its device hotplug handling. There
|
|
are four workarounds, the one that involves
|
|
editing <filename>/etc/hal/fdi/policy/preferences.fdi</filename>
|
|
is the recommont one.
|
|
</para>
|
|
|
|
<refsect2>
|
|
<title>Temporary workaround using hal-device</title>
|
|
<para>
|
|
Get the device id from hal:
|
|
</para>
|
|
|
|
<programlisting>$ hal-find-by-property --key 'info.product' --string 'Xbox Gamepad (userspace driver)'</programlisting>
|
|
|
|
<para>Then remove the device from hal with:</para>
|
|
|
|
<programlisting>$ hal-device -r $DEVICEID</programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Temporary workaround using xinput</title>
|
|
<para>
|
|
Second workaround works with xinput:
|
|
</para>
|
|
|
|
<programlisting><![CDATA[$ xinput list
|
|
$ xinput set-int-prop $DEVICEID 'Device Enabled' 32 0]]></programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Permanent workaround using .fdi files</title>
|
|
<para>
|
|
The former two workarounds are just temporary and have to be redone
|
|
after each start of xboxdrv, the last workaround is a permanent one:
|
|
</para>
|
|
<para>
|
|
You have to edit:
|
|
</para>
|
|
|
|
<para><filename>/etc/hal/fdi/policy/preferences.fdi</filename></para>
|
|
|
|
<para>And insert the following lines:</para>
|
|
|
|
<programlisting><![CDATA[
|
|
<match key="input.product" string="Xbox Gamepad (userspace driver)">
|
|
<remove key="input.x11_driver" />
|
|
</match>]]></programlisting>
|
|
</refsect2>
|
|
|
|
<refsect2>
|
|
<title>Permanent workaround by disabling device auto detection</title>
|
|
<para>
|
|
A fourth workaround involved disabling the autodetection of Xorg
|
|
completly, you can do that by adding the following lines to
|
|
<filename>/etc/X11/xorg.conf</filename>:</para>
|
|
|
|
<programlisting><![CDATA[Section "ServerFlags"
|
|
Option "AutoAddDevices" "False"
|
|
EndSection]]></programlisting>
|
|
|
|
<para>
|
|
Note that without auto detection you will have to manually configure
|
|
all your mice and keyboards or your Xorg Server won't start up
|
|
properly. So unless you are already familiar with editing Xorg you
|
|
better avoid this workaround. Workaround 3) has basically the same
|
|
effect, except that auto detection only gets disabled for the single
|
|
device it is causing problems.
|
|
</para>
|
|
</refsect2>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Wacom Trouble</title>
|
|
<para>
|
|
In recent kernels a Wacom graphic tablet creates a joystick device, so
|
|
xboxdrv or any other real joysticks ends up as <filename>/dev/input/js1</filename> instead
|
|
of <filename>/dev/input/js0</filename>. In many games this causes the joystick to not
|
|
function any more.
|
|
</para>
|
|
|
|
<para>A temporary workaround for this is to simply delete the joystick
|
|
device js0 and replace it with a symbolic link js1 via:
|
|
</para>
|
|
|
|
<programlisting>$ sudo ln -sf /dev/input/js1 /dev/input/js0</programlisting>
|
|
|
|
<para>
|
|
This workaround will only last till the next reboot, since the device
|
|
names are dynamically created, but for the time being there doesn't
|
|
seem to any other way to easily work around this issue.
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>uinput Trouble</title>
|
|
<para>
|
|
On Ubuntu 9.04 the permissions of the uinput device have changed to
|
|
0640, meaning only root has access to the device. To change this back
|
|
so that users in the group root have access the device and in turn can
|
|
run xboxdrv without sudo you have to create a file called:
|
|
</para>
|
|
<para>
|
|
<filename>/etc/udev/rules.d/55-permissions-uinput.rules</filename>
|
|
</para>
|
|
<para>
|
|
With the content:
|
|
</para>
|
|
<programlisting>KERNEL=="uinput", MODE="0660", GROUP="root"</programlisting>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Wine Trouble</title>
|
|
<para>
|
|
When using the Xbox360 gamepad in Wine it is not specially handled as
|
|
Xbox360 gamepad, this means games will not display the proper button
|
|
labels, but just numbers (i.e. 'Btn1' instead of 'A' for
|
|
example). Aside from that it should work fine.
|
|
</para>
|
|
<para>
|
|
XInput support (the DirectInput replacment, not the Xorg xinput)
|
|
is as of August 2010 not implemented in Wine, so games that
|
|
require XInput and don't have an DirectInput fallback will not
|
|
work with a Xbox360 controller, unofficial patches however do exist.
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Force Feedback Programming</title>
|
|
<para>
|
|
For documentation on the FF interface see:
|
|
</para>
|
|
|
|
<itemizedlist>
|
|
<listitem><para><ulink url="http://github.com/github/linux-2.6/blob/f3b8436ad9a8ad36b3c9fa1fe030c7f38e5d3d0b/Documentation/input/ff.txt">http://github.com/github/linux-2.6/blob/f3b8436ad9a8ad36b3c9fa1fe030c7f38e5d3d0b/Documentation/input/ff.txt</ulink></para></listitem>
|
|
<listitem><para><filename>/usr/include/linux/input.h</filename></para></listitem>
|
|
</itemizedlist>
|
|
|
|
<para>
|
|
Additional, non Linux related, force feedback related
|
|
information can be found at:
|
|
</para>
|
|
|
|
<itemizedlist>
|
|
<listitem><para><ulink url="http://www.immersion.com/developer/downloads/ImmFundamentals/HTML/"></ulink></para></listitem>
|
|
<listitem><para><ulink url="http://msdn.microsoft.com/en-us/library/bb219655(VS.85).aspx"></ulink></para></listitem>
|
|
</itemizedlist>
|
|
|
|
<para><command>fftest</command> is an application you can use to test the force feedback
|
|
interface.</para>
|
|
|
|
<para>Force feedback is disabed by default since it seems to causes trouble
|
|
in certain application, namely "Tomb Raider: Legend" when run in Wine
|
|
it crashes at startup when rumble is enabled, while it works perfectly
|
|
normal when rumble is disabled.</para>
|
|
|
|
<para>"Tomb Raider: Anniversary" running in Wine seems to work together with
|
|
xboxdrv and rumble, but hasn't been intensivly tested.</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Writing Start-Up Scripts for Games</title>
|
|
<para>When you want configurability and automatic launching, it is recomment
|
|
that you write little startup scripts for your games, such as this:</para>
|
|
|
|
<programlisting><![CDATA[#!/bin/sh
|
|
|
|
# Start xboxdrv and remember its PID in the variable XBOXPID
|
|
xboxdrv --trigger-as-button -s &
|
|
XBOXPID=$!
|
|
|
|
# Give xboxdrv a second to startup and create the device
|
|
sleep 1
|
|
|
|
# Launch your favorite game
|
|
your_favorite_game
|
|
|
|
# Kill xboxdrv and wait for it to finish
|
|
kill $XBOXPID
|
|
wait $XBOXPID
|
|
|
|
# EOF #]]></programlisting>
|
|
|
|
<para>That way you can individually configure every game and not
|
|
have to worry about launching xboxdrv manually.</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Bugs</title>
|
|
<para>
|
|
X11 keysyms might not work correctly in <option>--ui-buttonmap a=XK_Foobar</option>
|
|
when Foobar is mapped to multiple keycodes in the keymap.
|
|
</para>
|
|
|
|
<para>Workaround: Use <keysym>KEY_</keysym> instead or cleanup your keymap</para>
|
|
|
|
<para>
|
|
Force feedback support is brittle, if you Ctrl-c the driver in the
|
|
wrong moment you will end up with a dead uninterruptable process and
|
|
basically have to reboot. This looks like it might be a kernel issue
|
|
and not a xboxdrv one.
|
|
</para>
|
|
|
|
<para>
|
|
Workaround: Kill the app that uses xboxdrv before xboxdrv itself.
|
|
</para>
|
|
|
|
<para>
|
|
Report bugs to Ingo Ruhnke <email>grumbel@gmx.de</email>.
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>Copyright</title>
|
|
<para>
|
|
Copyright © 2010 Ingo Ruhnke <email>grumbel@gmx.de</email>
|
|
License GPLv3+: GNU GPL version 3 or later
|
|
<ulink url="http://gnu.org/licenses/gpl.html" />. This is free software: you
|
|
are free to change and redistribute it. There is NO WARRANTY,
|
|
to the extent permitted by law.
|
|
</para>
|
|
</refsect1>
|
|
|
|
<refsect1>
|
|
<title>See also</title>
|
|
<para>
|
|
<citerefentry>
|
|
<refentrytitle>xboxdrv-daemon</refentrytitle>
|
|
<manvolnum>1</manvolnum>
|
|
</citerefentry>,
|
|
<citerefentry>
|
|
<refentrytitle>evtest</refentrytitle>
|
|
<manvolnum>1</manvolnum>
|
|
</citerefentry>,
|
|
<citerefentry>
|
|
<refentrytitle>jstest</refentrytitle>
|
|
<manvolnum>1</manvolnum>
|
|
</citerefentry>,
|
|
<citerefentry>
|
|
<refentrytitle>xev</refentrytitle>
|
|
<manvolnum>1</manvolnum>
|
|
</citerefentry>,
|
|
<citerefentry>
|
|
<refentrytitle>fftest</refentrytitle>
|
|
<manvolnum>1</manvolnum>
|
|
</citerefentry>,
|
|
<citerefentry>
|
|
<refentrytitle>lsusb</refentrytitle>
|
|
<manvolnum>1</manvolnum>
|
|
</citerefentry>
|
|
</para>
|
|
</refsect1>
|
|
</refentry>
|