xref: /linux/drivers/hwmon/aquacomputer_d5next.c (revision 3fa7187eceee11998f756481e45ce8c4f9d9dc48)
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * hwmon driver for Aquacomputer devices (D5 Next, Farbwerk, Farbwerk 360, Octo,
4  * Quadro, High Flow Next, Aquaero, Aquastream Ultimate, Leakshield)
5  *
6  * Aquacomputer devices send HID reports (with ID 0x01) every second to report
7  * sensor values, except for devices that communicate through the
8  * legacy way (currently, Poweradjust 3).
9  *
10  * Copyright 2021 Aleksa Savic <savicaleksa83@gmail.com>
11  * Copyright 2022 Jack Doan <me@jackdoan.com>
12  */
13 
14 #include <linux/crc16.h>
15 #include <linux/debugfs.h>
16 #include <linux/hid.h>
17 #include <linux/hwmon.h>
18 #include <linux/jiffies.h>
19 #include <linux/module.h>
20 #include <linux/mutex.h>
21 #include <linux/seq_file.h>
22 #include <asm/unaligned.h>
23 
24 #define USB_VENDOR_ID_AQUACOMPUTER	0x0c70
25 #define USB_PRODUCT_ID_AQUAERO		0xf001
26 #define USB_PRODUCT_ID_FARBWERK		0xf00a
27 #define USB_PRODUCT_ID_QUADRO		0xf00d
28 #define USB_PRODUCT_ID_D5NEXT		0xf00e
29 #define USB_PRODUCT_ID_FARBWERK360	0xf010
30 #define USB_PRODUCT_ID_OCTO		0xf011
31 #define USB_PRODUCT_ID_HIGHFLOWNEXT	0xf012
32 #define USB_PRODUCT_ID_LEAKSHIELD	0xf014
33 #define USB_PRODUCT_ID_AQUASTREAMXT	0xf0b6
34 #define USB_PRODUCT_ID_AQUASTREAMULT	0xf00b
35 #define USB_PRODUCT_ID_POWERADJUST3	0xf0bd
36 
37 enum kinds {
38 	d5next, farbwerk, farbwerk360, octo, quadro,
39 	highflownext, aquaero, poweradjust3, aquastreamult,
40 	aquastreamxt, leakshield
41 };
42 
43 static const char *const aqc_device_names[] = {
44 	[d5next] = "d5next",
45 	[farbwerk] = "farbwerk",
46 	[farbwerk360] = "farbwerk360",
47 	[octo] = "octo",
48 	[quadro] = "quadro",
49 	[highflownext] = "highflownext",
50 	[leakshield] = "leakshield",
51 	[aquastreamxt] = "aquastreamxt",
52 	[aquaero] = "aquaero",
53 	[aquastreamult] = "aquastreamultimate",
54 	[poweradjust3] = "poweradjust3"
55 };
56 
57 #define DRIVER_NAME			"aquacomputer_d5next"
58 
59 #define STATUS_REPORT_ID		0x01
60 #define STATUS_UPDATE_INTERVAL		(2 * HZ)	/* In seconds */
61 #define SERIAL_PART_OFFSET		2
62 
63 #define CTRL_REPORT_ID			0x03
64 #define AQUAERO_CTRL_REPORT_ID		0x0b
65 
66 /* The HID report that the official software always sends
67  * after writing values, currently same for all devices
68  */
69 #define SECONDARY_CTRL_REPORT_ID	0x02
70 #define SECONDARY_CTRL_REPORT_SIZE	0x0B
71 
72 static u8 secondary_ctrl_report[] = {
73 	0x02, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x34, 0xC6
74 };
75 
76 /* Secondary HID report values for Aquaero */
77 #define AQUAERO_SECONDARY_CTRL_REPORT_ID	0x06
78 #define AQUAERO_SECONDARY_CTRL_REPORT_SIZE	0x07
79 
80 static u8 aquaero_secondary_ctrl_report[] = {
81 	0x06, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00
82 };
83 
84 /* Report IDs for legacy devices */
85 #define AQUASTREAMXT_STATUS_REPORT_ID	0x04
86 
87 #define POWERADJUST3_STATUS_REPORT_ID	0x03
88 
89 /* Data types for reading and writing control reports */
90 #define AQC_8		0
91 #define AQC_BE16	1
92 
93 /* Info, sensor sizes and offsets for most Aquacomputer devices */
94 #define AQC_SERIAL_START		0x3
95 #define AQC_FIRMWARE_VERSION		0xD
96 
97 #define AQC_SENSOR_SIZE			0x02
98 #define AQC_SENSOR_NA			0x7FFF
99 #define AQC_FAN_PERCENT_OFFSET		0x00
100 #define AQC_FAN_VOLTAGE_OFFSET		0x02
101 #define AQC_FAN_CURRENT_OFFSET		0x04
102 #define AQC_FAN_POWER_OFFSET		0x06
103 #define AQC_FAN_SPEED_OFFSET		0x08
104 
105 /* Specs of the Aquaero fan controllers */
106 #define AQUAERO_SERIAL_START			0x07
107 #define AQUAERO_FIRMWARE_VERSION		0x0B
108 #define AQUAERO_NUM_FANS			4
109 #define AQUAERO_NUM_SENSORS			8
110 #define AQUAERO_NUM_VIRTUAL_SENSORS		8
111 #define AQUAERO_NUM_CALC_VIRTUAL_SENSORS	4
112 #define AQUAERO_NUM_FLOW_SENSORS		2
113 #define AQUAERO_CTRL_REPORT_SIZE		0xa93
114 #define AQUAERO_CTRL_PRESET_ID			0x5c
115 #define AQUAERO_CTRL_PRESET_SIZE		0x02
116 #define AQUAERO_CTRL_PRESET_START		0x55c
117 
118 /* Sensor report offsets for Aquaero fan controllers */
119 #define AQUAERO_SENSOR_START			0x65
120 #define AQUAERO_VIRTUAL_SENSOR_START		0x85
121 #define AQUAERO_CALC_VIRTUAL_SENSOR_START	0x95
122 #define AQUAERO_FLOW_SENSORS_START		0xF9
123 #define AQUAERO_FAN_VOLTAGE_OFFSET		0x04
124 #define AQUAERO_FAN_CURRENT_OFFSET		0x06
125 #define AQUAERO_FAN_POWER_OFFSET		0x08
126 #define AQUAERO_FAN_SPEED_OFFSET		0x00
127 static u16 aquaero_sensor_fan_offsets[] = { 0x167, 0x173, 0x17f, 0x18B };
128 
129 /* Control report offsets for the Aquaero fan controllers */
130 #define AQUAERO_TEMP_CTRL_OFFSET	0xdb
131 #define AQUAERO_FAN_CTRL_MIN_PWR_OFFSET	0x04
132 #define AQUAERO_FAN_CTRL_MAX_PWR_OFFSET	0x06
133 #define AQUAERO_FAN_CTRL_SRC_OFFSET	0x10
134 static u16 aquaero_ctrl_fan_offsets[] = { 0x20c, 0x220, 0x234, 0x248 };
135 
136 /* Specs of the D5 Next pump */
137 #define D5NEXT_NUM_FANS			2
138 #define D5NEXT_NUM_SENSORS		1
139 #define D5NEXT_NUM_VIRTUAL_SENSORS	8
140 #define D5NEXT_CTRL_REPORT_SIZE		0x329
141 
142 /* Sensor report offsets for the D5 Next pump */
143 #define D5NEXT_POWER_CYCLES		0x18
144 #define D5NEXT_COOLANT_TEMP		0x57
145 #define D5NEXT_PUMP_OFFSET		0x6c
146 #define D5NEXT_FAN_OFFSET		0x5f
147 #define D5NEXT_5V_VOLTAGE		0x39
148 #define D5NEXT_12V_VOLTAGE		0x37
149 #define D5NEXT_VIRTUAL_SENSORS_START	0x3f
150 static u16 d5next_sensor_fan_offsets[] = { D5NEXT_PUMP_OFFSET, D5NEXT_FAN_OFFSET };
151 
152 /* Control report offsets for the D5 Next pump */
153 #define D5NEXT_TEMP_CTRL_OFFSET		0x2D	/* Temperature sensor offsets location */
154 static u16 d5next_ctrl_fan_offsets[] = { 0x97, 0x42 };	/* Pump and fan speed (from 0-100%) */
155 
156 /* Specs of the Aquastream Ultimate pump */
157 /* Pump does not follow the standard structure, so only consider the fan */
158 #define AQUASTREAMULT_NUM_FANS		1
159 #define AQUASTREAMULT_NUM_SENSORS	2
160 
161 /* Sensor report offsets for the Aquastream Ultimate pump */
162 #define AQUASTREAMULT_SENSOR_START		0x2D
163 #define AQUASTREAMULT_PUMP_OFFSET		0x51
164 #define AQUASTREAMULT_PUMP_VOLTAGE		0x3D
165 #define AQUASTREAMULT_PUMP_CURRENT		0x53
166 #define AQUASTREAMULT_PUMP_POWER		0x55
167 #define AQUASTREAMULT_FAN_OFFSET		0x41
168 #define AQUASTREAMULT_PRESSURE_OFFSET		0x57
169 #define AQUASTREAMULT_FLOW_SENSOR_OFFSET	0x37
170 #define AQUASTREAMULT_FAN_VOLTAGE_OFFSET	0x02
171 #define AQUASTREAMULT_FAN_CURRENT_OFFSET	0x00
172 #define AQUASTREAMULT_FAN_POWER_OFFSET		0x04
173 #define AQUASTREAMULT_FAN_SPEED_OFFSET		0x06
174 static u16 aquastreamult_sensor_fan_offsets[] = { AQUASTREAMULT_FAN_OFFSET };
175 
176 /* Spec and sensor report offset for the Farbwerk RGB controller */
177 #define FARBWERK_NUM_SENSORS		4
178 #define FARBWERK_SENSOR_START		0x2f
179 
180 /* Specs of the Farbwerk 360 RGB controller */
181 #define FARBWERK360_NUM_SENSORS			4
182 #define FARBWERK360_NUM_VIRTUAL_SENSORS		16
183 #define FARBWERK360_CTRL_REPORT_SIZE		0x682
184 
185 /* Sensor report offsets for the Farbwerk 360 */
186 #define FARBWERK360_SENSOR_START		0x32
187 #define FARBWERK360_VIRTUAL_SENSORS_START	0x3a
188 
189 /* Control report offsets for the Farbwerk 360 */
190 #define FARBWERK360_TEMP_CTRL_OFFSET		0x8
191 
192 /* Specs of the Octo fan controller */
193 #define OCTO_NUM_FANS			8
194 #define OCTO_NUM_SENSORS		4
195 #define OCTO_NUM_VIRTUAL_SENSORS	16
196 #define OCTO_CTRL_REPORT_SIZE		0x65F
197 
198 /* Sensor report offsets for the Octo */
199 #define OCTO_POWER_CYCLES		0x18
200 #define OCTO_SENSOR_START		0x3D
201 #define OCTO_VIRTUAL_SENSORS_START	0x45
202 static u16 octo_sensor_fan_offsets[] = { 0x7D, 0x8A, 0x97, 0xA4, 0xB1, 0xBE, 0xCB, 0xD8 };
203 
204 /* Control report offsets for the Octo */
205 #define OCTO_TEMP_CTRL_OFFSET		0xA
206 /* Fan speed offsets (0-100%) */
207 static u16 octo_ctrl_fan_offsets[] = { 0x5B, 0xB0, 0x105, 0x15A, 0x1AF, 0x204, 0x259, 0x2AE };
208 
209 /* Specs of Quadro fan controller */
210 #define QUADRO_NUM_FANS			4
211 #define QUADRO_NUM_SENSORS		4
212 #define QUADRO_NUM_VIRTUAL_SENSORS	16
213 #define QUADRO_NUM_FLOW_SENSORS		1
214 #define QUADRO_CTRL_REPORT_SIZE		0x3c1
215 
216 /* Sensor report offsets for the Quadro */
217 #define QUADRO_POWER_CYCLES		0x18
218 #define QUADRO_SENSOR_START		0x34
219 #define QUADRO_VIRTUAL_SENSORS_START	0x3c
220 #define QUADRO_FLOW_SENSOR_OFFSET	0x6e
221 static u16 quadro_sensor_fan_offsets[] = { 0x70, 0x7D, 0x8A, 0x97 };
222 
223 /* Control report offsets for the Quadro */
224 #define QUADRO_TEMP_CTRL_OFFSET		0xA
225 #define QUADRO_FLOW_PULSES_CTRL_OFFSET	0x6
226 static u16 quadro_ctrl_fan_offsets[] = { 0x37, 0x8c, 0xe1, 0x136 }; /* Fan speed offsets (0-100%) */
227 
228 /* Specs of High Flow Next flow sensor */
229 #define HIGHFLOWNEXT_NUM_SENSORS	2
230 #define HIGHFLOWNEXT_NUM_FLOW_SENSORS	1
231 
232 /* Sensor report offsets for the High Flow Next */
233 #define HIGHFLOWNEXT_SENSOR_START	85
234 #define HIGHFLOWNEXT_FLOW		81
235 #define HIGHFLOWNEXT_WATER_QUALITY	89
236 #define HIGHFLOWNEXT_POWER		91
237 #define HIGHFLOWNEXT_CONDUCTIVITY	95
238 #define HIGHFLOWNEXT_5V_VOLTAGE		97
239 #define HIGHFLOWNEXT_5V_VOLTAGE_USB	99
240 
241 /* Specs of the Leakshield */
242 #define LEAKSHIELD_NUM_SENSORS		2
243 
244 /* Sensor report offsets for Leakshield */
245 #define LEAKSHIELD_PRESSURE_ADJUSTED	285
246 #define LEAKSHIELD_TEMPERATURE_1	265
247 #define LEAKSHIELD_TEMPERATURE_2	287
248 #define LEAKSHIELD_PRESSURE_MIN		291
249 #define LEAKSHIELD_PRESSURE_TARGET	293
250 #define LEAKSHIELD_PRESSURE_MAX		295
251 #define LEAKSHIELD_PUMP_RPM_IN		101
252 #define LEAKSHIELD_FLOW_IN		111
253 #define LEAKSHIELD_RESERVOIR_VOLUME	313
254 #define LEAKSHIELD_RESERVOIR_FILLED	311
255 
256 /* Specs of the Aquastream XT pump */
257 #define AQUASTREAMXT_SERIAL_START		0x3a
258 #define AQUASTREAMXT_FIRMWARE_VERSION		0x32
259 #define AQUASTREAMXT_NUM_FANS			2
260 #define AQUASTREAMXT_NUM_SENSORS		3
261 #define AQUASTREAMXT_FAN_STOPPED		0x4
262 #define AQUASTREAMXT_PUMP_CONVERSION_CONST	45000000
263 #define AQUASTREAMXT_FAN_CONVERSION_CONST	5646000
264 #define AQUASTREAMXT_SENSOR_REPORT_SIZE		0x42
265 
266 /* Sensor report offsets and info for Aquastream XT */
267 #define AQUASTREAMXT_SENSOR_START		0xd
268 #define AQUASTREAMXT_FAN_VOLTAGE_OFFSET		0x7
269 #define AQUASTREAMXT_FAN_STATUS_OFFSET		0x1d
270 #define AQUASTREAMXT_PUMP_VOLTAGE_OFFSET	0x9
271 #define AQUASTREAMXT_PUMP_CURR_OFFSET		0xb
272 static u16 aquastreamxt_sensor_fan_offsets[] = { 0x13, 0x1b };
273 
274 /* Specs of the Poweradjust 3 */
275 #define POWERADJUST3_NUM_SENSORS	1
276 #define POWERADJUST3_SENSOR_REPORT_SIZE	0x32
277 
278 /* Sensor report offsets for the Poweradjust 3 */
279 #define POWERADJUST3_SENSOR_START	0x03
280 
281 /* Labels for D5 Next */
282 static const char *const label_d5next_temp[] = {
283 	"Coolant temp"
284 };
285 
286 static const char *const label_d5next_speeds[] = {
287 	"Pump speed",
288 	"Fan speed"
289 };
290 
291 static const char *const label_d5next_power[] = {
292 	"Pump power",
293 	"Fan power"
294 };
295 
296 static const char *const label_d5next_voltages[] = {
297 	"Pump voltage",
298 	"Fan voltage",
299 	"+5V voltage",
300 	"+12V voltage"
301 };
302 
303 static const char *const label_d5next_current[] = {
304 	"Pump current",
305 	"Fan current"
306 };
307 
308 /* Labels for Aquaero, Farbwerk, Farbwerk 360 and Octo and Quadro temperature sensors */
309 static const char *const label_temp_sensors[] = {
310 	"Sensor 1",
311 	"Sensor 2",
312 	"Sensor 3",
313 	"Sensor 4",
314 	"Sensor 5",
315 	"Sensor 6",
316 	"Sensor 7",
317 	"Sensor 8"
318 };
319 
320 static const char *const label_virtual_temp_sensors[] = {
321 	"Virtual sensor 1",
322 	"Virtual sensor 2",
323 	"Virtual sensor 3",
324 	"Virtual sensor 4",
325 	"Virtual sensor 5",
326 	"Virtual sensor 6",
327 	"Virtual sensor 7",
328 	"Virtual sensor 8",
329 	"Virtual sensor 9",
330 	"Virtual sensor 10",
331 	"Virtual sensor 11",
332 	"Virtual sensor 12",
333 	"Virtual sensor 13",
334 	"Virtual sensor 14",
335 	"Virtual sensor 15",
336 	"Virtual sensor 16",
337 };
338 
339 static const char *const label_aquaero_calc_temp_sensors[] = {
340 	"Calc. virtual sensor 1",
341 	"Calc. virtual sensor 2",
342 	"Calc. virtual sensor 3",
343 	"Calc. virtual sensor 4"
344 };
345 
346 /* Labels for Octo and Quadro (except speed) */
347 static const char *const label_fan_speed[] = {
348 	"Fan 1 speed",
349 	"Fan 2 speed",
350 	"Fan 3 speed",
351 	"Fan 4 speed",
352 	"Fan 5 speed",
353 	"Fan 6 speed",
354 	"Fan 7 speed",
355 	"Fan 8 speed"
356 };
357 
358 static const char *const label_fan_power[] = {
359 	"Fan 1 power",
360 	"Fan 2 power",
361 	"Fan 3 power",
362 	"Fan 4 power",
363 	"Fan 5 power",
364 	"Fan 6 power",
365 	"Fan 7 power",
366 	"Fan 8 power"
367 };
368 
369 static const char *const label_fan_voltage[] = {
370 	"Fan 1 voltage",
371 	"Fan 2 voltage",
372 	"Fan 3 voltage",
373 	"Fan 4 voltage",
374 	"Fan 5 voltage",
375 	"Fan 6 voltage",
376 	"Fan 7 voltage",
377 	"Fan 8 voltage"
378 };
379 
380 static const char *const label_fan_current[] = {
381 	"Fan 1 current",
382 	"Fan 2 current",
383 	"Fan 3 current",
384 	"Fan 4 current",
385 	"Fan 5 current",
386 	"Fan 6 current",
387 	"Fan 7 current",
388 	"Fan 8 current"
389 };
390 
391 /* Labels for Quadro fan speeds */
392 static const char *const label_quadro_speeds[] = {
393 	"Fan 1 speed",
394 	"Fan 2 speed",
395 	"Fan 3 speed",
396 	"Fan 4 speed",
397 	"Flow speed [dL/h]"
398 };
399 
400 /* Labels for Aquaero fan speeds */
401 static const char *const label_aquaero_speeds[] = {
402 	"Fan 1 speed",
403 	"Fan 2 speed",
404 	"Fan 3 speed",
405 	"Fan 4 speed",
406 	"Flow sensor 1 [dL/h]",
407 	"Flow sensor 2 [dL/h]"
408 };
409 
410 /* Labels for High Flow Next */
411 static const char *const label_highflownext_temp_sensors[] = {
412 	"Coolant temp",
413 	"External sensor"
414 };
415 
416 static const char *const label_highflownext_fan_speed[] = {
417 	"Flow [dL/h]",
418 	"Water quality [%]",
419 	"Conductivity [nS/cm]",
420 };
421 
422 static const char *const label_highflownext_power[] = {
423 	"Dissipated power",
424 };
425 
426 static const char *const label_highflownext_voltage[] = {
427 	"+5V voltage",
428 	"+5V USB voltage"
429 };
430 
431 /* Labels for Leakshield */
432 static const char *const label_leakshield_temp_sensors[] = {
433 	"Temperature 1",
434 	"Temperature 2"
435 };
436 
437 static const char *const label_leakshield_fan_speed[] = {
438 	"Pressure [ubar]",
439 	"User-Provided Pump Speed",
440 	"User-Provided Flow [dL/h]",
441 	"Reservoir Volume [ml]",
442 	"Reservoir Filled [ml]",
443 };
444 
445 /* Labels for Aquastream XT */
446 static const char *const label_aquastreamxt_temp_sensors[] = {
447 	"Fan IC temp",
448 	"External sensor",
449 	"Coolant temp"
450 };
451 
452 /* Labels for Aquastream Ultimate */
453 static const char *const label_aquastreamult_temp[] = {
454 	"Coolant temp",
455 	"External temp"
456 };
457 
458 static const char *const label_aquastreamult_speeds[] = {
459 	"Fan speed",
460 	"Pump speed",
461 	"Pressure [mbar]",
462 	"Flow speed [dL/h]"
463 };
464 
465 static const char *const label_aquastreamult_power[] = {
466 	"Fan power",
467 	"Pump power"
468 };
469 
470 static const char *const label_aquastreamult_voltages[] = {
471 	"Fan voltage",
472 	"Pump voltage"
473 };
474 
475 static const char *const label_aquastreamult_current[] = {
476 	"Fan current",
477 	"Pump current"
478 };
479 
480 /* Labels for Poweradjust 3 */
481 static const char *const label_poweradjust3_temp_sensors[] = {
482 	"External sensor"
483 };
484 
485 struct aqc_fan_structure_offsets {
486 	u8 voltage;
487 	u8 curr;
488 	u8 power;
489 	u8 speed;
490 };
491 
492 /* Fan structure offsets for Aquaero */
493 static struct aqc_fan_structure_offsets aqc_aquaero_fan_structure = {
494 	.voltage = AQUAERO_FAN_VOLTAGE_OFFSET,
495 	.curr = AQUAERO_FAN_CURRENT_OFFSET,
496 	.power = AQUAERO_FAN_POWER_OFFSET,
497 	.speed = AQUAERO_FAN_SPEED_OFFSET
498 };
499 
500 /* Fan structure offsets for Aquastream Ultimate */
501 static struct aqc_fan_structure_offsets aqc_aquastreamult_fan_structure = {
502 	.voltage = AQUASTREAMULT_FAN_VOLTAGE_OFFSET,
503 	.curr = AQUASTREAMULT_FAN_CURRENT_OFFSET,
504 	.power = AQUASTREAMULT_FAN_POWER_OFFSET,
505 	.speed = AQUASTREAMULT_FAN_SPEED_OFFSET
506 };
507 
508 /* Fan structure offsets for all devices except those above */
509 static struct aqc_fan_structure_offsets aqc_general_fan_structure = {
510 	.voltage = AQC_FAN_VOLTAGE_OFFSET,
511 	.curr = AQC_FAN_CURRENT_OFFSET,
512 	.power = AQC_FAN_POWER_OFFSET,
513 	.speed = AQC_FAN_SPEED_OFFSET
514 };
515 
516 struct aqc_data {
517 	struct hid_device *hdev;
518 	struct device *hwmon_dev;
519 	struct dentry *debugfs;
520 	struct mutex mutex;	/* Used for locking access when reading and writing PWM values */
521 	enum kinds kind;
522 	const char *name;
523 
524 	int status_report_id;	/* Used for legacy devices, report is stored in buffer */
525 	int ctrl_report_id;
526 	int secondary_ctrl_report_id;
527 	int secondary_ctrl_report_size;
528 	u8 *secondary_ctrl_report;
529 
530 	int buffer_size;
531 	u8 *buffer;
532 	int checksum_start;
533 	int checksum_length;
534 	int checksum_offset;
535 
536 	int num_fans;
537 	u16 *fan_sensor_offsets;
538 	u16 *fan_ctrl_offsets;
539 	int num_temp_sensors;
540 	int temp_sensor_start_offset;
541 	int num_virtual_temp_sensors;
542 	int virtual_temp_sensor_start_offset;
543 	int num_calc_virt_temp_sensors;
544 	int calc_virt_temp_sensor_start_offset;
545 	u16 temp_ctrl_offset;
546 	u16 power_cycle_count_offset;
547 	int num_flow_sensors;
548 	u8 flow_sensors_start_offset;
549 	u8 flow_pulses_ctrl_offset;
550 	struct aqc_fan_structure_offsets *fan_structure;
551 
552 	/* General info, same across all devices */
553 	u8 serial_number_start_offset;
554 	u32 serial_number[2];
555 	u8 firmware_version_offset;
556 	u16 firmware_version;
557 
558 	/* How many times the device was powered on, if available */
559 	u32 power_cycles;
560 
561 	/* Sensor values */
562 	s32 temp_input[20];	/* Max 4 physical and 16 virtual or 8 physical and 12 virtual */
563 	s32 speed_input[8];
564 	u32 speed_input_min[1];
565 	u32 speed_input_target[1];
566 	u32 speed_input_max[1];
567 	u32 power_input[8];
568 	u16 voltage_input[8];
569 	u16 current_input[8];
570 
571 	/* Label values */
572 	const char *const *temp_label;
573 	const char *const *virtual_temp_label;
574 	const char *const *calc_virt_temp_label;	/* For Aquaero */
575 	const char *const *speed_label;
576 	const char *const *power_label;
577 	const char *const *voltage_label;
578 	const char *const *current_label;
579 
580 	unsigned long updated;
581 };
582 
583 /* Converts from centi-percent */
584 static int aqc_percent_to_pwm(u16 val)
585 {
586 	return DIV_ROUND_CLOSEST(val * 255, 100 * 100);
587 }
588 
589 /* Converts to centi-percent */
590 static int aqc_pwm_to_percent(long val)
591 {
592 	if (val < 0 || val > 255)
593 		return -EINVAL;
594 
595 	return DIV_ROUND_CLOSEST(val * 100 * 100, 255);
596 }
597 
598 /* Converts raw value for Aquastream XT pump speed to RPM */
599 static int aqc_aquastreamxt_convert_pump_rpm(u16 val)
600 {
601 	if (val > 0)
602 		return DIV_ROUND_CLOSEST(AQUASTREAMXT_PUMP_CONVERSION_CONST, val);
603 	return 0;
604 }
605 
606 /* Converts raw value for Aquastream XT fan speed to RPM */
607 static int aqc_aquastreamxt_convert_fan_rpm(u16 val)
608 {
609 	if (val > 0)
610 		return DIV_ROUND_CLOSEST(AQUASTREAMXT_FAN_CONVERSION_CONST, val);
611 	return 0;
612 }
613 
614 /* Expects the mutex to be locked */
615 static int aqc_get_ctrl_data(struct aqc_data *priv)
616 {
617 	int ret;
618 
619 	memset(priv->buffer, 0x00, priv->buffer_size);
620 	ret = hid_hw_raw_request(priv->hdev, priv->ctrl_report_id, priv->buffer, priv->buffer_size,
621 				 HID_FEATURE_REPORT, HID_REQ_GET_REPORT);
622 	if (ret < 0)
623 		ret = -ENODATA;
624 
625 	return ret;
626 }
627 
628 /* Expects the mutex to be locked */
629 static int aqc_send_ctrl_data(struct aqc_data *priv)
630 {
631 	int ret;
632 	u16 checksum;
633 
634 	/* Checksum is not needed for Aquaero */
635 	if (priv->kind != aquaero) {
636 		/* Init and xorout value for CRC-16/USB is 0xffff */
637 		checksum = crc16(0xffff, priv->buffer + priv->checksum_start,
638 				 priv->checksum_length);
639 		checksum ^= 0xffff;
640 
641 		/* Place the new checksum at the end of the report */
642 		put_unaligned_be16(checksum, priv->buffer + priv->checksum_offset);
643 	}
644 
645 	/* Send the patched up report back to the device */
646 	ret = hid_hw_raw_request(priv->hdev, priv->ctrl_report_id, priv->buffer, priv->buffer_size,
647 				 HID_FEATURE_REPORT, HID_REQ_SET_REPORT);
648 	if (ret < 0)
649 		return ret;
650 
651 	/* The official software sends this report after every change, so do it here as well */
652 	ret = hid_hw_raw_request(priv->hdev, priv->secondary_ctrl_report_id,
653 				 priv->secondary_ctrl_report, priv->secondary_ctrl_report_size,
654 				 HID_FEATURE_REPORT, HID_REQ_SET_REPORT);
655 	return ret;
656 }
657 
658 /* Refreshes the control buffer and stores value at offset in val */
659 static int aqc_get_ctrl_val(struct aqc_data *priv, int offset, long *val, int type)
660 {
661 	int ret;
662 
663 	mutex_lock(&priv->mutex);
664 
665 	ret = aqc_get_ctrl_data(priv);
666 	if (ret < 0)
667 		goto unlock_and_return;
668 
669 	switch (type) {
670 	case AQC_BE16:
671 		*val = (s16)get_unaligned_be16(priv->buffer + offset);
672 		break;
673 	case AQC_8:
674 		*val = priv->buffer[offset];
675 		break;
676 	default:
677 		ret = -EINVAL;
678 	}
679 
680 unlock_and_return:
681 	mutex_unlock(&priv->mutex);
682 	return ret;
683 }
684 
685 static int aqc_set_ctrl_vals(struct aqc_data *priv, int *offsets, long *vals, int *types, int len)
686 {
687 	int ret, i;
688 
689 	mutex_lock(&priv->mutex);
690 
691 	ret = aqc_get_ctrl_data(priv);
692 	if (ret < 0)
693 		goto unlock_and_return;
694 
695 	for (i = 0; i < len; i++) {
696 		switch (types[i]) {
697 		case AQC_BE16:
698 			put_unaligned_be16((s16)vals[i], priv->buffer + offsets[i]);
699 			break;
700 		case AQC_8:
701 			priv->buffer[offsets[i]] = (u8)vals[i];
702 			break;
703 		default:
704 			ret = -EINVAL;
705 		}
706 	}
707 
708 	if (ret < 0)
709 		goto unlock_and_return;
710 
711 	ret = aqc_send_ctrl_data(priv);
712 
713 unlock_and_return:
714 	mutex_unlock(&priv->mutex);
715 	return ret;
716 }
717 
718 static int aqc_set_ctrl_val(struct aqc_data *priv, int offset, long val, int type)
719 {
720 	return aqc_set_ctrl_vals(priv, &offset, &val, &type, 1);
721 }
722 
723 static umode_t aqc_is_visible(const void *data, enum hwmon_sensor_types type, u32 attr, int channel)
724 {
725 	const struct aqc_data *priv = data;
726 
727 	switch (type) {
728 	case hwmon_temp:
729 		if (channel < priv->num_temp_sensors) {
730 			switch (attr) {
731 			case hwmon_temp_label:
732 			case hwmon_temp_input:
733 				return 0444;
734 			case hwmon_temp_offset:
735 				if (priv->temp_ctrl_offset != 0)
736 					return 0644;
737 				break;
738 			default:
739 				break;
740 			}
741 		}
742 
743 		if (channel <
744 		    priv->num_temp_sensors + priv->num_virtual_temp_sensors +
745 		    priv->num_calc_virt_temp_sensors)
746 			switch (attr) {
747 			case hwmon_temp_label:
748 			case hwmon_temp_input:
749 				return 0444;
750 			default:
751 				break;
752 			}
753 		break;
754 	case hwmon_pwm:
755 		if (priv->fan_ctrl_offsets && channel < priv->num_fans) {
756 			switch (attr) {
757 			case hwmon_pwm_input:
758 				return 0644;
759 			default:
760 				break;
761 			}
762 		}
763 		break;
764 	case hwmon_fan:
765 		switch (attr) {
766 		case hwmon_fan_input:
767 		case hwmon_fan_label:
768 			switch (priv->kind) {
769 			case aquastreamult:
770 				/*
771 				 * Special case to support pump RPM, fan RPM,
772 				 * pressure and flow sensor
773 				 */
774 				if (channel < 4)
775 					return 0444;
776 				break;
777 			case highflownext:
778 				/* Special case to support flow sensor, water quality
779 				 * and conductivity
780 				 */
781 				if (channel < 3)
782 					return 0444;
783 				break;
784 			case leakshield:
785 				/* Special case for Leakshield sensors */
786 				if (channel < 5)
787 					return 0444;
788 				break;
789 			case aquaero:
790 			case quadro:
791 				/* Special case to support flow sensors */
792 				if (channel < priv->num_fans + priv->num_flow_sensors)
793 					return 0444;
794 				break;
795 			default:
796 				if (channel < priv->num_fans)
797 					return 0444;
798 				break;
799 			}
800 			break;
801 		case hwmon_fan_pulses:
802 			/* Special case for Quadro flow sensor */
803 			if (priv->kind == quadro && channel == priv->num_fans)
804 				return 0644;
805 			break;
806 		case hwmon_fan_min:
807 		case hwmon_fan_max:
808 		case hwmon_fan_target:
809 			/* Special case for Leakshield pressure sensor */
810 			if (priv->kind == leakshield && channel == 0)
811 				return 0444;
812 			break;
813 		default:
814 			break;
815 		}
816 		break;
817 	case hwmon_power:
818 		switch (priv->kind) {
819 		case aquastreamult:
820 			/* Special case to support pump and fan power */
821 			if (channel < 2)
822 				return 0444;
823 			break;
824 		case highflownext:
825 			/* Special case to support one power sensor */
826 			if (channel == 0)
827 				return 0444;
828 			break;
829 		case aquastreamxt:
830 			break;
831 		default:
832 			if (channel < priv->num_fans)
833 				return 0444;
834 			break;
835 		}
836 		break;
837 	case hwmon_curr:
838 		switch (priv->kind) {
839 		case aquastreamult:
840 			/* Special case to support pump and fan current */
841 			if (channel < 2)
842 				return 0444;
843 			break;
844 		case aquastreamxt:
845 			/* Special case to support pump current */
846 			if (channel == 0)
847 				return 0444;
848 			break;
849 		default:
850 			if (channel < priv->num_fans)
851 				return 0444;
852 			break;
853 		}
854 		break;
855 	case hwmon_in:
856 		switch (priv->kind) {
857 		case d5next:
858 			/* Special case to support +5V and +12V voltage sensors */
859 			if (channel < priv->num_fans + 2)
860 				return 0444;
861 			break;
862 		case aquastreamult:
863 		case highflownext:
864 			/* Special case to support two voltage sensors */
865 			if (channel < 2)
866 				return 0444;
867 			break;
868 		default:
869 			if (channel < priv->num_fans)
870 				return 0444;
871 			break;
872 		}
873 		break;
874 	default:
875 		break;
876 	}
877 
878 	return 0;
879 }
880 
881 /* Read device sensors by manually requesting the sensor report (legacy way) */
882 static int aqc_legacy_read(struct aqc_data *priv)
883 {
884 	int ret, i, sensor_value;
885 
886 	mutex_lock(&priv->mutex);
887 
888 	memset(priv->buffer, 0x00, priv->buffer_size);
889 	ret = hid_hw_raw_request(priv->hdev, priv->status_report_id, priv->buffer,
890 				 priv->buffer_size, HID_FEATURE_REPORT, HID_REQ_GET_REPORT);
891 	if (ret < 0)
892 		goto unlock_and_return;
893 
894 	/* Temperature sensor readings */
895 	for (i = 0; i < priv->num_temp_sensors; i++) {
896 		sensor_value = get_unaligned_le16(priv->buffer + priv->temp_sensor_start_offset +
897 						  i * AQC_SENSOR_SIZE);
898 		priv->temp_input[i] = sensor_value * 10;
899 	}
900 
901 	/* Special-case sensor readings */
902 	switch (priv->kind) {
903 	case aquastreamxt:
904 		/* Info provided with every report */
905 		priv->serial_number[0] = get_unaligned_le16(priv->buffer +
906 							    priv->serial_number_start_offset);
907 		priv->firmware_version =
908 			get_unaligned_le16(priv->buffer + priv->firmware_version_offset);
909 
910 		/* Read pump speed in RPM */
911 		sensor_value = get_unaligned_le16(priv->buffer + priv->fan_sensor_offsets[0]);
912 		priv->speed_input[0] = aqc_aquastreamxt_convert_pump_rpm(sensor_value);
913 
914 		/* Read fan speed in RPM, if available */
915 		sensor_value = get_unaligned_le16(priv->buffer + AQUASTREAMXT_FAN_STATUS_OFFSET);
916 		if (sensor_value == AQUASTREAMXT_FAN_STOPPED) {
917 			priv->speed_input[1] = 0;
918 		} else {
919 			sensor_value =
920 				get_unaligned_le16(priv->buffer + priv->fan_sensor_offsets[1]);
921 			priv->speed_input[1] = aqc_aquastreamxt_convert_fan_rpm(sensor_value);
922 		}
923 
924 		/* Calculation derived from linear regression */
925 		sensor_value = get_unaligned_le16(priv->buffer + AQUASTREAMXT_PUMP_CURR_OFFSET);
926 		priv->current_input[0] = DIV_ROUND_CLOSEST(sensor_value * 176, 100) - 52;
927 
928 		sensor_value = get_unaligned_le16(priv->buffer + AQUASTREAMXT_PUMP_VOLTAGE_OFFSET);
929 		priv->voltage_input[0] = DIV_ROUND_CLOSEST(sensor_value * 1000, 61);
930 
931 		sensor_value = get_unaligned_le16(priv->buffer + AQUASTREAMXT_FAN_VOLTAGE_OFFSET);
932 		priv->voltage_input[1] = DIV_ROUND_CLOSEST(sensor_value * 1000, 63);
933 		break;
934 	default:
935 		break;
936 	}
937 
938 	priv->updated = jiffies;
939 
940 unlock_and_return:
941 	mutex_unlock(&priv->mutex);
942 	return ret;
943 }
944 
945 static int aqc_read(struct device *dev, enum hwmon_sensor_types type, u32 attr,
946 		    int channel, long *val)
947 {
948 	int ret;
949 	struct aqc_data *priv = dev_get_drvdata(dev);
950 
951 	if (time_after(jiffies, priv->updated + STATUS_UPDATE_INTERVAL)) {
952 		if (priv->status_report_id != 0) {
953 			/* Legacy devices require manual reads */
954 			ret = aqc_legacy_read(priv);
955 			if (ret < 0)
956 				return -ENODATA;
957 		} else {
958 			return -ENODATA;
959 		}
960 	}
961 
962 	switch (type) {
963 	case hwmon_temp:
964 		switch (attr) {
965 		case hwmon_temp_input:
966 			if (priv->temp_input[channel] == -ENODATA)
967 				return -ENODATA;
968 
969 			*val = priv->temp_input[channel];
970 			break;
971 		case hwmon_temp_offset:
972 			ret =
973 			    aqc_get_ctrl_val(priv, priv->temp_ctrl_offset +
974 					     channel * AQC_SENSOR_SIZE, val, AQC_BE16);
975 			if (ret < 0)
976 				return ret;
977 
978 			*val *= 10;
979 			break;
980 		default:
981 			break;
982 		}
983 		break;
984 	case hwmon_fan:
985 		switch (attr) {
986 		case hwmon_fan_input:
987 			if (priv->speed_input[channel] == -ENODATA)
988 				return -ENODATA;
989 
990 			*val = priv->speed_input[channel];
991 			break;
992 		case hwmon_fan_min:
993 			*val = priv->speed_input_min[channel];
994 			break;
995 		case hwmon_fan_max:
996 			*val = priv->speed_input_max[channel];
997 			break;
998 		case hwmon_fan_target:
999 			*val = priv->speed_input_target[channel];
1000 			break;
1001 		case hwmon_fan_pulses:
1002 			ret = aqc_get_ctrl_val(priv, priv->flow_pulses_ctrl_offset,
1003 					       val, AQC_BE16);
1004 			if (ret < 0)
1005 				return ret;
1006 			break;
1007 		default:
1008 			break;
1009 		}
1010 		break;
1011 	case hwmon_power:
1012 		*val = priv->power_input[channel];
1013 		break;
1014 	case hwmon_pwm:
1015 		switch (priv->kind) {
1016 		case aquaero:
1017 			ret = aqc_get_ctrl_val(priv,
1018 				AQUAERO_CTRL_PRESET_START + channel * AQUAERO_CTRL_PRESET_SIZE,
1019 				val, AQC_BE16);
1020 			if (ret < 0)
1021 				return ret;
1022 			*val = aqc_percent_to_pwm(*val);
1023 			break;
1024 		default:
1025 			ret = aqc_get_ctrl_val(priv, priv->fan_ctrl_offsets[channel],
1026 					       val, AQC_BE16);
1027 			if (ret < 0)
1028 				return ret;
1029 
1030 			*val = aqc_percent_to_pwm(*val);
1031 			break;
1032 		}
1033 		break;
1034 	case hwmon_in:
1035 		*val = priv->voltage_input[channel];
1036 		break;
1037 	case hwmon_curr:
1038 		*val = priv->current_input[channel];
1039 		break;
1040 	default:
1041 		return -EOPNOTSUPP;
1042 	}
1043 
1044 	return 0;
1045 }
1046 
1047 static int aqc_read_string(struct device *dev, enum hwmon_sensor_types type, u32 attr,
1048 			   int channel, const char **str)
1049 {
1050 	struct aqc_data *priv = dev_get_drvdata(dev);
1051 
1052 	/* Number of sensors that are not calculated */
1053 	int num_non_calc_sensors = priv->num_temp_sensors + priv->num_virtual_temp_sensors;
1054 
1055 	switch (type) {
1056 	case hwmon_temp:
1057 		if (channel < priv->num_temp_sensors) {
1058 			*str = priv->temp_label[channel];
1059 		} else {
1060 			if (priv->kind == aquaero && channel >= num_non_calc_sensors)
1061 				*str =
1062 				    priv->calc_virt_temp_label[channel - num_non_calc_sensors];
1063 			else
1064 				*str = priv->virtual_temp_label[channel - priv->num_temp_sensors];
1065 		}
1066 		break;
1067 	case hwmon_fan:
1068 		*str = priv->speed_label[channel];
1069 		break;
1070 	case hwmon_power:
1071 		*str = priv->power_label[channel];
1072 		break;
1073 	case hwmon_in:
1074 		*str = priv->voltage_label[channel];
1075 		break;
1076 	case hwmon_curr:
1077 		*str = priv->current_label[channel];
1078 		break;
1079 	default:
1080 		return -EOPNOTSUPP;
1081 	}
1082 
1083 	return 0;
1084 }
1085 
1086 static int aqc_write(struct device *dev, enum hwmon_sensor_types type, u32 attr, int channel,
1087 		     long val)
1088 {
1089 	int ret, pwm_value;
1090 	/* Arrays for setting multiple values at once in the control report */
1091 	int ctrl_values_offsets[4];
1092 	long ctrl_values[4];
1093 	int ctrl_values_types[4];
1094 	struct aqc_data *priv = dev_get_drvdata(dev);
1095 
1096 	switch (type) {
1097 	case hwmon_temp:
1098 		switch (attr) {
1099 		case hwmon_temp_offset:
1100 			/* Limit temp offset to +/- 15K as in the official software */
1101 			val = clamp_val(val, -15000, 15000) / 10;
1102 			ret =
1103 			    aqc_set_ctrl_val(priv, priv->temp_ctrl_offset +
1104 					     channel * AQC_SENSOR_SIZE, val, AQC_BE16);
1105 			if (ret < 0)
1106 				return ret;
1107 			break;
1108 		default:
1109 			return -EOPNOTSUPP;
1110 		}
1111 		break;
1112 	case hwmon_fan:
1113 		switch (attr) {
1114 		case hwmon_fan_pulses:
1115 			val = clamp_val(val, 10, 1000);
1116 			ret = aqc_set_ctrl_val(priv, priv->flow_pulses_ctrl_offset,
1117 					       val, AQC_BE16);
1118 			if (ret < 0)
1119 				return ret;
1120 			break;
1121 		default:
1122 			break;
1123 		}
1124 		break;
1125 	case hwmon_pwm:
1126 		switch (attr) {
1127 		case hwmon_pwm_input:
1128 			pwm_value = aqc_pwm_to_percent(val);
1129 			if (pwm_value < 0)
1130 				return pwm_value;
1131 
1132 			switch (priv->kind) {
1133 			case aquaero:
1134 				/* Write pwm value to preset corresponding to the channel */
1135 				ctrl_values_offsets[0] = AQUAERO_CTRL_PRESET_START +
1136 				    channel * AQUAERO_CTRL_PRESET_SIZE;
1137 				ctrl_values[0] = pwm_value;
1138 				ctrl_values_types[0] = AQC_BE16;
1139 
1140 				/* Write preset number in fan control source */
1141 				ctrl_values_offsets[1] = priv->fan_ctrl_offsets[channel] +
1142 				    AQUAERO_FAN_CTRL_SRC_OFFSET;
1143 				ctrl_values[1] = AQUAERO_CTRL_PRESET_ID + channel;
1144 				ctrl_values_types[1] = AQC_BE16;
1145 
1146 				/* Set minimum power to 0 to allow the fan to turn off */
1147 				ctrl_values_offsets[2] = priv->fan_ctrl_offsets[channel] +
1148 				    AQUAERO_FAN_CTRL_MIN_PWR_OFFSET;
1149 				ctrl_values[2] = 0;
1150 				ctrl_values_types[2] = AQC_BE16;
1151 
1152 				/* Set maximum power to 255 to allow the fan to reach max speed */
1153 				ctrl_values_offsets[3] = priv->fan_ctrl_offsets[channel] +
1154 				    AQUAERO_FAN_CTRL_MAX_PWR_OFFSET;
1155 				ctrl_values[3] = aqc_pwm_to_percent(255);
1156 				ctrl_values_types[3] = AQC_BE16;
1157 
1158 				ret = aqc_set_ctrl_vals(priv, ctrl_values_offsets, ctrl_values,
1159 							ctrl_values_types, 4);
1160 				if (ret < 0)
1161 					return ret;
1162 				break;
1163 			default:
1164 				ret = aqc_set_ctrl_val(priv, priv->fan_ctrl_offsets[channel],
1165 						       pwm_value, AQC_BE16);
1166 				if (ret < 0)
1167 					return ret;
1168 				break;
1169 			}
1170 			break;
1171 		default:
1172 			break;
1173 		}
1174 		break;
1175 	default:
1176 		return -EOPNOTSUPP;
1177 	}
1178 
1179 	return 0;
1180 }
1181 
1182 static const struct hwmon_ops aqc_hwmon_ops = {
1183 	.is_visible = aqc_is_visible,
1184 	.read = aqc_read,
1185 	.read_string = aqc_read_string,
1186 	.write = aqc_write
1187 };
1188 
1189 static const struct hwmon_channel_info * const aqc_info[] = {
1190 	HWMON_CHANNEL_INFO(temp,
1191 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1192 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1193 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1194 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1195 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1196 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1197 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1198 			   HWMON_T_INPUT | HWMON_T_LABEL | HWMON_T_OFFSET,
1199 			   HWMON_T_INPUT | HWMON_T_LABEL,
1200 			   HWMON_T_INPUT | HWMON_T_LABEL,
1201 			   HWMON_T_INPUT | HWMON_T_LABEL,
1202 			   HWMON_T_INPUT | HWMON_T_LABEL,
1203 			   HWMON_T_INPUT | HWMON_T_LABEL,
1204 			   HWMON_T_INPUT | HWMON_T_LABEL,
1205 			   HWMON_T_INPUT | HWMON_T_LABEL,
1206 			   HWMON_T_INPUT | HWMON_T_LABEL,
1207 			   HWMON_T_INPUT | HWMON_T_LABEL,
1208 			   HWMON_T_INPUT | HWMON_T_LABEL,
1209 			   HWMON_T_INPUT | HWMON_T_LABEL,
1210 			   HWMON_T_INPUT | HWMON_T_LABEL),
1211 	HWMON_CHANNEL_INFO(fan,
1212 			   HWMON_F_INPUT | HWMON_F_LABEL | HWMON_F_MIN | HWMON_F_MAX |
1213 			   HWMON_F_TARGET,
1214 			   HWMON_F_INPUT | HWMON_F_LABEL,
1215 			   HWMON_F_INPUT | HWMON_F_LABEL,
1216 			   HWMON_F_INPUT | HWMON_F_LABEL,
1217 			   HWMON_F_INPUT | HWMON_F_LABEL | HWMON_F_PULSES,
1218 			   HWMON_F_INPUT | HWMON_F_LABEL,
1219 			   HWMON_F_INPUT | HWMON_F_LABEL,
1220 			   HWMON_F_INPUT | HWMON_F_LABEL),
1221 	HWMON_CHANNEL_INFO(power,
1222 			   HWMON_P_INPUT | HWMON_P_LABEL,
1223 			   HWMON_P_INPUT | HWMON_P_LABEL,
1224 			   HWMON_P_INPUT | HWMON_P_LABEL,
1225 			   HWMON_P_INPUT | HWMON_P_LABEL,
1226 			   HWMON_P_INPUT | HWMON_P_LABEL,
1227 			   HWMON_P_INPUT | HWMON_P_LABEL,
1228 			   HWMON_P_INPUT | HWMON_P_LABEL,
1229 			   HWMON_P_INPUT | HWMON_P_LABEL),
1230 	HWMON_CHANNEL_INFO(pwm,
1231 			   HWMON_PWM_INPUT,
1232 			   HWMON_PWM_INPUT,
1233 			   HWMON_PWM_INPUT,
1234 			   HWMON_PWM_INPUT,
1235 			   HWMON_PWM_INPUT,
1236 			   HWMON_PWM_INPUT,
1237 			   HWMON_PWM_INPUT,
1238 			   HWMON_PWM_INPUT),
1239 	HWMON_CHANNEL_INFO(in,
1240 			   HWMON_I_INPUT | HWMON_I_LABEL,
1241 			   HWMON_I_INPUT | HWMON_I_LABEL,
1242 			   HWMON_I_INPUT | HWMON_I_LABEL,
1243 			   HWMON_I_INPUT | HWMON_I_LABEL,
1244 			   HWMON_I_INPUT | HWMON_I_LABEL,
1245 			   HWMON_I_INPUT | HWMON_I_LABEL,
1246 			   HWMON_I_INPUT | HWMON_I_LABEL,
1247 			   HWMON_I_INPUT | HWMON_I_LABEL),
1248 	HWMON_CHANNEL_INFO(curr,
1249 			   HWMON_C_INPUT | HWMON_C_LABEL,
1250 			   HWMON_C_INPUT | HWMON_C_LABEL,
1251 			   HWMON_C_INPUT | HWMON_C_LABEL,
1252 			   HWMON_C_INPUT | HWMON_C_LABEL,
1253 			   HWMON_C_INPUT | HWMON_C_LABEL,
1254 			   HWMON_C_INPUT | HWMON_C_LABEL,
1255 			   HWMON_C_INPUT | HWMON_C_LABEL,
1256 			   HWMON_C_INPUT | HWMON_C_LABEL),
1257 	NULL
1258 };
1259 
1260 static const struct hwmon_chip_info aqc_chip_info = {
1261 	.ops = &aqc_hwmon_ops,
1262 	.info = aqc_info,
1263 };
1264 
1265 static int aqc_raw_event(struct hid_device *hdev, struct hid_report *report, u8 *data, int size)
1266 {
1267 	int i, j, sensor_value;
1268 	struct aqc_data *priv;
1269 
1270 	if (report->id != STATUS_REPORT_ID)
1271 		return 0;
1272 
1273 	priv = hid_get_drvdata(hdev);
1274 
1275 	/* Info provided with every report */
1276 	priv->serial_number[0] = get_unaligned_be16(data + priv->serial_number_start_offset);
1277 	priv->serial_number[1] = get_unaligned_be16(data + priv->serial_number_start_offset +
1278 						    SERIAL_PART_OFFSET);
1279 	priv->firmware_version = get_unaligned_be16(data + priv->firmware_version_offset);
1280 
1281 	/* Physical temperature sensor readings */
1282 	for (i = 0; i < priv->num_temp_sensors; i++) {
1283 		sensor_value = get_unaligned_be16(data +
1284 						  priv->temp_sensor_start_offset +
1285 						  i * AQC_SENSOR_SIZE);
1286 		if (sensor_value == AQC_SENSOR_NA)
1287 			priv->temp_input[i] = -ENODATA;
1288 		else
1289 			priv->temp_input[i] = sensor_value * 10;
1290 	}
1291 
1292 	/* Virtual temperature sensor readings */
1293 	for (j = 0; j < priv->num_virtual_temp_sensors; j++) {
1294 		sensor_value = get_unaligned_be16(data +
1295 						  priv->virtual_temp_sensor_start_offset +
1296 						  j * AQC_SENSOR_SIZE);
1297 		if (sensor_value == AQC_SENSOR_NA)
1298 			priv->temp_input[i] = -ENODATA;
1299 		else
1300 			priv->temp_input[i] = sensor_value * 10;
1301 		i++;
1302 	}
1303 
1304 	/* Fan speed and related readings */
1305 	for (i = 0; i < priv->num_fans; i++) {
1306 		priv->speed_input[i] =
1307 		    get_unaligned_be16(data + priv->fan_sensor_offsets[i] +
1308 				       priv->fan_structure->speed);
1309 		priv->power_input[i] =
1310 		    get_unaligned_be16(data + priv->fan_sensor_offsets[i] +
1311 				       priv->fan_structure->power) * 10000;
1312 		priv->voltage_input[i] =
1313 		    get_unaligned_be16(data + priv->fan_sensor_offsets[i] +
1314 				       priv->fan_structure->voltage) * 10;
1315 		priv->current_input[i] =
1316 		    get_unaligned_be16(data + priv->fan_sensor_offsets[i] +
1317 				       priv->fan_structure->curr);
1318 	}
1319 
1320 	/* Flow sensor readings */
1321 	for (j = 0; j < priv->num_flow_sensors; j++) {
1322 		priv->speed_input[i] = get_unaligned_be16(data + priv->flow_sensors_start_offset +
1323 							  j * AQC_SENSOR_SIZE);
1324 		i++;
1325 	}
1326 
1327 	if (priv->power_cycle_count_offset != 0)
1328 		priv->power_cycles = get_unaligned_be32(data + priv->power_cycle_count_offset);
1329 
1330 	/* Special-case sensor readings */
1331 	switch (priv->kind) {
1332 	case aquaero:
1333 		/* Read calculated virtual temp sensors */
1334 		i = priv->num_temp_sensors + priv->num_virtual_temp_sensors;
1335 		for (j = 0; j < priv->num_calc_virt_temp_sensors; j++) {
1336 			sensor_value = get_unaligned_be16(data +
1337 					priv->calc_virt_temp_sensor_start_offset +
1338 					j * AQC_SENSOR_SIZE);
1339 			if (sensor_value == AQC_SENSOR_NA)
1340 				priv->temp_input[i] = -ENODATA;
1341 			else
1342 				priv->temp_input[i] = sensor_value * 10;
1343 			i++;
1344 		}
1345 		break;
1346 	case aquastreamult:
1347 		priv->speed_input[1] = get_unaligned_be16(data + AQUASTREAMULT_PUMP_OFFSET);
1348 		priv->speed_input[2] = get_unaligned_be16(data + AQUASTREAMULT_PRESSURE_OFFSET);
1349 		priv->speed_input[3] = get_unaligned_be16(data + AQUASTREAMULT_FLOW_SENSOR_OFFSET);
1350 
1351 		priv->power_input[1] = get_unaligned_be16(data + AQUASTREAMULT_PUMP_POWER) * 10000;
1352 
1353 		priv->voltage_input[1] = get_unaligned_be16(data + AQUASTREAMULT_PUMP_VOLTAGE) * 10;
1354 
1355 		priv->current_input[1] = get_unaligned_be16(data + AQUASTREAMULT_PUMP_CURRENT);
1356 		break;
1357 	case d5next:
1358 		priv->voltage_input[2] = get_unaligned_be16(data + D5NEXT_5V_VOLTAGE) * 10;
1359 		priv->voltage_input[3] = get_unaligned_be16(data + D5NEXT_12V_VOLTAGE) * 10;
1360 		break;
1361 	case highflownext:
1362 		/* If external temp sensor is not connected, its power reading is also N/A */
1363 		if (priv->temp_input[1] == -ENODATA)
1364 			priv->power_input[0] = -ENODATA;
1365 		else
1366 			priv->power_input[0] =
1367 			    get_unaligned_be16(data + HIGHFLOWNEXT_POWER) * 1000000;
1368 
1369 		priv->voltage_input[0] = get_unaligned_be16(data + HIGHFLOWNEXT_5V_VOLTAGE) * 10;
1370 		priv->voltage_input[1] =
1371 		    get_unaligned_be16(data + HIGHFLOWNEXT_5V_VOLTAGE_USB) * 10;
1372 
1373 		priv->speed_input[1] = get_unaligned_be16(data + HIGHFLOWNEXT_WATER_QUALITY);
1374 		priv->speed_input[2] = get_unaligned_be16(data + HIGHFLOWNEXT_CONDUCTIVITY);
1375 		break;
1376 	case leakshield:
1377 		priv->speed_input[0] =
1378 		    ((s16)get_unaligned_be16(data + LEAKSHIELD_PRESSURE_ADJUSTED)) * 100;
1379 		priv->speed_input_min[0] = get_unaligned_be16(data + LEAKSHIELD_PRESSURE_MIN) * 100;
1380 		priv->speed_input_target[0] =
1381 		    get_unaligned_be16(data + LEAKSHIELD_PRESSURE_TARGET) * 100;
1382 		priv->speed_input_max[0] = get_unaligned_be16(data + LEAKSHIELD_PRESSURE_MAX) * 100;
1383 
1384 		priv->speed_input[1] = get_unaligned_be16(data + LEAKSHIELD_PUMP_RPM_IN);
1385 		if (priv->speed_input[1] == AQC_SENSOR_NA)
1386 			priv->speed_input[1] = -ENODATA;
1387 
1388 		priv->speed_input[2] = get_unaligned_be16(data + LEAKSHIELD_FLOW_IN);
1389 		if (priv->speed_input[2] == AQC_SENSOR_NA)
1390 			priv->speed_input[2] = -ENODATA;
1391 
1392 		priv->speed_input[3] = get_unaligned_be16(data + LEAKSHIELD_RESERVOIR_VOLUME);
1393 		priv->speed_input[4] = get_unaligned_be16(data + LEAKSHIELD_RESERVOIR_FILLED);
1394 
1395 		/* Second temp sensor is not positioned after the first one, read it here */
1396 		priv->temp_input[1] = get_unaligned_be16(data + LEAKSHIELD_TEMPERATURE_2) * 10;
1397 		break;
1398 	default:
1399 		break;
1400 	}
1401 
1402 	priv->updated = jiffies;
1403 
1404 	return 0;
1405 }
1406 
1407 #ifdef CONFIG_DEBUG_FS
1408 
1409 static int serial_number_show(struct seq_file *seqf, void *unused)
1410 {
1411 	struct aqc_data *priv = seqf->private;
1412 
1413 	seq_printf(seqf, "%05u-%05u\n", priv->serial_number[0], priv->serial_number[1]);
1414 
1415 	return 0;
1416 }
1417 DEFINE_SHOW_ATTRIBUTE(serial_number);
1418 
1419 static int firmware_version_show(struct seq_file *seqf, void *unused)
1420 {
1421 	struct aqc_data *priv = seqf->private;
1422 
1423 	seq_printf(seqf, "%u\n", priv->firmware_version);
1424 
1425 	return 0;
1426 }
1427 DEFINE_SHOW_ATTRIBUTE(firmware_version);
1428 
1429 static int power_cycles_show(struct seq_file *seqf, void *unused)
1430 {
1431 	struct aqc_data *priv = seqf->private;
1432 
1433 	seq_printf(seqf, "%u\n", priv->power_cycles);
1434 
1435 	return 0;
1436 }
1437 DEFINE_SHOW_ATTRIBUTE(power_cycles);
1438 
1439 static void aqc_debugfs_init(struct aqc_data *priv)
1440 {
1441 	char name[64];
1442 
1443 	scnprintf(name, sizeof(name), "%s_%s-%s", "aquacomputer", priv->name,
1444 		  dev_name(&priv->hdev->dev));
1445 
1446 	priv->debugfs = debugfs_create_dir(name, NULL);
1447 
1448 	if (priv->serial_number_start_offset != 0)
1449 		debugfs_create_file("serial_number", 0444, priv->debugfs, priv,
1450 				    &serial_number_fops);
1451 	if (priv->firmware_version_offset != 0)
1452 		debugfs_create_file("firmware_version", 0444, priv->debugfs, priv,
1453 				    &firmware_version_fops);
1454 	if (priv->power_cycle_count_offset != 0)
1455 		debugfs_create_file("power_cycles", 0444, priv->debugfs, priv, &power_cycles_fops);
1456 }
1457 
1458 #else
1459 
1460 static void aqc_debugfs_init(struct aqc_data *priv)
1461 {
1462 }
1463 
1464 #endif
1465 
1466 static int aqc_probe(struct hid_device *hdev, const struct hid_device_id *id)
1467 {
1468 	struct aqc_data *priv;
1469 	int ret;
1470 
1471 	priv = devm_kzalloc(&hdev->dev, sizeof(*priv), GFP_KERNEL);
1472 	if (!priv)
1473 		return -ENOMEM;
1474 
1475 	priv->hdev = hdev;
1476 	hid_set_drvdata(hdev, priv);
1477 
1478 	priv->updated = jiffies - STATUS_UPDATE_INTERVAL;
1479 
1480 	ret = hid_parse(hdev);
1481 	if (ret)
1482 		return ret;
1483 
1484 	ret = hid_hw_start(hdev, HID_CONNECT_HIDRAW);
1485 	if (ret)
1486 		return ret;
1487 
1488 	ret = hid_hw_open(hdev);
1489 	if (ret)
1490 		goto fail_and_stop;
1491 
1492 	switch (hdev->product) {
1493 	case USB_PRODUCT_ID_AQUAERO:
1494 		/*
1495 		 * Aquaero presents itself as three HID devices under the same product ID:
1496 		 * "aquaero keyboard/mouse", "aquaero System Control" and "aquaero Device",
1497 		 * which is the one we want to communicate with. Unlike most other Aquacomputer
1498 		 * devices, Aquaero does not return meaningful data when explicitly requested
1499 		 * using GET_FEATURE_REPORT.
1500 		 *
1501 		 * The difference between "aquaero Device" and the other two is in the collections
1502 		 * they present. The two other devices have the type of the second element in
1503 		 * their respective collections set to 1, while the real device has it set to 0.
1504 		 */
1505 		if (hdev->collection[1].type != 0) {
1506 			ret = -ENODEV;
1507 			goto fail_and_close;
1508 		}
1509 
1510 		priv->kind = aquaero;
1511 
1512 		priv->num_fans = AQUAERO_NUM_FANS;
1513 		priv->fan_sensor_offsets = aquaero_sensor_fan_offsets;
1514 		priv->fan_ctrl_offsets = aquaero_ctrl_fan_offsets;
1515 
1516 		priv->num_temp_sensors = AQUAERO_NUM_SENSORS;
1517 		priv->temp_sensor_start_offset = AQUAERO_SENSOR_START;
1518 		priv->num_virtual_temp_sensors = AQUAERO_NUM_VIRTUAL_SENSORS;
1519 		priv->virtual_temp_sensor_start_offset = AQUAERO_VIRTUAL_SENSOR_START;
1520 		priv->num_calc_virt_temp_sensors = AQUAERO_NUM_CALC_VIRTUAL_SENSORS;
1521 		priv->calc_virt_temp_sensor_start_offset = AQUAERO_CALC_VIRTUAL_SENSOR_START;
1522 		priv->num_flow_sensors = AQUAERO_NUM_FLOW_SENSORS;
1523 		priv->flow_sensors_start_offset = AQUAERO_FLOW_SENSORS_START;
1524 
1525 		priv->buffer_size = AQUAERO_CTRL_REPORT_SIZE;
1526 		priv->temp_ctrl_offset = AQUAERO_TEMP_CTRL_OFFSET;
1527 
1528 		priv->temp_label = label_temp_sensors;
1529 		priv->virtual_temp_label = label_virtual_temp_sensors;
1530 		priv->calc_virt_temp_label = label_aquaero_calc_temp_sensors;
1531 		priv->speed_label = label_aquaero_speeds;
1532 		priv->power_label = label_fan_power;
1533 		priv->voltage_label = label_fan_voltage;
1534 		priv->current_label = label_fan_current;
1535 		break;
1536 	case USB_PRODUCT_ID_D5NEXT:
1537 		priv->kind = d5next;
1538 
1539 		priv->num_fans = D5NEXT_NUM_FANS;
1540 		priv->fan_sensor_offsets = d5next_sensor_fan_offsets;
1541 		priv->fan_ctrl_offsets = d5next_ctrl_fan_offsets;
1542 
1543 		priv->num_temp_sensors = D5NEXT_NUM_SENSORS;
1544 		priv->temp_sensor_start_offset = D5NEXT_COOLANT_TEMP;
1545 		priv->num_virtual_temp_sensors = D5NEXT_NUM_VIRTUAL_SENSORS;
1546 		priv->virtual_temp_sensor_start_offset = D5NEXT_VIRTUAL_SENSORS_START;
1547 		priv->temp_ctrl_offset = D5NEXT_TEMP_CTRL_OFFSET;
1548 
1549 		priv->buffer_size = D5NEXT_CTRL_REPORT_SIZE;
1550 
1551 		priv->power_cycle_count_offset = D5NEXT_POWER_CYCLES;
1552 
1553 		priv->temp_label = label_d5next_temp;
1554 		priv->virtual_temp_label = label_virtual_temp_sensors;
1555 		priv->speed_label = label_d5next_speeds;
1556 		priv->power_label = label_d5next_power;
1557 		priv->voltage_label = label_d5next_voltages;
1558 		priv->current_label = label_d5next_current;
1559 		break;
1560 	case USB_PRODUCT_ID_FARBWERK:
1561 		priv->kind = farbwerk;
1562 
1563 		priv->num_fans = 0;
1564 
1565 		priv->num_temp_sensors = FARBWERK_NUM_SENSORS;
1566 		priv->temp_sensor_start_offset = FARBWERK_SENSOR_START;
1567 
1568 		priv->temp_label = label_temp_sensors;
1569 		break;
1570 	case USB_PRODUCT_ID_FARBWERK360:
1571 		priv->kind = farbwerk360;
1572 
1573 		priv->num_fans = 0;
1574 
1575 		priv->num_temp_sensors = FARBWERK360_NUM_SENSORS;
1576 		priv->temp_sensor_start_offset = FARBWERK360_SENSOR_START;
1577 		priv->num_virtual_temp_sensors = FARBWERK360_NUM_VIRTUAL_SENSORS;
1578 		priv->virtual_temp_sensor_start_offset = FARBWERK360_VIRTUAL_SENSORS_START;
1579 		priv->temp_ctrl_offset = FARBWERK360_TEMP_CTRL_OFFSET;
1580 
1581 		priv->buffer_size = FARBWERK360_CTRL_REPORT_SIZE;
1582 
1583 		priv->temp_label = label_temp_sensors;
1584 		priv->virtual_temp_label = label_virtual_temp_sensors;
1585 		break;
1586 	case USB_PRODUCT_ID_OCTO:
1587 		priv->kind = octo;
1588 
1589 		priv->num_fans = OCTO_NUM_FANS;
1590 		priv->fan_sensor_offsets = octo_sensor_fan_offsets;
1591 		priv->fan_ctrl_offsets = octo_ctrl_fan_offsets;
1592 
1593 		priv->num_temp_sensors = OCTO_NUM_SENSORS;
1594 		priv->temp_sensor_start_offset = OCTO_SENSOR_START;
1595 		priv->num_virtual_temp_sensors = OCTO_NUM_VIRTUAL_SENSORS;
1596 		priv->virtual_temp_sensor_start_offset = OCTO_VIRTUAL_SENSORS_START;
1597 		priv->temp_ctrl_offset = OCTO_TEMP_CTRL_OFFSET;
1598 
1599 		priv->buffer_size = OCTO_CTRL_REPORT_SIZE;
1600 
1601 		priv->power_cycle_count_offset = OCTO_POWER_CYCLES;
1602 
1603 		priv->temp_label = label_temp_sensors;
1604 		priv->virtual_temp_label = label_virtual_temp_sensors;
1605 		priv->speed_label = label_fan_speed;
1606 		priv->power_label = label_fan_power;
1607 		priv->voltage_label = label_fan_voltage;
1608 		priv->current_label = label_fan_current;
1609 		break;
1610 	case USB_PRODUCT_ID_QUADRO:
1611 		priv->kind = quadro;
1612 
1613 		priv->num_fans = QUADRO_NUM_FANS;
1614 		priv->fan_sensor_offsets = quadro_sensor_fan_offsets;
1615 		priv->fan_ctrl_offsets = quadro_ctrl_fan_offsets;
1616 
1617 		priv->num_temp_sensors = QUADRO_NUM_SENSORS;
1618 		priv->temp_sensor_start_offset = QUADRO_SENSOR_START;
1619 		priv->num_virtual_temp_sensors = QUADRO_NUM_VIRTUAL_SENSORS;
1620 		priv->virtual_temp_sensor_start_offset = QUADRO_VIRTUAL_SENSORS_START;
1621 		priv->num_flow_sensors = QUADRO_NUM_FLOW_SENSORS;
1622 		priv->flow_sensors_start_offset = QUADRO_FLOW_SENSOR_OFFSET;
1623 
1624 		priv->temp_ctrl_offset = QUADRO_TEMP_CTRL_OFFSET;
1625 
1626 		priv->buffer_size = QUADRO_CTRL_REPORT_SIZE;
1627 
1628 		priv->flow_pulses_ctrl_offset = QUADRO_FLOW_PULSES_CTRL_OFFSET;
1629 		priv->power_cycle_count_offset = QUADRO_POWER_CYCLES;
1630 
1631 		priv->temp_label = label_temp_sensors;
1632 		priv->virtual_temp_label = label_virtual_temp_sensors;
1633 		priv->speed_label = label_quadro_speeds;
1634 		priv->power_label = label_fan_power;
1635 		priv->voltage_label = label_fan_voltage;
1636 		priv->current_label = label_fan_current;
1637 		break;
1638 	case USB_PRODUCT_ID_HIGHFLOWNEXT:
1639 		priv->kind = highflownext;
1640 
1641 		priv->num_fans = 0;
1642 
1643 		priv->num_temp_sensors = HIGHFLOWNEXT_NUM_SENSORS;
1644 		priv->temp_sensor_start_offset = HIGHFLOWNEXT_SENSOR_START;
1645 		priv->num_flow_sensors = HIGHFLOWNEXT_NUM_FLOW_SENSORS;
1646 		priv->flow_sensors_start_offset = HIGHFLOWNEXT_FLOW;
1647 
1648 		priv->power_cycle_count_offset = QUADRO_POWER_CYCLES;
1649 
1650 		priv->temp_label = label_highflownext_temp_sensors;
1651 		priv->speed_label = label_highflownext_fan_speed;
1652 		priv->power_label = label_highflownext_power;
1653 		priv->voltage_label = label_highflownext_voltage;
1654 		break;
1655 	case USB_PRODUCT_ID_LEAKSHIELD:
1656 		/*
1657 		 * Choose the right Leakshield device, because
1658 		 * the other one acts as a keyboard
1659 		 */
1660 		if (hdev->type != 2) {
1661 			ret = -ENODEV;
1662 			goto fail_and_close;
1663 		}
1664 
1665 		priv->kind = leakshield;
1666 
1667 		priv->num_fans = 0;
1668 		priv->num_temp_sensors = LEAKSHIELD_NUM_SENSORS;
1669 		priv->temp_sensor_start_offset = LEAKSHIELD_TEMPERATURE_1;
1670 
1671 		priv->temp_label = label_leakshield_temp_sensors;
1672 		priv->speed_label = label_leakshield_fan_speed;
1673 		break;
1674 	case USB_PRODUCT_ID_AQUASTREAMXT:
1675 		priv->kind = aquastreamxt;
1676 
1677 		priv->num_fans = AQUASTREAMXT_NUM_FANS;
1678 		priv->fan_sensor_offsets = aquastreamxt_sensor_fan_offsets;
1679 
1680 		priv->num_temp_sensors = AQUASTREAMXT_NUM_SENSORS;
1681 		priv->temp_sensor_start_offset = AQUASTREAMXT_SENSOR_START;
1682 		priv->buffer_size = AQUASTREAMXT_SENSOR_REPORT_SIZE;
1683 
1684 		priv->temp_label = label_aquastreamxt_temp_sensors;
1685 		priv->speed_label = label_d5next_speeds;
1686 		priv->voltage_label = label_d5next_voltages;
1687 		priv->current_label = label_d5next_current;
1688 		break;
1689 	case USB_PRODUCT_ID_AQUASTREAMULT:
1690 		priv->kind = aquastreamult;
1691 
1692 		priv->num_fans = AQUASTREAMULT_NUM_FANS;
1693 		priv->fan_sensor_offsets = aquastreamult_sensor_fan_offsets;
1694 
1695 		priv->num_temp_sensors = AQUASTREAMULT_NUM_SENSORS;
1696 		priv->temp_sensor_start_offset = AQUASTREAMULT_SENSOR_START;
1697 
1698 		priv->temp_label = label_aquastreamult_temp;
1699 		priv->speed_label = label_aquastreamult_speeds;
1700 		priv->power_label = label_aquastreamult_power;
1701 		priv->voltage_label = label_aquastreamult_voltages;
1702 		priv->current_label = label_aquastreamult_current;
1703 		break;
1704 	case USB_PRODUCT_ID_POWERADJUST3:
1705 		priv->kind = poweradjust3;
1706 
1707 		priv->num_fans = 0;
1708 
1709 		priv->num_temp_sensors = POWERADJUST3_NUM_SENSORS;
1710 		priv->temp_sensor_start_offset = POWERADJUST3_SENSOR_START;
1711 		priv->buffer_size = POWERADJUST3_SENSOR_REPORT_SIZE;
1712 
1713 		priv->temp_label = label_poweradjust3_temp_sensors;
1714 		break;
1715 	default:
1716 		break;
1717 	}
1718 
1719 	switch (priv->kind) {
1720 	case aquaero:
1721 		priv->serial_number_start_offset = AQUAERO_SERIAL_START;
1722 		priv->firmware_version_offset = AQUAERO_FIRMWARE_VERSION;
1723 
1724 		priv->fan_structure = &aqc_aquaero_fan_structure;
1725 
1726 		priv->ctrl_report_id = AQUAERO_CTRL_REPORT_ID;
1727 		priv->secondary_ctrl_report_id = AQUAERO_SECONDARY_CTRL_REPORT_ID;
1728 		priv->secondary_ctrl_report_size = AQUAERO_SECONDARY_CTRL_REPORT_SIZE;
1729 		priv->secondary_ctrl_report = aquaero_secondary_ctrl_report;
1730 		break;
1731 	case poweradjust3:
1732 		priv->status_report_id = POWERADJUST3_STATUS_REPORT_ID;
1733 		break;
1734 	case aquastreamxt:
1735 		priv->serial_number_start_offset = AQUASTREAMXT_SERIAL_START;
1736 		priv->firmware_version_offset = AQUASTREAMXT_FIRMWARE_VERSION;
1737 
1738 		priv->status_report_id = AQUASTREAMXT_STATUS_REPORT_ID;
1739 		break;
1740 	default:
1741 		priv->serial_number_start_offset = AQC_SERIAL_START;
1742 		priv->firmware_version_offset = AQC_FIRMWARE_VERSION;
1743 
1744 		priv->ctrl_report_id = CTRL_REPORT_ID;
1745 		priv->secondary_ctrl_report_id = SECONDARY_CTRL_REPORT_ID;
1746 		priv->secondary_ctrl_report_size = SECONDARY_CTRL_REPORT_SIZE;
1747 		priv->secondary_ctrl_report = secondary_ctrl_report;
1748 
1749 		if (priv->kind == aquastreamult)
1750 			priv->fan_structure = &aqc_aquastreamult_fan_structure;
1751 		else
1752 			priv->fan_structure = &aqc_general_fan_structure;
1753 		break;
1754 	}
1755 
1756 	if (priv->buffer_size != 0) {
1757 		priv->checksum_start = 0x01;
1758 		priv->checksum_length = priv->buffer_size - 3;
1759 		priv->checksum_offset = priv->buffer_size - 2;
1760 	}
1761 
1762 	priv->name = aqc_device_names[priv->kind];
1763 
1764 	priv->buffer = devm_kzalloc(&hdev->dev, priv->buffer_size, GFP_KERNEL);
1765 	if (!priv->buffer) {
1766 		ret = -ENOMEM;
1767 		goto fail_and_close;
1768 	}
1769 
1770 	mutex_init(&priv->mutex);
1771 
1772 	priv->hwmon_dev = hwmon_device_register_with_info(&hdev->dev, priv->name, priv,
1773 							  &aqc_chip_info, NULL);
1774 
1775 	if (IS_ERR(priv->hwmon_dev)) {
1776 		ret = PTR_ERR(priv->hwmon_dev);
1777 		goto fail_and_close;
1778 	}
1779 
1780 	aqc_debugfs_init(priv);
1781 
1782 	return 0;
1783 
1784 fail_and_close:
1785 	hid_hw_close(hdev);
1786 fail_and_stop:
1787 	hid_hw_stop(hdev);
1788 	return ret;
1789 }
1790 
1791 static void aqc_remove(struct hid_device *hdev)
1792 {
1793 	struct aqc_data *priv = hid_get_drvdata(hdev);
1794 
1795 	debugfs_remove_recursive(priv->debugfs);
1796 	hwmon_device_unregister(priv->hwmon_dev);
1797 
1798 	hid_hw_close(hdev);
1799 	hid_hw_stop(hdev);
1800 }
1801 
1802 static const struct hid_device_id aqc_table[] = {
1803 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_AQUAERO) },
1804 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_D5NEXT) },
1805 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_FARBWERK) },
1806 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_FARBWERK360) },
1807 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_OCTO) },
1808 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_QUADRO) },
1809 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_HIGHFLOWNEXT) },
1810 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_LEAKSHIELD) },
1811 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_AQUASTREAMXT) },
1812 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_AQUASTREAMULT) },
1813 	{ HID_USB_DEVICE(USB_VENDOR_ID_AQUACOMPUTER, USB_PRODUCT_ID_POWERADJUST3) },
1814 	{ }
1815 };
1816 
1817 MODULE_DEVICE_TABLE(hid, aqc_table);
1818 
1819 static struct hid_driver aqc_driver = {
1820 	.name = DRIVER_NAME,
1821 	.id_table = aqc_table,
1822 	.probe = aqc_probe,
1823 	.remove = aqc_remove,
1824 	.raw_event = aqc_raw_event,
1825 };
1826 
1827 static int __init aqc_init(void)
1828 {
1829 	return hid_register_driver(&aqc_driver);
1830 }
1831 
1832 static void __exit aqc_exit(void)
1833 {
1834 	hid_unregister_driver(&aqc_driver);
1835 }
1836 
1837 /* Request to initialize after the HID bus to ensure it's not being loaded before */
1838 late_initcall(aqc_init);
1839 module_exit(aqc_exit);
1840 
1841 MODULE_LICENSE("GPL");
1842 MODULE_AUTHOR("Aleksa Savic <savicaleksa83@gmail.com>");
1843 MODULE_AUTHOR("Jack Doan <me@jackdoan.com>");
1844 MODULE_DESCRIPTION("Hwmon driver for Aquacomputer devices");
1845