docs: add README with build/usage instructions
Signed-off-by: NotAShelf <raf@notashelf.dev> Change-Id: I6a6a6964b03685f7d0b7060c928d3bd8b28f5819
This commit is contained in:
parent
6abac69e75
commit
1d1d0f96c7
1 changed files with 383 additions and 0 deletions
383
docs/README.md
Normal file
383
docs/README.md
Normal file
|
@ -0,0 +1,383 @@
|
|||
# Deepcool
|
||||
|
||||
An unofficial Linux kernel module Provides early boot support and sysfs
|
||||
interface for monitoring and controlling device display modes for Deepcool
|
||||
Digital USB HID devices (CPU coolers, AIOs, cases). The module runs directly in
|
||||
kernel space, providing early boot support and standard Linux interfaces for
|
||||
controlling Deepcool Digital USB HID devices.
|
||||
|
||||
## Motive
|
||||
|
||||
[deepcool-digital-linux]: https://github.com/Nortank12/deepcool-digital-linux
|
||||
|
||||
This project exists solely because I hoped to replace the userspace daemon with
|
||||
a kernel module that is always loaded. Simply put, I don't need it to be an
|
||||
userspace daemon, and I am under the impression that using the Linux kernel APIs
|
||||
directly will yield be better performance, or at least less overhead.
|
||||
|
||||
[deepcool-digital-linux] is an userspace daemon that does a little more than
|
||||
this project, and is a more suitable replacement if you are not looking to taint
|
||||
your kernel with out-of-tree modules. Not that a "tainted kernel" is inherently
|
||||
bad, though. There are different usecases. See below for a better comparison
|
||||
between **Deepcool** (this module) and **deepcool-digital-linux**, the userspace
|
||||
daemon.
|
||||
|
||||
## Features
|
||||
|
||||
The primary feature of Deepcool is that it supports early boot, or in other
|
||||
words, its functionality fully available _as soon as you reach the kernel_. Rest
|
||||
of the functionality is almost identical with little caveats.
|
||||
|
||||
- **Real-time Monitoring**: CPU temperature, usage, power, frequency
|
||||
- **Display Modes**: Auto-cycling, CPU temp, CPU usage, CPU power, and more
|
||||
- **Sysfs Interface**: Standard Linux interface for configuration
|
||||
- **Automatic Device Detection**: Supports most Deepcool Digital product series
|
||||
- **Multiple Device Series Support**:
|
||||
- AK Series (AK400 DIGITAL, AK500 DIGITAL, AK620 DIGITAL)
|
||||
- AK400 PRO, AK620 PRO
|
||||
- LS Series
|
||||
- AG Series
|
||||
- LQ Series
|
||||
- LD Series
|
||||
- LP Series
|
||||
- CH Series (Gen1, Gen2, CH510)
|
||||
|
||||
> [!INFO]
|
||||
> **For device support, please refer to the
|
||||
> [device support matrix](#device-support-matrix) below**
|
||||
|
||||
If you believe there is anything missing that belongs in a kernel module, please
|
||||
feel free to let me know. I'd be happy to discuss.
|
||||
|
||||
## Usage
|
||||
|
||||
To use Deepcool, you must load it in your kernel. The installation steps may
|
||||
differ based on your distro, but most distros should be supported out of the
|
||||
box.
|
||||
|
||||
### Requirements
|
||||
|
||||
- Linux kernel 5.10 or later
|
||||
- Kernel headers for your running kernel
|
||||
- Build essentials (gcc, make)
|
||||
- Root/sudo access for installation
|
||||
|
||||
#### Kernel Configuration
|
||||
|
||||
The following kernel options must be enabled:
|
||||
|
||||
```plaintext
|
||||
CONFIG_HID=y or m
|
||||
CONFIG_HIDRAW=y or m
|
||||
CONFIG_USB_HID=y or m
|
||||
CONFIG_THERMAL=y
|
||||
CONFIG_CPU_FREQ=y
|
||||
CONFIG_CPUFREQ_STATS=y
|
||||
CONFIG_SYSFS=y
|
||||
```
|
||||
|
||||
Most of those features are enabled on most kernels, but is best to check before
|
||||
you build. `zcat` can be used to check the configuration for your current kernel
|
||||
configuration:
|
||||
|
||||
```sh
|
||||
$ zcat /proc/config.gz | grep CONFIG_HID
|
||||
# => CONFIG_HIDRAW=y
|
||||
```
|
||||
|
||||
For Intel RAPL power monitoring:
|
||||
|
||||
```plaintext
|
||||
CONFIG_POWERCAP=y
|
||||
CONFIG_INTEL_RAPL=y or m
|
||||
```
|
||||
|
||||
### Building
|
||||
|
||||
Once you confirm that you meet the requirements, you may build the kernel
|
||||
module. To build, navigate to the cloned directory and run `make`.
|
||||
|
||||
```bash
|
||||
$ make
|
||||
#=> The module will be built as `deepcool.ko`.
|
||||
```
|
||||
|
||||
## Installation
|
||||
|
||||
### Manual Installation
|
||||
|
||||
[DKMS framework]: https://wiki.archlinux.org/title/Dynamic_Kernel_Module_Support
|
||||
|
||||
The Makefile provides a task to install Deepcool for Linux distributions using
|
||||
the [DKMS framework]. NixOS should refer to the section below.
|
||||
|
||||
```bash
|
||||
# Build the module
|
||||
make
|
||||
|
||||
# Install to system
|
||||
sudo make dkms-install
|
||||
|
||||
# Load the module
|
||||
sudo modprobe deepcool
|
||||
```
|
||||
|
||||
## Automatic Loading on Boot
|
||||
|
||||
Create a module configuration file:
|
||||
|
||||
```bash
|
||||
sudo tee /etc/modules-load.d/deepcool_digital.conf <<EOF
|
||||
deepcool
|
||||
EOF
|
||||
```
|
||||
|
||||
Once loaded, the module automatically detects connected Deepcool Digital devices
|
||||
and creates sysfs entries under `/sys/bus/hid/drivers/deepcool_digital/`.
|
||||
|
||||
### Finding Your Device
|
||||
|
||||
```bash
|
||||
# List all detected devices
|
||||
ls /sys/bus/hid/drivers/deepcool_digital/
|
||||
```
|
||||
|
||||
The device path will typically be something like:
|
||||
|
||||
```plaintext
|
||||
/sys/bus/hid/drivers/deepcool_digital/0003:3633:0007.XXXX/
|
||||
```
|
||||
|
||||
Replace `0003:3633:0007.XXXX` with your actual device path in the examples
|
||||
below.
|
||||
|
||||
### Sysfs Attributes
|
||||
|
||||
This module uses sysfs to interact with the module. You may find configuration
|
||||
attributes below.
|
||||
|
||||
#### Configuration Attributes (Read/Write)
|
||||
|
||||
**`mode`** - Display mode
|
||||
|
||||
```bash
|
||||
# View current mode
|
||||
cat mode
|
||||
|
||||
# Set mode
|
||||
echo "cpu_temp" > mode
|
||||
|
||||
# Available modes:
|
||||
# - auto (cycle between supported metrics)
|
||||
# - cpu_temp (CPU temperature)
|
||||
# - cpu_usage (CPU usage percentage)
|
||||
# - cpu_power (CPU power consumption)
|
||||
# - cpu_freq (CPU frequency)
|
||||
# - cpu_fan (CPU fan speed, if supported)
|
||||
# - gpu_temp (GPU temperature, if supported)
|
||||
# - gpu_usage (GPU usage, if supported)
|
||||
# - gpu_power (GPU power, if supported)
|
||||
```
|
||||
|
||||
**`update_interval`** - Update interval in milliseconds (100-2000)
|
||||
|
||||
```bash
|
||||
# View current interval
|
||||
cat update_interval
|
||||
|
||||
# Set to 500ms
|
||||
echo 500 > update_interval
|
||||
```
|
||||
|
||||
**`fahrenheit`** - Temperature unit (0=Celsius, 1=Fahrenheit)
|
||||
|
||||
```bash
|
||||
# Use Fahrenheit
|
||||
echo 1 > fahrenheit
|
||||
|
||||
# Use Celsius
|
||||
echo 0 > fahrenheit
|
||||
```
|
||||
|
||||
**`alarm`** - Temperature alarm (0=off, 1=on)
|
||||
|
||||
```bash
|
||||
# Enable alarm
|
||||
echo 1 > alarm
|
||||
|
||||
# Disable alarm
|
||||
echo 0 > alarm
|
||||
```
|
||||
|
||||
#### Sensor Attributes (Read-Only)
|
||||
|
||||
**`cpu_temp`** - CPU temperature (°C or °F based on fahrenheit setting)
|
||||
|
||||
```bash
|
||||
cat cpu_temp
|
||||
```
|
||||
|
||||
**`cpu_usage`** - CPU usage percentage (0-100)
|
||||
|
||||
```bash
|
||||
cat cpu_usage
|
||||
```
|
||||
|
||||
**`cpu_power`** - CPU power consumption (Watts)
|
||||
|
||||
```bash
|
||||
cat cpu_power
|
||||
```
|
||||
|
||||
**`cpu_freq`** - CPU frequency (MHz)
|
||||
|
||||
```bash
|
||||
cat cpu_freq
|
||||
```
|
||||
|
||||
### Examples
|
||||
|
||||
#### Set CPU temperature display with Fahrenheit
|
||||
|
||||
```bash
|
||||
echo "cpu_temp" > /sys/bus/hid/drivers/deepcool_digital/0003:3633:0007.XXXX/mode
|
||||
echo 1 > fahrenheit
|
||||
echo 1 > alarm
|
||||
```
|
||||
|
||||
#### Auto-cycle between metrics at 1-second intervals
|
||||
|
||||
```bash
|
||||
echo "auto" > /sys/bus/hid/drivers/deepcool_digital/0003:3633:0007.XXXX/mode
|
||||
echo 1000 > /sys/bus/hid/drivers/deepcool_digital/0003:3633:0007.XXXX/update_interval
|
||||
```
|
||||
|
||||
#### Monitor CPU power consumption
|
||||
|
||||
```bash
|
||||
echo "cpu_power" > /sys/bus/hid/drivers/deepcool_digital/0003:3633:0007.XXXX/mode
|
||||
```
|
||||
|
||||
#### Create a simple monitoring script
|
||||
|
||||
```bash
|
||||
#!/usr/bin/env bash
|
||||
DEVICE="/sys/bus/hid/drivers/deepcool_digital/0003:3633:0007.XXXX"
|
||||
|
||||
while true; do
|
||||
echo "CPU Temp: $(cat $DEVICE/cpu_temp)°C"
|
||||
echo "CPU Usage: $(cat $DEVICE/cpu_usage)%"
|
||||
echo "CPU Power: $(cat $DEVICE/cpu_power)W"
|
||||
echo "CPU Freq: $(cat $DEVICE/cpu_freq)MHz"
|
||||
echo "---"
|
||||
sleep 1
|
||||
done
|
||||
```
|
||||
|
||||
## Device Support Matrix
|
||||
|
||||
<!-- markdownlint-disable MD013 -->
|
||||
|
||||
| Device Series | Auto Mode | Alarm | Fahrenheit | Secondary Display | Rotation |
|
||||
| ------------- | --------- | ------ | ---------- | ----------------- | -------- |
|
||||
| AK Series | ✓ | ✓ | ✓ | ✗ | ✗ |
|
||||
| AK400 PRO | ✓ | HW | ✓ | ✗ | ✗ |
|
||||
| AK620 PRO | ✓ | HW | ✓ | ✗ | ✗ |
|
||||
| LS Series | ✓ | ✓ | ✓ | ✗ | ✗ |
|
||||
| AG Series | ✓ | ✓ | ✗ | ✗ | ✗ |
|
||||
| LP Series | ✓ | ✗ | ✓ | ✓ | ✓ |
|
||||
| LQ Series | ✓ | ✓ | ✓ | ✗ | ✗ |
|
||||
| CH Series | ✓ | varies | varies | varies | ✗ |
|
||||
|
||||
<!-- markdownlint-enabled MD013 -->
|
||||
|
||||
**Legend:**
|
||||
|
||||
| Supported | Not Supported | Hardware-Controlled (Fixed thresholds) |
|
||||
| :-------: | :-----------: | :------------------------------------: |
|
||||
| ✓ | ✗ | HW |
|
||||
|
||||
## How It Works
|
||||
|
||||
### Initialization
|
||||
|
||||
1. Module loads and registers HID driver
|
||||
2. Kernel calls `probe()` when device is detected
|
||||
3. Driver identifies device series and capabilities
|
||||
4. Sysfs attributes are created
|
||||
5. Work queue is scheduled for periodic updates
|
||||
|
||||
### Runtime Operation
|
||||
|
||||
```
|
||||
Timer fires (every update_interval ms)
|
||||
↓
|
||||
Work queue handler executes
|
||||
↓
|
||||
Read CPU sensors:
|
||||
* Temperature from thermal subsystem
|
||||
* Usage from kernel CPU statistics
|
||||
* Frequency from CPUFreq
|
||||
* Power from Intel RAPL
|
||||
↓
|
||||
Build device-specific packet
|
||||
↓
|
||||
Send HID output report over USB
|
||||
↓
|
||||
Display updates
|
||||
↓
|
||||
Reschedule work queue
|
||||
```
|
||||
|
||||
### User Interaction
|
||||
|
||||
```
|
||||
User writes to sysfs attribute
|
||||
↓
|
||||
Kernel calls store() handler
|
||||
↓
|
||||
Validate input
|
||||
↓
|
||||
Update device configuration
|
||||
↓
|
||||
Next work cycle uses new configuration
|
||||
```
|
||||
|
||||
## Contributing
|
||||
|
||||
Contributions are always welcome! When submitting patches, please try to follow
|
||||
the several recommendations:
|
||||
|
||||
- Tabs and 8 character indentations are heretical. A cardinal sin. Please don't
|
||||
use those.
|
||||
- Testing on your own hardware is recommended, but not a hard-requirement
|
||||
- If there is device-specific behaviour (or non-behaviour), please document it!
|
||||
- Include dmesg output for new devices
|
||||
|
||||
Refer to [BUILD.md](./BUILD.md) for additional notes on working with and
|
||||
building Deepcool.
|
||||
|
||||
## License
|
||||
|
||||
GPL-2.0-only
|
||||
|
||||
## Attributions
|
||||
|
||||
[Nortank12]: https://github.com/Nortank12
|
||||
[zenpower]: https://github.com/ocerman/zenpower
|
||||
|
||||
There are a few projects that I would like to give credit to. Namely I'd like to
|
||||
thank the [deepcool-digital-linux] project for the inspiration and the device
|
||||
data. This project would be incredibly annoying to do without the efforts of
|
||||
[Nortank12]. Please make sure to give them some love!
|
||||
|
||||
I'd like to extend my thanks to the [zenpower] project that provided insight
|
||||
into developing Linux kernel modules, and the DKMS installation tasks. Thank you
|
||||
:)
|
||||
|
||||
## See Also
|
||||
|
||||
- [deepcool-digital-linux]: an userspace daemon providing similar functionality,
|
||||
with better GPU support.
|
||||
- Linux HID documentation: `Documentation/hid/` in kernel source
|
||||
- Sysfs documentation: `Documentation/filesystems/sysfs.txt`
|
Loading…
Add table
Add a link
Reference in a new issue