Become a Patron! - Asus Linux Website
WARNING: Many features are developed in tandem with kernel patches. If you see a feature is missing you either need a patched kernel or latest release.
asusd
is a utility for Linux to control many aspects of various ASUS laptops
but can also be used with non-asus laptops with reduced features.
Now includes a GUI, rog-control-center
.
The minimum supported kernel version is 6.6
The main goal of this work is to provide a safe and easy to use abstraction over various laptop features via DBUS, and to provide some helpful defaults and other behaviour such as toggling throttle/profile on AC/battery change.
- Provide safe dbus interface
- Respect the users resources: be small, light, and fast
Point 4? asusd currently uses a tiny fraction of cpu time, and less than 1Mb of ram, the way a system-level daemon should. Languages such as JS and python should never be used for system level daemons (please stop).
The level of support for laptops is dependent on folks submitting data to include in ./rog-aura/data/layouts/aura_support.ron
, typically installed in /usr/share/asusd/aura_support.ron
. This is because the controller used for keyboards and LEDs is used across many years and many laptop models, all with different firmware configurations - the only way to track this is with the file mentioned above. Why not just enable all by default? Because it confuses people.
See the rog-aura readme for more details.
Most ASUS gaming laptops that have a USB keyboard. If lsusb
shows something similar
to this:
Bus 001 Device 002: ID 0b05:1866 ASUSTek Computer, Inc. N-KEY Device
or
Bus 003 Device 002: ID 0b05:19b6 ASUSTek Computer, Inc. [unknown]
then it may work without tweaks. Technically all other functions except the LED and AniMe parts should work regardless of your latop make.
- System daemon
- GUI app (includes tray and notifications)
- Setting/modifying built-in LED modes
- Per-key LED setting
- Fancy LED modes (See examples) (currently being reworked)
- AniMatrix display on G14 and M16 models that include it
- Set battery charge limit (with kernel supporting this)
- Fan curve control on supported laptops (G14/G15, some TUF like FA507)
- Toggle bios setting for boot/POST sound
- Toggle GPU MUX (g-sync, or called MUX on 2022+ laptops)
A gui is now in the repo - ROG Control Center. At this time it is still a WIP, but it has almost all features in place already.
Requirements are rust >= 1.75 installed from rustup.io if the distro provided version is too old, and make
.
Ubuntu (unsuported):
apt install libgtk-3-dev libpango1.0-dev libgdk-pixbuf-2.0-dev libglib2.0-dev cmake libclang-dev libudev-dev libayatana-appindicator3-1
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
source "$HOME/.cargo/env"
make
sudo make install
popos (unsuported):
sudo apt install cmake libclang-dev libudev-dev libgtk-3-dev libclang-dev libglib2.0-dev libatkmm-1.6-dev libpangomm-1.4-dev librust-gdk-pixbuf-dev
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
source "$HOME/.cargo/env"
make
sudo make install
fedora:
dnf install cmake clang-devel systemd-devel glib2-devel cairo-devel atkmm-devel pangomm-devel gdk-pixbuf2-devel gtk3-devel libappindicator-gtk3
make
sudo make install
openSUSE:
Works with KDE Plasma (without GTK packages)
zypper in -t pattern devel_basis
zypper in rustup make cmake systemd-devel clang-devel llvm-devel gdk-pixbuf-devel cairo-devel pango-devel freetype-devel gtk3-devel libexpat-devel libayatana-indicator3-7
make
sudo make install
- Fedora copr = https://copr.fedorainfracloud.org/coprs/lukenukem/asus-linux/
- openSUSE = https://download.opensuse.org/repositories/home:/luke_nukem:/asus/
- Ubuntu = not supported due to packaging woes, but you can build and install on your own.
=======
The default init method is to use the udev rule, this ensures that the service is started when the device is initialised and ready.
If you are upgrading from a previous installed version, you will need to restart the service or reboot.
$ systemctl daemon-reload && systemctl restart asusd
You may also need to activate the service for debian install. If running Pop!_OS, I suggest disabling system76-power
gnome-shell extension and systemd service.
Run sudo make uninstall
in the source repo, and remove /etc/asusd/
.
See CONTRIBUTING.md
. Additionally, also do cargo clean
and cargo test
on first checkout to ensure the commit hooks are used (via cargo-husky
).
Generation of the bindings with make bindings
requires typeshare
to be installed.
Dbus introsepction XML requires with make introspection
requires anime_sim
to be running before starting asusd
.
A simulator using SDL2 can be built using cargo build --package rog_simulators
and run with ./target/debug/anime_sim
. Once started asusd
will need restarting to pick it up. If running this sim on a laptop with the display, the simulated display will be used instead of the physical display.
Please file a support request.
Mozilla Public License 2 (MPL-2.0)
ASUS and ROG Trademark is either a US registered trademark or trademark of ASUSTeK Computer Inc. in the United States and/or other countries.
Reference to any ASUS products, services, processes, or other information and/or use of ASUS Trademarks does not constitute or imply endorsement, sponsorship, or recommendation thereof by ASUS.
The use of ROG and ASUS trademarks within this website and associated tools and libraries is only to provide a recognisable identifier to users to enable them to associate that these tools will work with ASUS ROG laptops.