amc6821.c 27 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * amc6821.c - Part of lm_sensors, Linux kernel modules for hardware
  4. * monitoring
  5. * Copyright (C) 2009 T. Mertelj <tomaz.mertelj@guest.arnes.si>
  6. *
  7. * Based on max6650.c:
  8. * Copyright (C) 2007 Hans J. Koch <hjk@hansjkoch.de>
  9. *
  10. * Conversion to regmap and with_info API:
  11. * Copyright (C) 2024 Guenter Roeck <linux@roeck-us.net>
  12. */
  13. #include <linux/bitfield.h>
  14. #include <linux/bitops.h>
  15. #include <linux/bits.h>
  16. #include <linux/err.h>
  17. #include <linux/hwmon.h>
  18. #include <linux/hwmon-sysfs.h>
  19. #include <linux/i2c.h>
  20. #include <linux/init.h>
  21. #include <linux/minmax.h>
  22. #include <linux/module.h>
  23. #include <linux/mutex.h>
  24. #include <linux/of_platform.h>
  25. #include <linux/pwm.h>
  26. #include <linux/regmap.h>
  27. #include <linux/slab.h>
  28. #include <linux/thermal.h>
  29. #include <dt-bindings/pwm/pwm.h>
  30. /*
  31. * Addresses to scan.
  32. */
  33. static const unsigned short normal_i2c[] = {0x18, 0x19, 0x1a, 0x2c, 0x2d, 0x2e,
  34. 0x4c, 0x4d, 0x4e, I2C_CLIENT_END};
  35. /*
  36. * Insmod parameters
  37. */
  38. static int pwminv = -1; /*Inverted PWM output. */
  39. module_param(pwminv, int, 0444);
  40. static int init = 1; /*Power-on initialization.*/
  41. module_param(init, int, 0444);
  42. #define AMC6821_REG_DEV_ID 0x3D
  43. #define AMC6821_REG_COMP_ID 0x3E
  44. #define AMC6821_REG_CONF1 0x00
  45. #define AMC6821_REG_CONF2 0x01
  46. #define AMC6821_REG_CONF3 0x3F
  47. #define AMC6821_REG_CONF4 0x04
  48. #define AMC6821_REG_STAT1 0x02
  49. #define AMC6821_REG_STAT2 0x03
  50. #define AMC6821_REG_TEMP_LO 0x06
  51. #define AMC6821_REG_TDATA_LOW 0x08
  52. #define AMC6821_REG_TDATA_HI 0x09
  53. #define AMC6821_REG_LTEMP_HI 0x0A
  54. #define AMC6821_REG_RTEMP_HI 0x0B
  55. #define AMC6821_REG_LTEMP_LIMIT_MIN 0x15
  56. #define AMC6821_REG_LTEMP_LIMIT_MAX 0x14
  57. #define AMC6821_REG_RTEMP_LIMIT_MIN 0x19
  58. #define AMC6821_REG_RTEMP_LIMIT_MAX 0x18
  59. #define AMC6821_REG_LTEMP_CRIT 0x1B
  60. #define AMC6821_REG_RTEMP_CRIT 0x1D
  61. #define AMC6821_REG_PSV_TEMP 0x1C
  62. #define AMC6821_REG_DCY 0x22
  63. #define AMC6821_REG_LTEMP_FAN_CTRL 0x24
  64. #define AMC6821_REG_RTEMP_FAN_CTRL 0x25
  65. #define AMC6821_REG_DCY_LOW_TEMP 0x21
  66. #define AMC6821_REG_TACH_LLIMITL 0x10
  67. #define AMC6821_REG_TACH_HLIMITL 0x12
  68. #define AMC6821_REG_TACH_SETTINGL 0x1e
  69. #define AMC6821_CONF1_START BIT(0)
  70. #define AMC6821_CONF1_FAN_INT_EN BIT(1)
  71. #define AMC6821_CONF1_FANIE BIT(2)
  72. #define AMC6821_CONF1_PWMINV BIT(3)
  73. #define AMC6821_CONF1_FAN_FAULT_EN BIT(4)
  74. #define AMC6821_CONF1_FDRC0 BIT(5)
  75. #define AMC6821_CONF1_FDRC1 BIT(6)
  76. #define AMC6821_CONF1_THERMOVIE BIT(7)
  77. #define AMC6821_CONF2_PWM_EN BIT(0)
  78. #define AMC6821_CONF2_TACH_MODE BIT(1)
  79. #define AMC6821_CONF2_TACH_EN BIT(2)
  80. #define AMC6821_CONF2_RTFIE BIT(3)
  81. #define AMC6821_CONF2_LTOIE BIT(4)
  82. #define AMC6821_CONF2_RTOIE BIT(5)
  83. #define AMC6821_CONF2_PSVIE BIT(6)
  84. #define AMC6821_CONF2_RST BIT(7)
  85. #define AMC6821_CONF3_THERM_FAN_EN BIT(7)
  86. #define AMC6821_CONF3_REV_MASK GENMASK(3, 0)
  87. #define AMC6821_CONF4_OVREN BIT(4)
  88. #define AMC6821_CONF4_TACH_FAST BIT(5)
  89. #define AMC6821_CONF4_PSPR BIT(6)
  90. #define AMC6821_CONF4_MODE BIT(7)
  91. #define AMC6821_STAT1_RPM_ALARM BIT(0)
  92. #define AMC6821_STAT1_FANS BIT(1)
  93. #define AMC6821_STAT1_RTH BIT(2)
  94. #define AMC6821_STAT1_RTL BIT(3)
  95. #define AMC6821_STAT1_R_THERM BIT(4)
  96. #define AMC6821_STAT1_RTF BIT(5)
  97. #define AMC6821_STAT1_LTH BIT(6)
  98. #define AMC6821_STAT1_LTL BIT(7)
  99. #define AMC6821_STAT2_RTC BIT(3)
  100. #define AMC6821_STAT2_LTC BIT(4)
  101. #define AMC6821_STAT2_LPSV BIT(5)
  102. #define AMC6821_STAT2_L_THERM BIT(6)
  103. #define AMC6821_STAT2_THERM_IN BIT(7)
  104. #define AMC6821_TEMP_SLOPE_MASK GENMASK(2, 0)
  105. #define AMC6821_TEMP_LIMIT_MASK GENMASK(7, 3)
  106. /*
  107. * Client data (each client gets its own)
  108. */
  109. struct amc6821_data {
  110. struct regmap *regmap;
  111. struct mutex update_lock;
  112. unsigned long fan_state;
  113. unsigned long fan_max_state;
  114. unsigned int *fan_cooling_levels;
  115. enum pwm_polarity pwm_polarity;
  116. };
  117. /*
  118. * Return 0 on success or negative error code.
  119. *
  120. * temps returns set of three temperatures, in °C:
  121. * temps[0]: Passive cooling temperature, applies to both channels
  122. * temps[1]: Low temperature, start slope calculations
  123. * temps[2]: High temperature
  124. *
  125. * Channel 0: local, channel 1: remote.
  126. */
  127. static int amc6821_get_auto_point_temps(struct regmap *regmap, int channel, u8 *temps)
  128. {
  129. u32 regs[] = {
  130. AMC6821_REG_DCY_LOW_TEMP,
  131. AMC6821_REG_PSV_TEMP,
  132. channel ? AMC6821_REG_RTEMP_FAN_CTRL : AMC6821_REG_LTEMP_FAN_CTRL
  133. };
  134. u8 regvals[3];
  135. int slope;
  136. int err;
  137. err = regmap_multi_reg_read(regmap, regs, regvals, 3);
  138. if (err)
  139. return err;
  140. temps[0] = regvals[1];
  141. temps[1] = FIELD_GET(AMC6821_TEMP_LIMIT_MASK, regvals[2]) * 4;
  142. /* slope is 32 >> <slope bits> in °C */
  143. slope = 32 >> FIELD_GET(AMC6821_TEMP_SLOPE_MASK, regvals[2]);
  144. if (slope)
  145. temps[2] = temps[1] + DIV_ROUND_CLOSEST(255 - regvals[0], slope);
  146. else
  147. temps[2] = 255;
  148. return 0;
  149. }
  150. static int amc6821_temp_read_values(struct regmap *regmap, u32 attr, int channel, long *val)
  151. {
  152. int reg, err;
  153. u32 regval;
  154. switch (attr) {
  155. case hwmon_temp_input:
  156. reg = channel ? AMC6821_REG_RTEMP_HI : AMC6821_REG_LTEMP_HI;
  157. break;
  158. case hwmon_temp_min:
  159. reg = channel ? AMC6821_REG_RTEMP_LIMIT_MIN : AMC6821_REG_LTEMP_LIMIT_MIN;
  160. break;
  161. case hwmon_temp_max:
  162. reg = channel ? AMC6821_REG_RTEMP_LIMIT_MAX : AMC6821_REG_LTEMP_LIMIT_MAX;
  163. break;
  164. case hwmon_temp_crit:
  165. reg = channel ? AMC6821_REG_RTEMP_CRIT : AMC6821_REG_LTEMP_CRIT;
  166. break;
  167. default:
  168. return -EOPNOTSUPP;
  169. }
  170. err = regmap_read(regmap, reg, &regval);
  171. if (err)
  172. return err;
  173. *val = sign_extend32(regval, 7) * 1000;
  174. return 0;
  175. }
  176. static int amc6821_read_alarms(struct regmap *regmap, enum hwmon_sensor_types type,
  177. u32 attr, int channel, long *val)
  178. {
  179. int reg, mask, err;
  180. u32 regval;
  181. switch (type) {
  182. case hwmon_temp:
  183. switch (attr) {
  184. case hwmon_temp_min_alarm:
  185. reg = AMC6821_REG_STAT1;
  186. mask = channel ? AMC6821_STAT1_RTL : AMC6821_STAT1_LTL;
  187. break;
  188. case hwmon_temp_max_alarm:
  189. reg = AMC6821_REG_STAT1;
  190. mask = channel ? AMC6821_STAT1_RTH : AMC6821_STAT1_LTH;
  191. break;
  192. case hwmon_temp_crit_alarm:
  193. reg = AMC6821_REG_STAT2;
  194. mask = channel ? AMC6821_STAT2_RTC : AMC6821_STAT2_LTC;
  195. break;
  196. case hwmon_temp_fault:
  197. reg = AMC6821_REG_STAT1;
  198. mask = AMC6821_STAT1_RTF;
  199. break;
  200. default:
  201. return -EOPNOTSUPP;
  202. }
  203. break;
  204. case hwmon_fan:
  205. switch (attr) {
  206. case hwmon_fan_fault:
  207. reg = AMC6821_REG_STAT1;
  208. mask = AMC6821_STAT1_FANS;
  209. break;
  210. default:
  211. return -EOPNOTSUPP;
  212. }
  213. break;
  214. default:
  215. return -EOPNOTSUPP;
  216. }
  217. err = regmap_read(regmap, reg, &regval);
  218. if (err)
  219. return err;
  220. *val = !!(regval & mask);
  221. return 0;
  222. }
  223. static int amc6821_temp_read(struct device *dev, u32 attr, int channel, long *val)
  224. {
  225. struct amc6821_data *data = dev_get_drvdata(dev);
  226. switch (attr) {
  227. case hwmon_temp_input:
  228. case hwmon_temp_min:
  229. case hwmon_temp_max:
  230. case hwmon_temp_crit:
  231. return amc6821_temp_read_values(data->regmap, attr, channel, val);
  232. case hwmon_temp_min_alarm:
  233. case hwmon_temp_max_alarm:
  234. case hwmon_temp_crit_alarm:
  235. case hwmon_temp_fault:
  236. return amc6821_read_alarms(data->regmap, hwmon_temp, attr, channel, val);
  237. default:
  238. return -EOPNOTSUPP;
  239. }
  240. }
  241. static int amc6821_temp_write(struct device *dev, u32 attr, int channel, long val)
  242. {
  243. struct amc6821_data *data = dev_get_drvdata(dev);
  244. int reg;
  245. val = DIV_ROUND_CLOSEST(clamp_val(val, -128000, 127000), 1000);
  246. switch (attr) {
  247. case hwmon_temp_min:
  248. reg = channel ? AMC6821_REG_RTEMP_LIMIT_MIN : AMC6821_REG_LTEMP_LIMIT_MIN;
  249. break;
  250. case hwmon_temp_max:
  251. reg = channel ? AMC6821_REG_RTEMP_LIMIT_MAX : AMC6821_REG_LTEMP_LIMIT_MAX;
  252. break;
  253. case hwmon_temp_crit:
  254. reg = channel ? AMC6821_REG_RTEMP_CRIT : AMC6821_REG_LTEMP_CRIT;
  255. break;
  256. default:
  257. return -EOPNOTSUPP;
  258. }
  259. return regmap_write(data->regmap, reg, val);
  260. }
  261. static int amc6821_pwm_read(struct device *dev, u32 attr, long *val)
  262. {
  263. struct amc6821_data *data = dev_get_drvdata(dev);
  264. struct regmap *regmap = data->regmap;
  265. u32 regval;
  266. int err;
  267. switch (attr) {
  268. case hwmon_pwm_enable:
  269. err = regmap_read(regmap, AMC6821_REG_CONF1, &regval);
  270. if (err)
  271. return err;
  272. switch (regval & (AMC6821_CONF1_FDRC0 | AMC6821_CONF1_FDRC1)) {
  273. case 0:
  274. *val = 1; /* manual */
  275. break;
  276. case AMC6821_CONF1_FDRC0:
  277. *val = 4; /* target rpm (fan1_target) controlled */
  278. break;
  279. case AMC6821_CONF1_FDRC1:
  280. *val = 2; /* remote temp controlled */
  281. break;
  282. default:
  283. *val = 3; /* max(local, remote) temp controlled */
  284. break;
  285. }
  286. return 0;
  287. case hwmon_pwm_mode:
  288. err = regmap_read(regmap, AMC6821_REG_CONF2, &regval);
  289. if (err)
  290. return err;
  291. *val = !!(regval & AMC6821_CONF2_TACH_MODE);
  292. return 0;
  293. case hwmon_pwm_auto_channels_temp:
  294. err = regmap_read(regmap, AMC6821_REG_CONF1, &regval);
  295. if (err)
  296. return err;
  297. switch (regval & (AMC6821_CONF1_FDRC0 | AMC6821_CONF1_FDRC1)) {
  298. case 0:
  299. case AMC6821_CONF1_FDRC0:
  300. *val = 0; /* manual or target rpm controlled */
  301. break;
  302. case AMC6821_CONF1_FDRC1:
  303. *val = 2; /* remote temp controlled */
  304. break;
  305. default:
  306. *val = 3; /* max(local, remote) temp controlled */
  307. break;
  308. }
  309. return 0;
  310. case hwmon_pwm_input:
  311. err = regmap_read(regmap, AMC6821_REG_DCY, &regval);
  312. if (err)
  313. return err;
  314. *val = regval;
  315. return 0;
  316. default:
  317. return -EOPNOTSUPP;
  318. }
  319. }
  320. static int amc6821_pwm_write(struct device *dev, u32 attr, long val)
  321. {
  322. struct amc6821_data *data = dev_get_drvdata(dev);
  323. struct regmap *regmap = data->regmap;
  324. u32 mode;
  325. switch (attr) {
  326. case hwmon_pwm_enable:
  327. switch (val) {
  328. case 1:
  329. mode = 0;
  330. break;
  331. case 2:
  332. mode = AMC6821_CONF1_FDRC1;
  333. break;
  334. case 3:
  335. mode = AMC6821_CONF1_FDRC0 | AMC6821_CONF1_FDRC1;
  336. break;
  337. case 4:
  338. mode = AMC6821_CONF1_FDRC0;
  339. break;
  340. default:
  341. return -EINVAL;
  342. }
  343. return regmap_update_bits(regmap, AMC6821_REG_CONF1,
  344. AMC6821_CONF1_FDRC0 | AMC6821_CONF1_FDRC1,
  345. mode);
  346. case hwmon_pwm_mode:
  347. if (val < 0 || val > 1)
  348. return -EINVAL;
  349. return regmap_update_bits(regmap, AMC6821_REG_CONF2,
  350. AMC6821_CONF2_TACH_MODE,
  351. val ? AMC6821_CONF2_TACH_MODE : 0);
  352. break;
  353. case hwmon_pwm_input:
  354. if (val < 0 || val > 255)
  355. return -EINVAL;
  356. return regmap_write(regmap, AMC6821_REG_DCY, val);
  357. default:
  358. return -EOPNOTSUPP;
  359. }
  360. }
  361. static int amc6821_fan_read_rpm(struct regmap *regmap, u32 attr, long *val)
  362. {
  363. int reg, err;
  364. u8 regs[2];
  365. u32 regval;
  366. switch (attr) {
  367. case hwmon_fan_input:
  368. reg = AMC6821_REG_TDATA_LOW;
  369. break;
  370. case hwmon_fan_min:
  371. reg = AMC6821_REG_TACH_LLIMITL;
  372. break;
  373. case hwmon_fan_max:
  374. reg = AMC6821_REG_TACH_HLIMITL;
  375. break;
  376. case hwmon_fan_target:
  377. reg = AMC6821_REG_TACH_SETTINGL;
  378. break;
  379. default:
  380. return -EOPNOTSUPP;
  381. }
  382. err = regmap_bulk_read(regmap, reg, regs, 2);
  383. if (err)
  384. return err;
  385. regval = (regs[1] << 8) | regs[0];
  386. *val = regval ? 6000000 / regval : 0;
  387. return 0;
  388. }
  389. static int amc6821_fan_read(struct device *dev, u32 attr, long *val)
  390. {
  391. struct amc6821_data *data = dev_get_drvdata(dev);
  392. struct regmap *regmap = data->regmap;
  393. u32 regval;
  394. int err;
  395. switch (attr) {
  396. case hwmon_fan_input:
  397. case hwmon_fan_min:
  398. case hwmon_fan_max:
  399. case hwmon_fan_target:
  400. return amc6821_fan_read_rpm(regmap, attr, val);
  401. case hwmon_fan_fault:
  402. return amc6821_read_alarms(regmap, hwmon_fan, attr, 0, val);
  403. case hwmon_fan_pulses:
  404. err = regmap_read(regmap, AMC6821_REG_CONF4, &regval);
  405. if (err)
  406. return err;
  407. *val = (regval & AMC6821_CONF4_PSPR) ? 4 : 2;
  408. return 0;
  409. default:
  410. return -EOPNOTSUPP;
  411. }
  412. }
  413. static int amc6821_fan_write(struct device *dev, u32 attr, long val)
  414. {
  415. struct amc6821_data *data = dev_get_drvdata(dev);
  416. struct regmap *regmap = data->regmap;
  417. u8 regs[2];
  418. int reg;
  419. if (attr == hwmon_fan_pulses) {
  420. if (val != 2 && val != 4)
  421. return -EINVAL;
  422. return regmap_update_bits(regmap, AMC6821_REG_CONF4,
  423. AMC6821_CONF4_PSPR,
  424. val == 4 ? AMC6821_CONF4_PSPR : 0);
  425. }
  426. if (val < 0)
  427. return -EINVAL;
  428. switch (attr) {
  429. case hwmon_fan_min:
  430. if (!val) /* no unlimited minimum speed */
  431. return -EINVAL;
  432. reg = AMC6821_REG_TACH_LLIMITL;
  433. break;
  434. case hwmon_fan_max:
  435. reg = AMC6821_REG_TACH_HLIMITL;
  436. break;
  437. case hwmon_fan_target:
  438. if (!val) /* no unlimited target speed */
  439. return -EINVAL;
  440. reg = AMC6821_REG_TACH_SETTINGL;
  441. break;
  442. default:
  443. return -EOPNOTSUPP;
  444. }
  445. val = val ? 6000000 / clamp_val(val, 1, 6000000) : 0;
  446. val = clamp_val(val, 0, 0xffff);
  447. regs[0] = val & 0xff;
  448. regs[1] = val >> 8;
  449. return regmap_bulk_write(data->regmap, reg, regs, 2);
  450. }
  451. static ssize_t temp_auto_point_temp_show(struct device *dev,
  452. struct device_attribute *devattr,
  453. char *buf)
  454. {
  455. struct amc6821_data *data = dev_get_drvdata(dev);
  456. int ix = to_sensor_dev_attr_2(devattr)->index;
  457. int nr = to_sensor_dev_attr_2(devattr)->nr;
  458. u8 temps[3];
  459. int err;
  460. mutex_lock(&data->update_lock);
  461. err = amc6821_get_auto_point_temps(data->regmap, nr, temps);
  462. mutex_unlock(&data->update_lock);
  463. if (err)
  464. return err;
  465. return sysfs_emit(buf, "%d\n", temps[ix] * 1000);
  466. }
  467. static ssize_t pwm1_auto_point_pwm_show(struct device *dev,
  468. struct device_attribute *devattr,
  469. char *buf)
  470. {
  471. struct amc6821_data *data = dev_get_drvdata(dev);
  472. int ix = to_sensor_dev_attr(devattr)->index;
  473. u32 val;
  474. int err;
  475. switch (ix) {
  476. case 0:
  477. val = 0;
  478. break;
  479. case 1:
  480. err = regmap_read(data->regmap, AMC6821_REG_DCY_LOW_TEMP, &val);
  481. if (err)
  482. return err;
  483. break;
  484. default:
  485. val = 255;
  486. break;
  487. }
  488. return sysfs_emit(buf, "%d\n", val);
  489. }
  490. /*
  491. * Set TEMP[0-4] (low temperature) and SLP[0-2] (slope) of local or remote
  492. * TEMP-FAN control register.
  493. *
  494. * Return 0 on success or negative error code.
  495. *
  496. * Channel 0: local, channel 1: remote
  497. */
  498. static inline int set_slope_register(struct regmap *regmap, int channel, u8 *temps)
  499. {
  500. u8 regval = FIELD_PREP(AMC6821_TEMP_LIMIT_MASK, temps[1] / 4);
  501. u8 tmp, dpwm;
  502. int err, dt;
  503. u32 pwm;
  504. err = regmap_read(regmap, AMC6821_REG_DCY_LOW_TEMP, &pwm);
  505. if (err)
  506. return err;
  507. dpwm = 255 - pwm;
  508. dt = temps[2] - temps[1];
  509. for (tmp = 4; tmp > 0; tmp--) {
  510. if (dt * (32 >> tmp) >= dpwm)
  511. break;
  512. }
  513. regval |= FIELD_PREP(AMC6821_TEMP_SLOPE_MASK, tmp);
  514. return regmap_write(regmap,
  515. channel ? AMC6821_REG_RTEMP_FAN_CTRL : AMC6821_REG_LTEMP_FAN_CTRL,
  516. regval);
  517. }
  518. static ssize_t temp_auto_point_temp_store(struct device *dev,
  519. struct device_attribute *attr,
  520. const char *buf, size_t count)
  521. {
  522. struct amc6821_data *data = dev_get_drvdata(dev);
  523. int ix = to_sensor_dev_attr_2(attr)->index;
  524. int nr = to_sensor_dev_attr_2(attr)->nr;
  525. struct regmap *regmap = data->regmap;
  526. u8 temps[3], otemps[3];
  527. long val;
  528. int ret;
  529. ret = kstrtol(buf, 10, &val);
  530. if (ret)
  531. return ret;
  532. mutex_lock(&data->update_lock);
  533. ret = amc6821_get_auto_point_temps(data->regmap, nr, temps);
  534. if (ret)
  535. goto unlock;
  536. switch (ix) {
  537. case 0:
  538. /*
  539. * Passive cooling temperature. Range limit against low limit
  540. * of both channels.
  541. */
  542. ret = amc6821_get_auto_point_temps(data->regmap, 1 - nr, otemps);
  543. if (ret)
  544. goto unlock;
  545. val = DIV_ROUND_CLOSEST(clamp_val(val, 0, 63000), 1000);
  546. val = clamp_val(val, 0, min(temps[1], otemps[1]));
  547. ret = regmap_write(regmap, AMC6821_REG_PSV_TEMP, val);
  548. break;
  549. case 1:
  550. /*
  551. * Low limit; must be between passive and high limit,
  552. * and not exceed 124. Step size is 4 degrees C.
  553. */
  554. val = clamp_val(val, DIV_ROUND_UP(temps[0], 4) * 4000, 124000);
  555. temps[1] = DIV_ROUND_CLOSEST(val, 4000) * 4;
  556. val = temps[1] / 4;
  557. /* Auto-adjust high limit if necessary */
  558. temps[2] = clamp_val(temps[2], temps[1] + 1, 255);
  559. ret = set_slope_register(regmap, nr, temps);
  560. break;
  561. case 2:
  562. /* high limit, must be higher than low limit */
  563. val = clamp_val(val, (temps[1] + 1) * 1000, 255000);
  564. temps[2] = DIV_ROUND_CLOSEST(val, 1000);
  565. ret = set_slope_register(regmap, nr, temps);
  566. break;
  567. default:
  568. ret = -EINVAL;
  569. break;
  570. }
  571. unlock:
  572. mutex_unlock(&data->update_lock);
  573. return ret ? : count;
  574. }
  575. static ssize_t pwm1_auto_point_pwm_store(struct device *dev,
  576. struct device_attribute *attr,
  577. const char *buf, size_t count)
  578. {
  579. struct amc6821_data *data = dev_get_drvdata(dev);
  580. struct regmap *regmap = data->regmap;
  581. int i, ret;
  582. u8 val;
  583. ret = kstrtou8(buf, 10, &val);
  584. if (ret)
  585. return ret;
  586. mutex_lock(&data->update_lock);
  587. ret = regmap_write(regmap, AMC6821_REG_DCY_LOW_TEMP, val);
  588. if (ret)
  589. goto unlock;
  590. for (i = 0; i < 2; i++) {
  591. u8 temps[3];
  592. ret = amc6821_get_auto_point_temps(regmap, i, temps);
  593. if (ret)
  594. break;
  595. ret = set_slope_register(regmap, i, temps);
  596. if (ret)
  597. break;
  598. }
  599. unlock:
  600. mutex_unlock(&data->update_lock);
  601. return ret ? : count;
  602. }
  603. static SENSOR_DEVICE_ATTR_RO(pwm1_auto_point1_pwm, pwm1_auto_point_pwm, 0);
  604. static SENSOR_DEVICE_ATTR_RW(pwm1_auto_point2_pwm, pwm1_auto_point_pwm, 1);
  605. static SENSOR_DEVICE_ATTR_RO(pwm1_auto_point3_pwm, pwm1_auto_point_pwm, 2);
  606. static SENSOR_DEVICE_ATTR_2_RO(temp1_auto_point1_temp, temp_auto_point_temp,
  607. 0, 0);
  608. static SENSOR_DEVICE_ATTR_2_RW(temp1_auto_point2_temp, temp_auto_point_temp,
  609. 0, 1);
  610. static SENSOR_DEVICE_ATTR_2_RW(temp1_auto_point3_temp, temp_auto_point_temp,
  611. 0, 2);
  612. static SENSOR_DEVICE_ATTR_2_RW(temp2_auto_point1_temp, temp_auto_point_temp,
  613. 1, 0);
  614. static SENSOR_DEVICE_ATTR_2_RW(temp2_auto_point2_temp, temp_auto_point_temp,
  615. 1, 1);
  616. static SENSOR_DEVICE_ATTR_2_RW(temp2_auto_point3_temp, temp_auto_point_temp,
  617. 1, 2);
  618. static struct attribute *amc6821_attrs[] = {
  619. &sensor_dev_attr_pwm1_auto_point1_pwm.dev_attr.attr,
  620. &sensor_dev_attr_pwm1_auto_point2_pwm.dev_attr.attr,
  621. &sensor_dev_attr_pwm1_auto_point3_pwm.dev_attr.attr,
  622. &sensor_dev_attr_temp1_auto_point1_temp.dev_attr.attr,
  623. &sensor_dev_attr_temp1_auto_point2_temp.dev_attr.attr,
  624. &sensor_dev_attr_temp1_auto_point3_temp.dev_attr.attr,
  625. &sensor_dev_attr_temp2_auto_point1_temp.dev_attr.attr,
  626. &sensor_dev_attr_temp2_auto_point2_temp.dev_attr.attr,
  627. &sensor_dev_attr_temp2_auto_point3_temp.dev_attr.attr,
  628. NULL
  629. };
  630. ATTRIBUTE_GROUPS(amc6821);
  631. static int amc6821_read(struct device *dev, enum hwmon_sensor_types type,
  632. u32 attr, int channel, long *val)
  633. {
  634. switch (type) {
  635. case hwmon_temp:
  636. return amc6821_temp_read(dev, attr, channel, val);
  637. case hwmon_fan:
  638. return amc6821_fan_read(dev, attr, val);
  639. case hwmon_pwm:
  640. return amc6821_pwm_read(dev, attr, val);
  641. default:
  642. return -EOPNOTSUPP;
  643. }
  644. }
  645. static int amc6821_write(struct device *dev, enum hwmon_sensor_types type,
  646. u32 attr, int channel, long val)
  647. {
  648. switch (type) {
  649. case hwmon_temp:
  650. return amc6821_temp_write(dev, attr, channel, val);
  651. case hwmon_fan:
  652. return amc6821_fan_write(dev, attr, val);
  653. case hwmon_pwm:
  654. return amc6821_pwm_write(dev, attr, val);
  655. default:
  656. return -EOPNOTSUPP;
  657. }
  658. }
  659. static umode_t amc6821_is_visible(const void *data,
  660. enum hwmon_sensor_types type,
  661. u32 attr, int channel)
  662. {
  663. switch (type) {
  664. case hwmon_temp:
  665. switch (attr) {
  666. case hwmon_temp_input:
  667. case hwmon_temp_min_alarm:
  668. case hwmon_temp_max_alarm:
  669. case hwmon_temp_crit_alarm:
  670. case hwmon_temp_fault:
  671. return 0444;
  672. case hwmon_temp_min:
  673. case hwmon_temp_max:
  674. case hwmon_temp_crit:
  675. return 0644;
  676. default:
  677. return 0;
  678. }
  679. case hwmon_fan:
  680. switch (attr) {
  681. case hwmon_fan_input:
  682. case hwmon_fan_fault:
  683. return 0444;
  684. case hwmon_fan_pulses:
  685. case hwmon_fan_min:
  686. case hwmon_fan_max:
  687. case hwmon_fan_target:
  688. return 0644;
  689. default:
  690. return 0;
  691. }
  692. case hwmon_pwm:
  693. switch (attr) {
  694. case hwmon_pwm_mode:
  695. case hwmon_pwm_enable:
  696. case hwmon_pwm_input:
  697. return 0644;
  698. case hwmon_pwm_auto_channels_temp:
  699. return 0444;
  700. default:
  701. return 0;
  702. }
  703. default:
  704. return 0;
  705. }
  706. }
  707. static const struct hwmon_channel_info * const amc6821_info[] = {
  708. HWMON_CHANNEL_INFO(temp,
  709. HWMON_T_INPUT | HWMON_T_MIN | HWMON_T_MAX |
  710. HWMON_T_CRIT | HWMON_T_MIN_ALARM |
  711. HWMON_T_MAX_ALARM | HWMON_T_CRIT_ALARM,
  712. HWMON_T_INPUT | HWMON_T_MIN | HWMON_T_MAX |
  713. HWMON_T_CRIT | HWMON_T_MIN_ALARM |
  714. HWMON_T_MAX_ALARM | HWMON_T_CRIT_ALARM |
  715. HWMON_T_FAULT),
  716. HWMON_CHANNEL_INFO(fan,
  717. HWMON_F_INPUT | HWMON_F_MIN | HWMON_F_MAX |
  718. HWMON_F_TARGET | HWMON_F_PULSES | HWMON_F_FAULT),
  719. HWMON_CHANNEL_INFO(pwm,
  720. HWMON_PWM_INPUT | HWMON_PWM_ENABLE | HWMON_PWM_MODE |
  721. HWMON_PWM_AUTO_CHANNELS_TEMP),
  722. NULL
  723. };
  724. static const struct hwmon_ops amc6821_hwmon_ops = {
  725. .is_visible = amc6821_is_visible,
  726. .read = amc6821_read,
  727. .write = amc6821_write,
  728. };
  729. static const struct hwmon_chip_info amc6821_chip_info = {
  730. .ops = &amc6821_hwmon_ops,
  731. .info = amc6821_info,
  732. };
  733. static int amc6821_set_sw_dcy(struct amc6821_data *data, u8 duty_cycle)
  734. {
  735. int ret;
  736. ret = regmap_write(data->regmap, AMC6821_REG_DCY, duty_cycle);
  737. if (ret)
  738. return ret;
  739. return regmap_update_bits(data->regmap, AMC6821_REG_CONF1,
  740. AMC6821_CONF1_FDRC0 | AMC6821_CONF1_FDRC1, 0);
  741. }
  742. static int amc6821_get_max_state(struct thermal_cooling_device *cdev, unsigned long *state)
  743. {
  744. struct amc6821_data *data = cdev->devdata;
  745. if (!data)
  746. return -EINVAL;
  747. *state = data->fan_max_state;
  748. return 0;
  749. }
  750. static int amc6821_get_cur_state(struct thermal_cooling_device *cdev, unsigned long *state)
  751. {
  752. struct amc6821_data *data = cdev->devdata;
  753. if (!data)
  754. return -EINVAL;
  755. *state = data->fan_state;
  756. return 0;
  757. }
  758. static int amc6821_set_cur_state(struct thermal_cooling_device *cdev, unsigned long state)
  759. {
  760. struct amc6821_data *data = cdev->devdata;
  761. int ret;
  762. if (!data || state > data->fan_max_state)
  763. return -EINVAL;
  764. ret = amc6821_set_sw_dcy(data, data->fan_cooling_levels[state]);
  765. if (ret)
  766. return ret;
  767. data->fan_state = state;
  768. return 0;
  769. }
  770. static const struct thermal_cooling_device_ops amc6821_cooling_ops = {
  771. .get_max_state = amc6821_get_max_state,
  772. .get_cur_state = amc6821_get_cur_state,
  773. .set_cur_state = amc6821_set_cur_state,
  774. };
  775. /* Return 0 if detection is successful, -ENODEV otherwise */
  776. static int amc6821_detect(struct i2c_client *client, struct i2c_board_info *info)
  777. {
  778. struct i2c_adapter *adapter = client->adapter;
  779. int address = client->addr;
  780. int dev_id, comp_id;
  781. dev_dbg(&adapter->dev, "amc6821_detect called.\n");
  782. if (!i2c_check_functionality(adapter, I2C_FUNC_SMBUS_BYTE_DATA)) {
  783. dev_dbg(&adapter->dev,
  784. "amc6821: I2C bus doesn't support byte mode, "
  785. "skipping.\n");
  786. return -ENODEV;
  787. }
  788. dev_id = i2c_smbus_read_byte_data(client, AMC6821_REG_DEV_ID);
  789. comp_id = i2c_smbus_read_byte_data(client, AMC6821_REG_COMP_ID);
  790. if (dev_id != 0x21 || comp_id != 0x49) {
  791. dev_dbg(&adapter->dev,
  792. "amc6821: detection failed at 0x%02x.\n",
  793. address);
  794. return -ENODEV;
  795. }
  796. /*
  797. * Bit 7 of the address register is ignored, so we can check the
  798. * ID registers again
  799. */
  800. dev_id = i2c_smbus_read_byte_data(client, 0x80 | AMC6821_REG_DEV_ID);
  801. comp_id = i2c_smbus_read_byte_data(client, 0x80 | AMC6821_REG_COMP_ID);
  802. if (dev_id != 0x21 || comp_id != 0x49) {
  803. dev_dbg(&adapter->dev,
  804. "amc6821: detection failed at 0x%02x.\n",
  805. address);
  806. return -ENODEV;
  807. }
  808. dev_info(&adapter->dev, "amc6821: chip found at 0x%02x.\n", address);
  809. strscpy(info->type, "amc6821", I2C_NAME_SIZE);
  810. return 0;
  811. }
  812. static enum pwm_polarity amc6821_pwm_polarity(struct i2c_client *client,
  813. struct device_node *fan_np)
  814. {
  815. enum pwm_polarity polarity = PWM_POLARITY_NORMAL;
  816. struct of_phandle_args args;
  817. /*
  818. * For backward compatibility, the pwminv module parameter takes
  819. * always the precedence over any other device description
  820. */
  821. if (pwminv == 0)
  822. return PWM_POLARITY_NORMAL;
  823. if (pwminv > 0)
  824. return PWM_POLARITY_INVERSED;
  825. if (of_parse_phandle_with_args(fan_np, "pwms", "#pwm-cells", 0, &args))
  826. goto out;
  827. of_node_put(args.np);
  828. if (args.args_count != 2)
  829. goto out;
  830. if (args.args[1] & PWM_POLARITY_INVERTED)
  831. polarity = PWM_POLARITY_INVERSED;
  832. out:
  833. return polarity;
  834. }
  835. static int amc6821_of_fan_read_data(struct i2c_client *client,
  836. struct amc6821_data *data,
  837. struct device_node *fan_np)
  838. {
  839. int num;
  840. data->pwm_polarity = amc6821_pwm_polarity(client, fan_np);
  841. num = of_property_count_u32_elems(fan_np, "cooling-levels");
  842. if (num <= 0)
  843. return 0;
  844. data->fan_max_state = num - 1;
  845. data->fan_cooling_levels = devm_kcalloc(&client->dev, num,
  846. sizeof(u32),
  847. GFP_KERNEL);
  848. if (!data->fan_cooling_levels)
  849. return -ENOMEM;
  850. return of_property_read_u32_array(fan_np, "cooling-levels",
  851. data->fan_cooling_levels, num);
  852. }
  853. static int amc6821_init_client(struct i2c_client *client, struct amc6821_data *data)
  854. {
  855. struct regmap *regmap = data->regmap;
  856. u32 regval;
  857. int err;
  858. if (init) {
  859. err = regmap_set_bits(regmap, AMC6821_REG_CONF4, AMC6821_CONF4_MODE);
  860. if (err)
  861. return err;
  862. err = regmap_clear_bits(regmap, AMC6821_REG_CONF3, AMC6821_CONF3_THERM_FAN_EN);
  863. if (err)
  864. return err;
  865. err = regmap_clear_bits(regmap, AMC6821_REG_CONF2,
  866. AMC6821_CONF2_RTFIE |
  867. AMC6821_CONF2_LTOIE |
  868. AMC6821_CONF2_RTOIE);
  869. if (err)
  870. return err;
  871. regval = AMC6821_CONF1_START;
  872. if (data->pwm_polarity == PWM_POLARITY_INVERSED)
  873. regval |= AMC6821_CONF1_PWMINV;
  874. err = regmap_update_bits(regmap, AMC6821_REG_CONF1,
  875. AMC6821_CONF1_THERMOVIE | AMC6821_CONF1_FANIE |
  876. AMC6821_CONF1_START | AMC6821_CONF1_PWMINV,
  877. regval);
  878. if (err)
  879. return err;
  880. /* Software DCY-control mode with fan enabled when cooling-levels present */
  881. if (data->fan_cooling_levels) {
  882. err = amc6821_set_sw_dcy(data,
  883. data->fan_cooling_levels[data->fan_max_state]);
  884. if (err)
  885. return err;
  886. }
  887. }
  888. return 0;
  889. }
  890. static bool amc6821_volatile_reg(struct device *dev, unsigned int reg)
  891. {
  892. switch (reg) {
  893. case AMC6821_REG_STAT1:
  894. case AMC6821_REG_STAT2:
  895. case AMC6821_REG_TEMP_LO:
  896. case AMC6821_REG_TDATA_LOW:
  897. case AMC6821_REG_LTEMP_HI:
  898. case AMC6821_REG_RTEMP_HI:
  899. case AMC6821_REG_TDATA_HI:
  900. return true;
  901. default:
  902. return false;
  903. }
  904. }
  905. static const struct regmap_config amc6821_regmap_config = {
  906. .reg_bits = 8,
  907. .val_bits = 8,
  908. .volatile_reg = amc6821_volatile_reg,
  909. .cache_type = REGCACHE_MAPLE,
  910. };
  911. static int amc6821_probe(struct i2c_client *client)
  912. {
  913. struct device *dev = &client->dev;
  914. struct amc6821_data *data;
  915. struct device *hwmon_dev;
  916. struct regmap *regmap;
  917. struct device_node *fan_np __free(device_node) = NULL;
  918. int err;
  919. data = devm_kzalloc(dev, sizeof(struct amc6821_data), GFP_KERNEL);
  920. if (!data)
  921. return -ENOMEM;
  922. regmap = devm_regmap_init_i2c(client, &amc6821_regmap_config);
  923. if (IS_ERR(regmap))
  924. return dev_err_probe(dev, PTR_ERR(regmap),
  925. "Failed to initialize regmap\n");
  926. data->regmap = regmap;
  927. fan_np = of_get_child_by_name(dev->of_node, "fan");
  928. if (fan_np) {
  929. err = amc6821_of_fan_read_data(client, data, fan_np);
  930. if (err)
  931. return dev_err_probe(dev, err,
  932. "Failed to read fan device tree data\n");
  933. }
  934. err = amc6821_init_client(client, data);
  935. if (err)
  936. return err;
  937. if (of_device_is_compatible(dev->of_node, "tsd,mule")) {
  938. err = devm_of_platform_populate(dev);
  939. if (err)
  940. return dev_err_probe(dev, err,
  941. "Failed to create sub-devices\n");
  942. }
  943. hwmon_dev = devm_hwmon_device_register_with_info(dev, client->name,
  944. data, &amc6821_chip_info,
  945. amc6821_groups);
  946. if (IS_ERR(hwmon_dev))
  947. return dev_err_probe(dev, PTR_ERR(hwmon_dev),
  948. "Failed to initialize hwmon\n");
  949. if (IS_ENABLED(CONFIG_THERMAL) && fan_np && data->fan_cooling_levels)
  950. return PTR_ERR_OR_ZERO(devm_thermal_of_cooling_device_register(dev,
  951. fan_np, client->name, data, &amc6821_cooling_ops));
  952. return 0;
  953. }
  954. static const struct i2c_device_id amc6821_id[] = {
  955. { "amc6821" },
  956. { }
  957. };
  958. MODULE_DEVICE_TABLE(i2c, amc6821_id);
  959. static const struct of_device_id __maybe_unused amc6821_of_match[] = {
  960. {
  961. .compatible = "ti,amc6821",
  962. },
  963. {
  964. .compatible = "tsd,mule",
  965. },
  966. { }
  967. };
  968. MODULE_DEVICE_TABLE(of, amc6821_of_match);
  969. static struct i2c_driver amc6821_driver = {
  970. .class = I2C_CLASS_HWMON,
  971. .driver = {
  972. .name = "amc6821",
  973. .of_match_table = of_match_ptr(amc6821_of_match),
  974. },
  975. .probe = amc6821_probe,
  976. .id_table = amc6821_id,
  977. .detect = amc6821_detect,
  978. .address_list = normal_i2c,
  979. };
  980. module_i2c_driver(amc6821_driver);
  981. MODULE_LICENSE("GPL");
  982. MODULE_AUTHOR("T. Mertelj <tomaz.mertelj@guest.arnes.si>");
  983. MODULE_DESCRIPTION("Texas Instruments amc6821 hwmon driver");