f71805f.c 41 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405
  1. /*
  2. * f71805f.c - driver for the Fintek F71805F/FG and F71872F/FG Super-I/O
  3. * chips integrated hardware monitoring features
  4. * Copyright (C) 2005-2006 Jean Delvare <khali@linux-fr.org>
  5. *
  6. * The F71805F/FG is a LPC Super-I/O chip made by Fintek. It integrates
  7. * complete hardware monitoring features: voltage, fan and temperature
  8. * sensors, and manual and automatic fan speed control.
  9. *
  10. * The F71872F/FG is almost the same, with two more voltages monitored,
  11. * and 6 VID inputs.
  12. *
  13. * This program is free software; you can redistribute it and/or modify
  14. * it under the terms of the GNU General Public License as published by
  15. * the Free Software Foundation; either version 2 of the License, or
  16. * (at your option) any later version.
  17. *
  18. * This program is distributed in the hope that it will be useful,
  19. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  20. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  21. * GNU General Public License for more details.
  22. *
  23. * You should have received a copy of the GNU General Public License
  24. * along with this program; if not, write to the Free Software
  25. * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  26. */
  27. #include <linux/module.h>
  28. #include <linux/init.h>
  29. #include <linux/slab.h>
  30. #include <linux/jiffies.h>
  31. #include <linux/platform_device.h>
  32. #include <linux/hwmon.h>
  33. #include <linux/hwmon-sysfs.h>
  34. #include <linux/err.h>
  35. #include <linux/mutex.h>
  36. #include <linux/sysfs.h>
  37. #include <asm/io.h>
  38. static struct platform_device *pdev;
  39. #define DRVNAME "f71805f"
  40. enum kinds { f71805f, f71872f };
  41. /*
  42. * Super-I/O constants and functions
  43. */
  44. #define F71805F_LD_HWM 0x04
  45. #define SIO_REG_LDSEL 0x07 /* Logical device select */
  46. #define SIO_REG_DEVID 0x20 /* Device ID (2 bytes) */
  47. #define SIO_REG_DEVREV 0x22 /* Device revision */
  48. #define SIO_REG_MANID 0x23 /* Fintek ID (2 bytes) */
  49. #define SIO_REG_FNSEL1 0x29 /* Multi Function Select 1 (F71872F) */
  50. #define SIO_REG_ENABLE 0x30 /* Logical device enable */
  51. #define SIO_REG_ADDR 0x60 /* Logical device address (2 bytes) */
  52. #define SIO_FINTEK_ID 0x1934
  53. #define SIO_F71805F_ID 0x0406
  54. #define SIO_F71872F_ID 0x0341
  55. static inline int
  56. superio_inb(int base, int reg)
  57. {
  58. outb(reg, base);
  59. return inb(base + 1);
  60. }
  61. static int
  62. superio_inw(int base, int reg)
  63. {
  64. int val;
  65. outb(reg++, base);
  66. val = inb(base + 1) << 8;
  67. outb(reg, base);
  68. val |= inb(base + 1);
  69. return val;
  70. }
  71. static inline void
  72. superio_select(int base, int ld)
  73. {
  74. outb(SIO_REG_LDSEL, base);
  75. outb(ld, base + 1);
  76. }
  77. static inline void
  78. superio_enter(int base)
  79. {
  80. outb(0x87, base);
  81. outb(0x87, base);
  82. }
  83. static inline void
  84. superio_exit(int base)
  85. {
  86. outb(0xaa, base);
  87. }
  88. /*
  89. * ISA constants
  90. */
  91. #define REGION_LENGTH 8
  92. #define ADDR_REG_OFFSET 5
  93. #define DATA_REG_OFFSET 6
  94. /*
  95. * Registers
  96. */
  97. /* in nr from 0 to 10 (8-bit values) */
  98. #define F71805F_REG_IN(nr) (0x10 + (nr))
  99. #define F71805F_REG_IN_HIGH(nr) ((nr) < 10 ? 0x40 + 2 * (nr) : 0x2E)
  100. #define F71805F_REG_IN_LOW(nr) ((nr) < 10 ? 0x41 + 2 * (nr) : 0x2F)
  101. /* fan nr from 0 to 2 (12-bit values, two registers) */
  102. #define F71805F_REG_FAN(nr) (0x20 + 2 * (nr))
  103. #define F71805F_REG_FAN_LOW(nr) (0x28 + 2 * (nr))
  104. #define F71805F_REG_FAN_TARGET(nr) (0x69 + 16 * (nr))
  105. #define F71805F_REG_FAN_CTRL(nr) (0x60 + 16 * (nr))
  106. #define F71805F_REG_PWM_FREQ(nr) (0x63 + 16 * (nr))
  107. #define F71805F_REG_PWM_DUTY(nr) (0x6B + 16 * (nr))
  108. /* temp nr from 0 to 2 (8-bit values) */
  109. #define F71805F_REG_TEMP(nr) (0x1B + (nr))
  110. #define F71805F_REG_TEMP_HIGH(nr) (0x54 + 2 * (nr))
  111. #define F71805F_REG_TEMP_HYST(nr) (0x55 + 2 * (nr))
  112. #define F71805F_REG_TEMP_MODE 0x01
  113. #define F71805F_REG_START 0x00
  114. /* status nr from 0 to 2 */
  115. #define F71805F_REG_STATUS(nr) (0x36 + (nr))
  116. /* individual register bits */
  117. #define FAN_CTRL_DC_MODE 0x10
  118. #define FAN_CTRL_LATCH_FULL 0x08
  119. #define FAN_CTRL_MODE_MASK 0x03
  120. #define FAN_CTRL_MODE_SPEED 0x00
  121. #define FAN_CTRL_MODE_TEMPERATURE 0x01
  122. #define FAN_CTRL_MODE_MANUAL 0x02
  123. /*
  124. * Data structures and manipulation thereof
  125. */
  126. struct f71805f_data {
  127. unsigned short addr;
  128. const char *name;
  129. struct class_device *class_dev;
  130. struct mutex update_lock;
  131. char valid; /* !=0 if following fields are valid */
  132. unsigned long last_updated; /* In jiffies */
  133. unsigned long last_limits; /* In jiffies */
  134. /* Register values */
  135. u8 in[11];
  136. u8 in_high[11];
  137. u8 in_low[11];
  138. u16 has_in;
  139. u16 fan[3];
  140. u16 fan_low[3];
  141. u16 fan_target[3];
  142. u8 fan_ctrl[3];
  143. u8 pwm[3];
  144. u8 pwm_freq[3];
  145. u8 temp[3];
  146. u8 temp_high[3];
  147. u8 temp_hyst[3];
  148. u8 temp_mode;
  149. unsigned long alarms;
  150. };
  151. struct f71805f_sio_data {
  152. enum kinds kind;
  153. u8 fnsel1;
  154. };
  155. static inline long in_from_reg(u8 reg)
  156. {
  157. return (reg * 8);
  158. }
  159. /* The 2 least significant bits are not used */
  160. static inline u8 in_to_reg(long val)
  161. {
  162. if (val <= 0)
  163. return 0;
  164. if (val >= 2016)
  165. return 0xfc;
  166. return (((val + 16) / 32) << 2);
  167. }
  168. /* in0 is downscaled by a factor 2 internally */
  169. static inline long in0_from_reg(u8 reg)
  170. {
  171. return (reg * 16);
  172. }
  173. static inline u8 in0_to_reg(long val)
  174. {
  175. if (val <= 0)
  176. return 0;
  177. if (val >= 4032)
  178. return 0xfc;
  179. return (((val + 32) / 64) << 2);
  180. }
  181. /* The 4 most significant bits are not used */
  182. static inline long fan_from_reg(u16 reg)
  183. {
  184. reg &= 0xfff;
  185. if (!reg || reg == 0xfff)
  186. return 0;
  187. return (1500000 / reg);
  188. }
  189. static inline u16 fan_to_reg(long rpm)
  190. {
  191. /* If the low limit is set below what the chip can measure,
  192. store the largest possible 12-bit value in the registers,
  193. so that no alarm will ever trigger. */
  194. if (rpm < 367)
  195. return 0xfff;
  196. return (1500000 / rpm);
  197. }
  198. static inline unsigned long pwm_freq_from_reg(u8 reg)
  199. {
  200. unsigned long clock = (reg & 0x80) ? 48000000UL : 1000000UL;
  201. reg &= 0x7f;
  202. if (reg == 0)
  203. reg++;
  204. return clock / (reg << 8);
  205. }
  206. static inline u8 pwm_freq_to_reg(unsigned long val)
  207. {
  208. if (val >= 187500) /* The highest we can do */
  209. return 0x80;
  210. if (val >= 1475) /* Use 48 MHz clock */
  211. return 0x80 | (48000000UL / (val << 8));
  212. if (val < 31) /* The lowest we can do */
  213. return 0x7f;
  214. else /* Use 1 MHz clock */
  215. return 1000000UL / (val << 8);
  216. }
  217. static inline int pwm_mode_from_reg(u8 reg)
  218. {
  219. return !(reg & FAN_CTRL_DC_MODE);
  220. }
  221. static inline long temp_from_reg(u8 reg)
  222. {
  223. return (reg * 1000);
  224. }
  225. static inline u8 temp_to_reg(long val)
  226. {
  227. if (val < 0)
  228. val = 0;
  229. else if (val > 1000 * 0xff)
  230. val = 0xff;
  231. return ((val + 500) / 1000);
  232. }
  233. /*
  234. * Device I/O access
  235. */
  236. /* Must be called with data->update_lock held, except during initialization */
  237. static u8 f71805f_read8(struct f71805f_data *data, u8 reg)
  238. {
  239. outb(reg, data->addr + ADDR_REG_OFFSET);
  240. return inb(data->addr + DATA_REG_OFFSET);
  241. }
  242. /* Must be called with data->update_lock held, except during initialization */
  243. static void f71805f_write8(struct f71805f_data *data, u8 reg, u8 val)
  244. {
  245. outb(reg, data->addr + ADDR_REG_OFFSET);
  246. outb(val, data->addr + DATA_REG_OFFSET);
  247. }
  248. /* It is important to read the MSB first, because doing so latches the
  249. value of the LSB, so we are sure both bytes belong to the same value.
  250. Must be called with data->update_lock held, except during initialization */
  251. static u16 f71805f_read16(struct f71805f_data *data, u8 reg)
  252. {
  253. u16 val;
  254. outb(reg, data->addr + ADDR_REG_OFFSET);
  255. val = inb(data->addr + DATA_REG_OFFSET) << 8;
  256. outb(++reg, data->addr + ADDR_REG_OFFSET);
  257. val |= inb(data->addr + DATA_REG_OFFSET);
  258. return val;
  259. }
  260. /* Must be called with data->update_lock held, except during initialization */
  261. static void f71805f_write16(struct f71805f_data *data, u8 reg, u16 val)
  262. {
  263. outb(reg, data->addr + ADDR_REG_OFFSET);
  264. outb(val >> 8, data->addr + DATA_REG_OFFSET);
  265. outb(++reg, data->addr + ADDR_REG_OFFSET);
  266. outb(val & 0xff, data->addr + DATA_REG_OFFSET);
  267. }
  268. static struct f71805f_data *f71805f_update_device(struct device *dev)
  269. {
  270. struct f71805f_data *data = dev_get_drvdata(dev);
  271. int nr;
  272. mutex_lock(&data->update_lock);
  273. /* Limit registers cache is refreshed after 60 seconds */
  274. if (time_after(jiffies, data->last_updated + 60 * HZ)
  275. || !data->valid) {
  276. for (nr = 0; nr < 11; nr++) {
  277. if (!(data->has_in & (1 << nr)))
  278. continue;
  279. data->in_high[nr] = f71805f_read8(data,
  280. F71805F_REG_IN_HIGH(nr));
  281. data->in_low[nr] = f71805f_read8(data,
  282. F71805F_REG_IN_LOW(nr));
  283. }
  284. for (nr = 0; nr < 3; nr++) {
  285. data->fan_low[nr] = f71805f_read16(data,
  286. F71805F_REG_FAN_LOW(nr));
  287. data->fan_target[nr] = f71805f_read16(data,
  288. F71805F_REG_FAN_TARGET(nr));
  289. data->pwm_freq[nr] = f71805f_read8(data,
  290. F71805F_REG_PWM_FREQ(nr));
  291. }
  292. for (nr = 0; nr < 3; nr++) {
  293. data->temp_high[nr] = f71805f_read8(data,
  294. F71805F_REG_TEMP_HIGH(nr));
  295. data->temp_hyst[nr] = f71805f_read8(data,
  296. F71805F_REG_TEMP_HYST(nr));
  297. }
  298. data->temp_mode = f71805f_read8(data, F71805F_REG_TEMP_MODE);
  299. data->last_limits = jiffies;
  300. }
  301. /* Measurement registers cache is refreshed after 1 second */
  302. if (time_after(jiffies, data->last_updated + HZ)
  303. || !data->valid) {
  304. for (nr = 0; nr < 11; nr++) {
  305. if (!(data->has_in & (1 << nr)))
  306. continue;
  307. data->in[nr] = f71805f_read8(data,
  308. F71805F_REG_IN(nr));
  309. }
  310. for (nr = 0; nr < 3; nr++) {
  311. data->fan[nr] = f71805f_read16(data,
  312. F71805F_REG_FAN(nr));
  313. data->fan_ctrl[nr] = f71805f_read8(data,
  314. F71805F_REG_FAN_CTRL(nr));
  315. data->pwm[nr] = f71805f_read8(data,
  316. F71805F_REG_PWM_DUTY(nr));
  317. }
  318. for (nr = 0; nr < 3; nr++) {
  319. data->temp[nr] = f71805f_read8(data,
  320. F71805F_REG_TEMP(nr));
  321. }
  322. data->alarms = f71805f_read8(data, F71805F_REG_STATUS(0))
  323. + (f71805f_read8(data, F71805F_REG_STATUS(1)) << 8)
  324. + (f71805f_read8(data, F71805F_REG_STATUS(2)) << 16);
  325. data->last_updated = jiffies;
  326. data->valid = 1;
  327. }
  328. mutex_unlock(&data->update_lock);
  329. return data;
  330. }
  331. /*
  332. * Sysfs interface
  333. */
  334. static ssize_t show_in0(struct device *dev, struct device_attribute *devattr,
  335. char *buf)
  336. {
  337. struct f71805f_data *data = f71805f_update_device(dev);
  338. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  339. int nr = attr->index;
  340. return sprintf(buf, "%ld\n", in0_from_reg(data->in[nr]));
  341. }
  342. static ssize_t show_in0_max(struct device *dev, struct device_attribute
  343. *devattr, char *buf)
  344. {
  345. struct f71805f_data *data = f71805f_update_device(dev);
  346. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  347. int nr = attr->index;
  348. return sprintf(buf, "%ld\n", in0_from_reg(data->in_high[nr]));
  349. }
  350. static ssize_t show_in0_min(struct device *dev, struct device_attribute
  351. *devattr, char *buf)
  352. {
  353. struct f71805f_data *data = f71805f_update_device(dev);
  354. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  355. int nr = attr->index;
  356. return sprintf(buf, "%ld\n", in0_from_reg(data->in_low[nr]));
  357. }
  358. static ssize_t set_in0_max(struct device *dev, struct device_attribute
  359. *devattr, const char *buf, size_t count)
  360. {
  361. struct f71805f_data *data = dev_get_drvdata(dev);
  362. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  363. int nr = attr->index;
  364. long val = simple_strtol(buf, NULL, 10);
  365. mutex_lock(&data->update_lock);
  366. data->in_high[nr] = in0_to_reg(val);
  367. f71805f_write8(data, F71805F_REG_IN_HIGH(nr), data->in_high[nr]);
  368. mutex_unlock(&data->update_lock);
  369. return count;
  370. }
  371. static ssize_t set_in0_min(struct device *dev, struct device_attribute
  372. *devattr, const char *buf, size_t count)
  373. {
  374. struct f71805f_data *data = dev_get_drvdata(dev);
  375. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  376. int nr = attr->index;
  377. long val = simple_strtol(buf, NULL, 10);
  378. mutex_lock(&data->update_lock);
  379. data->in_low[nr] = in0_to_reg(val);
  380. f71805f_write8(data, F71805F_REG_IN_LOW(nr), data->in_low[nr]);
  381. mutex_unlock(&data->update_lock);
  382. return count;
  383. }
  384. static ssize_t show_in(struct device *dev, struct device_attribute *devattr,
  385. char *buf)
  386. {
  387. struct f71805f_data *data = f71805f_update_device(dev);
  388. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  389. int nr = attr->index;
  390. return sprintf(buf, "%ld\n", in_from_reg(data->in[nr]));
  391. }
  392. static ssize_t show_in_max(struct device *dev, struct device_attribute
  393. *devattr, char *buf)
  394. {
  395. struct f71805f_data *data = f71805f_update_device(dev);
  396. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  397. int nr = attr->index;
  398. return sprintf(buf, "%ld\n", in_from_reg(data->in_high[nr]));
  399. }
  400. static ssize_t show_in_min(struct device *dev, struct device_attribute
  401. *devattr, char *buf)
  402. {
  403. struct f71805f_data *data = f71805f_update_device(dev);
  404. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  405. int nr = attr->index;
  406. return sprintf(buf, "%ld\n", in_from_reg(data->in_low[nr]));
  407. }
  408. static ssize_t set_in_max(struct device *dev, struct device_attribute
  409. *devattr, const char *buf, size_t count)
  410. {
  411. struct f71805f_data *data = dev_get_drvdata(dev);
  412. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  413. int nr = attr->index;
  414. long val = simple_strtol(buf, NULL, 10);
  415. mutex_lock(&data->update_lock);
  416. data->in_high[nr] = in_to_reg(val);
  417. f71805f_write8(data, F71805F_REG_IN_HIGH(nr), data->in_high[nr]);
  418. mutex_unlock(&data->update_lock);
  419. return count;
  420. }
  421. static ssize_t set_in_min(struct device *dev, struct device_attribute
  422. *devattr, const char *buf, size_t count)
  423. {
  424. struct f71805f_data *data = dev_get_drvdata(dev);
  425. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  426. int nr = attr->index;
  427. long val = simple_strtol(buf, NULL, 10);
  428. mutex_lock(&data->update_lock);
  429. data->in_low[nr] = in_to_reg(val);
  430. f71805f_write8(data, F71805F_REG_IN_LOW(nr), data->in_low[nr]);
  431. mutex_unlock(&data->update_lock);
  432. return count;
  433. }
  434. static ssize_t show_fan(struct device *dev, struct device_attribute *devattr,
  435. char *buf)
  436. {
  437. struct f71805f_data *data = f71805f_update_device(dev);
  438. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  439. int nr = attr->index;
  440. return sprintf(buf, "%ld\n", fan_from_reg(data->fan[nr]));
  441. }
  442. static ssize_t show_fan_min(struct device *dev, struct device_attribute
  443. *devattr, char *buf)
  444. {
  445. struct f71805f_data *data = f71805f_update_device(dev);
  446. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  447. int nr = attr->index;
  448. return sprintf(buf, "%ld\n", fan_from_reg(data->fan_low[nr]));
  449. }
  450. static ssize_t show_fan_target(struct device *dev, struct device_attribute
  451. *devattr, char *buf)
  452. {
  453. struct f71805f_data *data = f71805f_update_device(dev);
  454. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  455. int nr = attr->index;
  456. return sprintf(buf, "%ld\n", fan_from_reg(data->fan_target[nr]));
  457. }
  458. static ssize_t set_fan_min(struct device *dev, struct device_attribute
  459. *devattr, const char *buf, size_t count)
  460. {
  461. struct f71805f_data *data = dev_get_drvdata(dev);
  462. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  463. int nr = attr->index;
  464. long val = simple_strtol(buf, NULL, 10);
  465. mutex_lock(&data->update_lock);
  466. data->fan_low[nr] = fan_to_reg(val);
  467. f71805f_write16(data, F71805F_REG_FAN_LOW(nr), data->fan_low[nr]);
  468. mutex_unlock(&data->update_lock);
  469. return count;
  470. }
  471. static ssize_t set_fan_target(struct device *dev, struct device_attribute
  472. *devattr, const char *buf, size_t count)
  473. {
  474. struct f71805f_data *data = dev_get_drvdata(dev);
  475. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  476. int nr = attr->index;
  477. long val = simple_strtol(buf, NULL, 10);
  478. mutex_lock(&data->update_lock);
  479. data->fan_target[nr] = fan_to_reg(val);
  480. f71805f_write16(data, F71805F_REG_FAN_TARGET(nr),
  481. data->fan_target[nr]);
  482. mutex_unlock(&data->update_lock);
  483. return count;
  484. }
  485. static ssize_t show_pwm(struct device *dev, struct device_attribute *devattr,
  486. char *buf)
  487. {
  488. struct f71805f_data *data = f71805f_update_device(dev);
  489. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  490. int nr = attr->index;
  491. return sprintf(buf, "%d\n", (int)data->pwm[nr]);
  492. }
  493. static ssize_t show_pwm_enable(struct device *dev, struct device_attribute
  494. *devattr, char *buf)
  495. {
  496. struct f71805f_data *data = f71805f_update_device(dev);
  497. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  498. int nr = attr->index;
  499. int mode;
  500. switch (data->fan_ctrl[nr] & FAN_CTRL_MODE_MASK) {
  501. case FAN_CTRL_MODE_SPEED:
  502. mode = 3;
  503. break;
  504. case FAN_CTRL_MODE_TEMPERATURE:
  505. mode = 2;
  506. break;
  507. default: /* MANUAL */
  508. mode = 1;
  509. }
  510. return sprintf(buf, "%d\n", mode);
  511. }
  512. static ssize_t show_pwm_freq(struct device *dev, struct device_attribute
  513. *devattr, char *buf)
  514. {
  515. struct f71805f_data *data = f71805f_update_device(dev);
  516. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  517. int nr = attr->index;
  518. return sprintf(buf, "%lu\n", pwm_freq_from_reg(data->pwm_freq[nr]));
  519. }
  520. static ssize_t show_pwm_mode(struct device *dev, struct device_attribute
  521. *devattr, char *buf)
  522. {
  523. struct f71805f_data *data = f71805f_update_device(dev);
  524. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  525. int nr = attr->index;
  526. return sprintf(buf, "%d\n", pwm_mode_from_reg(data->fan_ctrl[nr]));
  527. }
  528. static ssize_t set_pwm(struct device *dev, struct device_attribute *devattr,
  529. const char *buf, size_t count)
  530. {
  531. struct f71805f_data *data = dev_get_drvdata(dev);
  532. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  533. int nr = attr->index;
  534. unsigned long val = simple_strtoul(buf, NULL, 10);
  535. if (val > 255)
  536. return -EINVAL;
  537. mutex_lock(&data->update_lock);
  538. data->pwm[nr] = val;
  539. f71805f_write8(data, F71805F_REG_PWM_DUTY(nr), data->pwm[nr]);
  540. mutex_unlock(&data->update_lock);
  541. return count;
  542. }
  543. static struct attribute *f71805f_attr_pwm[];
  544. static ssize_t set_pwm_enable(struct device *dev, struct device_attribute
  545. *devattr, const char *buf, size_t count)
  546. {
  547. struct f71805f_data *data = dev_get_drvdata(dev);
  548. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  549. int nr = attr->index;
  550. unsigned long val = simple_strtoul(buf, NULL, 10);
  551. u8 reg;
  552. if (val < 1 || val > 3)
  553. return -EINVAL;
  554. if (val > 1) { /* Automatic mode, user can't set PWM value */
  555. if (sysfs_chmod_file(&dev->kobj, f71805f_attr_pwm[nr],
  556. S_IRUGO))
  557. dev_dbg(dev, "chmod -w pwm%d failed\n", nr + 1);
  558. }
  559. mutex_lock(&data->update_lock);
  560. reg = f71805f_read8(data, F71805F_REG_FAN_CTRL(nr))
  561. & ~FAN_CTRL_MODE_MASK;
  562. switch (val) {
  563. case 1:
  564. reg |= FAN_CTRL_MODE_MANUAL;
  565. break;
  566. case 2:
  567. reg |= FAN_CTRL_MODE_TEMPERATURE;
  568. break;
  569. case 3:
  570. reg |= FAN_CTRL_MODE_SPEED;
  571. break;
  572. }
  573. data->fan_ctrl[nr] = reg;
  574. f71805f_write8(data, F71805F_REG_FAN_CTRL(nr), reg);
  575. mutex_unlock(&data->update_lock);
  576. if (val == 1) { /* Manual mode, user can set PWM value */
  577. if (sysfs_chmod_file(&dev->kobj, f71805f_attr_pwm[nr],
  578. S_IRUGO | S_IWUSR))
  579. dev_dbg(dev, "chmod +w pwm%d failed\n", nr + 1);
  580. }
  581. return count;
  582. }
  583. static ssize_t set_pwm_freq(struct device *dev, struct device_attribute
  584. *devattr, const char *buf, size_t count)
  585. {
  586. struct f71805f_data *data = dev_get_drvdata(dev);
  587. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  588. int nr = attr->index;
  589. unsigned long val = simple_strtoul(buf, NULL, 10);
  590. mutex_lock(&data->update_lock);
  591. data->pwm_freq[nr] = pwm_freq_to_reg(val);
  592. f71805f_write8(data, F71805F_REG_PWM_FREQ(nr), data->pwm_freq[nr]);
  593. mutex_unlock(&data->update_lock);
  594. return count;
  595. }
  596. static ssize_t show_temp(struct device *dev, struct device_attribute *devattr,
  597. char *buf)
  598. {
  599. struct f71805f_data *data = f71805f_update_device(dev);
  600. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  601. int nr = attr->index;
  602. return sprintf(buf, "%ld\n", temp_from_reg(data->temp[nr]));
  603. }
  604. static ssize_t show_temp_max(struct device *dev, struct device_attribute
  605. *devattr, char *buf)
  606. {
  607. struct f71805f_data *data = f71805f_update_device(dev);
  608. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  609. int nr = attr->index;
  610. return sprintf(buf, "%ld\n", temp_from_reg(data->temp_high[nr]));
  611. }
  612. static ssize_t show_temp_hyst(struct device *dev, struct device_attribute
  613. *devattr, char *buf)
  614. {
  615. struct f71805f_data *data = f71805f_update_device(dev);
  616. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  617. int nr = attr->index;
  618. return sprintf(buf, "%ld\n", temp_from_reg(data->temp_hyst[nr]));
  619. }
  620. static ssize_t show_temp_type(struct device *dev, struct device_attribute
  621. *devattr, char *buf)
  622. {
  623. struct f71805f_data *data = f71805f_update_device(dev);
  624. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  625. int nr = attr->index;
  626. /* 3 is diode, 4 is thermistor */
  627. return sprintf(buf, "%u\n", (data->temp_mode & (1 << nr)) ? 3 : 4);
  628. }
  629. static ssize_t set_temp_max(struct device *dev, struct device_attribute
  630. *devattr, const char *buf, size_t count)
  631. {
  632. struct f71805f_data *data = dev_get_drvdata(dev);
  633. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  634. int nr = attr->index;
  635. long val = simple_strtol(buf, NULL, 10);
  636. mutex_lock(&data->update_lock);
  637. data->temp_high[nr] = temp_to_reg(val);
  638. f71805f_write8(data, F71805F_REG_TEMP_HIGH(nr), data->temp_high[nr]);
  639. mutex_unlock(&data->update_lock);
  640. return count;
  641. }
  642. static ssize_t set_temp_hyst(struct device *dev, struct device_attribute
  643. *devattr, const char *buf, size_t count)
  644. {
  645. struct f71805f_data *data = dev_get_drvdata(dev);
  646. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  647. int nr = attr->index;
  648. long val = simple_strtol(buf, NULL, 10);
  649. mutex_lock(&data->update_lock);
  650. data->temp_hyst[nr] = temp_to_reg(val);
  651. f71805f_write8(data, F71805F_REG_TEMP_HYST(nr), data->temp_hyst[nr]);
  652. mutex_unlock(&data->update_lock);
  653. return count;
  654. }
  655. static ssize_t show_alarms_in(struct device *dev, struct device_attribute
  656. *devattr, char *buf)
  657. {
  658. struct f71805f_data *data = f71805f_update_device(dev);
  659. return sprintf(buf, "%lu\n", data->alarms & 0x7ff);
  660. }
  661. static ssize_t show_alarms_fan(struct device *dev, struct device_attribute
  662. *devattr, char *buf)
  663. {
  664. struct f71805f_data *data = f71805f_update_device(dev);
  665. return sprintf(buf, "%lu\n", (data->alarms >> 16) & 0x07);
  666. }
  667. static ssize_t show_alarms_temp(struct device *dev, struct device_attribute
  668. *devattr, char *buf)
  669. {
  670. struct f71805f_data *data = f71805f_update_device(dev);
  671. return sprintf(buf, "%lu\n", (data->alarms >> 11) & 0x07);
  672. }
  673. static ssize_t show_alarm(struct device *dev, struct device_attribute
  674. *devattr, char *buf)
  675. {
  676. struct f71805f_data *data = f71805f_update_device(dev);
  677. struct sensor_device_attribute *attr = to_sensor_dev_attr(devattr);
  678. int bitnr = attr->index;
  679. return sprintf(buf, "%lu\n", (data->alarms >> bitnr) & 1);
  680. }
  681. static ssize_t show_name(struct device *dev, struct device_attribute
  682. *devattr, char *buf)
  683. {
  684. struct f71805f_data *data = dev_get_drvdata(dev);
  685. return sprintf(buf, "%s\n", data->name);
  686. }
  687. static SENSOR_DEVICE_ATTR(in0_input, S_IRUGO, show_in0, NULL, 0);
  688. static SENSOR_DEVICE_ATTR(in0_max, S_IRUGO| S_IWUSR,
  689. show_in0_max, set_in0_max, 0);
  690. static SENSOR_DEVICE_ATTR(in0_min, S_IRUGO| S_IWUSR,
  691. show_in0_min, set_in0_min, 0);
  692. static SENSOR_DEVICE_ATTR(in1_input, S_IRUGO, show_in, NULL, 1);
  693. static SENSOR_DEVICE_ATTR(in1_max, S_IRUGO | S_IWUSR,
  694. show_in_max, set_in_max, 1);
  695. static SENSOR_DEVICE_ATTR(in1_min, S_IRUGO | S_IWUSR,
  696. show_in_min, set_in_min, 1);
  697. static SENSOR_DEVICE_ATTR(in2_input, S_IRUGO, show_in, NULL, 2);
  698. static SENSOR_DEVICE_ATTR(in2_max, S_IRUGO | S_IWUSR,
  699. show_in_max, set_in_max, 2);
  700. static SENSOR_DEVICE_ATTR(in2_min, S_IRUGO | S_IWUSR,
  701. show_in_min, set_in_min, 2);
  702. static SENSOR_DEVICE_ATTR(in3_input, S_IRUGO, show_in, NULL, 3);
  703. static SENSOR_DEVICE_ATTR(in3_max, S_IRUGO | S_IWUSR,
  704. show_in_max, set_in_max, 3);
  705. static SENSOR_DEVICE_ATTR(in3_min, S_IRUGO | S_IWUSR,
  706. show_in_min, set_in_min, 3);
  707. static SENSOR_DEVICE_ATTR(in4_input, S_IRUGO, show_in, NULL, 4);
  708. static SENSOR_DEVICE_ATTR(in4_max, S_IRUGO | S_IWUSR,
  709. show_in_max, set_in_max, 4);
  710. static SENSOR_DEVICE_ATTR(in4_min, S_IRUGO | S_IWUSR,
  711. show_in_min, set_in_min, 4);
  712. static SENSOR_DEVICE_ATTR(in5_input, S_IRUGO, show_in, NULL, 5);
  713. static SENSOR_DEVICE_ATTR(in5_max, S_IRUGO | S_IWUSR,
  714. show_in_max, set_in_max, 5);
  715. static SENSOR_DEVICE_ATTR(in5_min, S_IRUGO | S_IWUSR,
  716. show_in_min, set_in_min, 5);
  717. static SENSOR_DEVICE_ATTR(in6_input, S_IRUGO, show_in, NULL, 6);
  718. static SENSOR_DEVICE_ATTR(in6_max, S_IRUGO | S_IWUSR,
  719. show_in_max, set_in_max, 6);
  720. static SENSOR_DEVICE_ATTR(in6_min, S_IRUGO | S_IWUSR,
  721. show_in_min, set_in_min, 6);
  722. static SENSOR_DEVICE_ATTR(in7_input, S_IRUGO, show_in, NULL, 7);
  723. static SENSOR_DEVICE_ATTR(in7_max, S_IRUGO | S_IWUSR,
  724. show_in_max, set_in_max, 7);
  725. static SENSOR_DEVICE_ATTR(in7_min, S_IRUGO | S_IWUSR,
  726. show_in_min, set_in_min, 7);
  727. static SENSOR_DEVICE_ATTR(in8_input, S_IRUGO, show_in, NULL, 8);
  728. static SENSOR_DEVICE_ATTR(in8_max, S_IRUGO | S_IWUSR,
  729. show_in_max, set_in_max, 8);
  730. static SENSOR_DEVICE_ATTR(in8_min, S_IRUGO | S_IWUSR,
  731. show_in_min, set_in_min, 8);
  732. static SENSOR_DEVICE_ATTR(in9_input, S_IRUGO, show_in0, NULL, 9);
  733. static SENSOR_DEVICE_ATTR(in9_max, S_IRUGO | S_IWUSR,
  734. show_in0_max, set_in0_max, 9);
  735. static SENSOR_DEVICE_ATTR(in9_min, S_IRUGO | S_IWUSR,
  736. show_in0_min, set_in0_min, 9);
  737. static SENSOR_DEVICE_ATTR(in10_input, S_IRUGO, show_in0, NULL, 10);
  738. static SENSOR_DEVICE_ATTR(in10_max, S_IRUGO | S_IWUSR,
  739. show_in0_max, set_in0_max, 10);
  740. static SENSOR_DEVICE_ATTR(in10_min, S_IRUGO | S_IWUSR,
  741. show_in0_min, set_in0_min, 10);
  742. static SENSOR_DEVICE_ATTR(fan1_input, S_IRUGO, show_fan, NULL, 0);
  743. static SENSOR_DEVICE_ATTR(fan1_min, S_IRUGO | S_IWUSR,
  744. show_fan_min, set_fan_min, 0);
  745. static SENSOR_DEVICE_ATTR(fan1_target, S_IRUGO | S_IWUSR,
  746. show_fan_target, set_fan_target, 0);
  747. static SENSOR_DEVICE_ATTR(fan2_input, S_IRUGO, show_fan, NULL, 1);
  748. static SENSOR_DEVICE_ATTR(fan2_min, S_IRUGO | S_IWUSR,
  749. show_fan_min, set_fan_min, 1);
  750. static SENSOR_DEVICE_ATTR(fan2_target, S_IRUGO | S_IWUSR,
  751. show_fan_target, set_fan_target, 1);
  752. static SENSOR_DEVICE_ATTR(fan3_input, S_IRUGO, show_fan, NULL, 2);
  753. static SENSOR_DEVICE_ATTR(fan3_min, S_IRUGO | S_IWUSR,
  754. show_fan_min, set_fan_min, 2);
  755. static SENSOR_DEVICE_ATTR(fan3_target, S_IRUGO | S_IWUSR,
  756. show_fan_target, set_fan_target, 2);
  757. static SENSOR_DEVICE_ATTR(temp1_input, S_IRUGO, show_temp, NULL, 0);
  758. static SENSOR_DEVICE_ATTR(temp1_max, S_IRUGO | S_IWUSR,
  759. show_temp_max, set_temp_max, 0);
  760. static SENSOR_DEVICE_ATTR(temp1_max_hyst, S_IRUGO | S_IWUSR,
  761. show_temp_hyst, set_temp_hyst, 0);
  762. static SENSOR_DEVICE_ATTR(temp1_type, S_IRUGO, show_temp_type, NULL, 0);
  763. static SENSOR_DEVICE_ATTR(temp2_input, S_IRUGO, show_temp, NULL, 1);
  764. static SENSOR_DEVICE_ATTR(temp2_max, S_IRUGO | S_IWUSR,
  765. show_temp_max, set_temp_max, 1);
  766. static SENSOR_DEVICE_ATTR(temp2_max_hyst, S_IRUGO | S_IWUSR,
  767. show_temp_hyst, set_temp_hyst, 1);
  768. static SENSOR_DEVICE_ATTR(temp2_type, S_IRUGO, show_temp_type, NULL, 1);
  769. static SENSOR_DEVICE_ATTR(temp3_input, S_IRUGO, show_temp, NULL, 2);
  770. static SENSOR_DEVICE_ATTR(temp3_max, S_IRUGO | S_IWUSR,
  771. show_temp_max, set_temp_max, 2);
  772. static SENSOR_DEVICE_ATTR(temp3_max_hyst, S_IRUGO | S_IWUSR,
  773. show_temp_hyst, set_temp_hyst, 2);
  774. static SENSOR_DEVICE_ATTR(temp3_type, S_IRUGO, show_temp_type, NULL, 2);
  775. /* pwm (value) files are created read-only, write permission is
  776. then added or removed dynamically as needed */
  777. static SENSOR_DEVICE_ATTR(pwm1, S_IRUGO, show_pwm, set_pwm, 0);
  778. static SENSOR_DEVICE_ATTR(pwm1_enable, S_IRUGO | S_IWUSR,
  779. show_pwm_enable, set_pwm_enable, 0);
  780. static SENSOR_DEVICE_ATTR(pwm1_freq, S_IRUGO | S_IWUSR,
  781. show_pwm_freq, set_pwm_freq, 0);
  782. static SENSOR_DEVICE_ATTR(pwm1_mode, S_IRUGO, show_pwm_mode, NULL, 0);
  783. static SENSOR_DEVICE_ATTR(pwm2, S_IRUGO, show_pwm, set_pwm, 1);
  784. static SENSOR_DEVICE_ATTR(pwm2_enable, S_IRUGO | S_IWUSR,
  785. show_pwm_enable, set_pwm_enable, 1);
  786. static SENSOR_DEVICE_ATTR(pwm2_freq, S_IRUGO | S_IWUSR,
  787. show_pwm_freq, set_pwm_freq, 1);
  788. static SENSOR_DEVICE_ATTR(pwm2_mode, S_IRUGO, show_pwm_mode, NULL, 1);
  789. static SENSOR_DEVICE_ATTR(pwm3, S_IRUGO, show_pwm, set_pwm, 2);
  790. static SENSOR_DEVICE_ATTR(pwm3_enable, S_IRUGO | S_IWUSR,
  791. show_pwm_enable, set_pwm_enable, 2);
  792. static SENSOR_DEVICE_ATTR(pwm3_freq, S_IRUGO | S_IWUSR,
  793. show_pwm_freq, set_pwm_freq, 2);
  794. static SENSOR_DEVICE_ATTR(pwm3_mode, S_IRUGO, show_pwm_mode, NULL, 2);
  795. static SENSOR_DEVICE_ATTR(in0_alarm, S_IRUGO, show_alarm, NULL, 0);
  796. static SENSOR_DEVICE_ATTR(in1_alarm, S_IRUGO, show_alarm, NULL, 1);
  797. static SENSOR_DEVICE_ATTR(in2_alarm, S_IRUGO, show_alarm, NULL, 2);
  798. static SENSOR_DEVICE_ATTR(in3_alarm, S_IRUGO, show_alarm, NULL, 3);
  799. static SENSOR_DEVICE_ATTR(in4_alarm, S_IRUGO, show_alarm, NULL, 4);
  800. static SENSOR_DEVICE_ATTR(in5_alarm, S_IRUGO, show_alarm, NULL, 5);
  801. static SENSOR_DEVICE_ATTR(in6_alarm, S_IRUGO, show_alarm, NULL, 6);
  802. static SENSOR_DEVICE_ATTR(in7_alarm, S_IRUGO, show_alarm, NULL, 7);
  803. static SENSOR_DEVICE_ATTR(in8_alarm, S_IRUGO, show_alarm, NULL, 8);
  804. static SENSOR_DEVICE_ATTR(in9_alarm, S_IRUGO, show_alarm, NULL, 9);
  805. static SENSOR_DEVICE_ATTR(in10_alarm, S_IRUGO, show_alarm, NULL, 10);
  806. static SENSOR_DEVICE_ATTR(temp1_alarm, S_IRUGO, show_alarm, NULL, 11);
  807. static SENSOR_DEVICE_ATTR(temp2_alarm, S_IRUGO, show_alarm, NULL, 12);
  808. static SENSOR_DEVICE_ATTR(temp3_alarm, S_IRUGO, show_alarm, NULL, 13);
  809. static SENSOR_DEVICE_ATTR(fan1_alarm, S_IRUGO, show_alarm, NULL, 16);
  810. static SENSOR_DEVICE_ATTR(fan2_alarm, S_IRUGO, show_alarm, NULL, 17);
  811. static SENSOR_DEVICE_ATTR(fan3_alarm, S_IRUGO, show_alarm, NULL, 18);
  812. static DEVICE_ATTR(alarms_in, S_IRUGO, show_alarms_in, NULL);
  813. static DEVICE_ATTR(alarms_fan, S_IRUGO, show_alarms_fan, NULL);
  814. static DEVICE_ATTR(alarms_temp, S_IRUGO, show_alarms_temp, NULL);
  815. static DEVICE_ATTR(name, S_IRUGO, show_name, NULL);
  816. static struct attribute *f71805f_attributes[] = {
  817. &sensor_dev_attr_in0_input.dev_attr.attr,
  818. &sensor_dev_attr_in0_max.dev_attr.attr,
  819. &sensor_dev_attr_in0_min.dev_attr.attr,
  820. &sensor_dev_attr_in1_input.dev_attr.attr,
  821. &sensor_dev_attr_in1_max.dev_attr.attr,
  822. &sensor_dev_attr_in1_min.dev_attr.attr,
  823. &sensor_dev_attr_in2_input.dev_attr.attr,
  824. &sensor_dev_attr_in2_max.dev_attr.attr,
  825. &sensor_dev_attr_in2_min.dev_attr.attr,
  826. &sensor_dev_attr_in3_input.dev_attr.attr,
  827. &sensor_dev_attr_in3_max.dev_attr.attr,
  828. &sensor_dev_attr_in3_min.dev_attr.attr,
  829. &sensor_dev_attr_in5_input.dev_attr.attr,
  830. &sensor_dev_attr_in5_max.dev_attr.attr,
  831. &sensor_dev_attr_in5_min.dev_attr.attr,
  832. &sensor_dev_attr_in6_input.dev_attr.attr,
  833. &sensor_dev_attr_in6_max.dev_attr.attr,
  834. &sensor_dev_attr_in6_min.dev_attr.attr,
  835. &sensor_dev_attr_in7_input.dev_attr.attr,
  836. &sensor_dev_attr_in7_max.dev_attr.attr,
  837. &sensor_dev_attr_in7_min.dev_attr.attr,
  838. &sensor_dev_attr_fan1_input.dev_attr.attr,
  839. &sensor_dev_attr_fan1_min.dev_attr.attr,
  840. &sensor_dev_attr_fan1_alarm.dev_attr.attr,
  841. &sensor_dev_attr_fan1_target.dev_attr.attr,
  842. &sensor_dev_attr_fan2_input.dev_attr.attr,
  843. &sensor_dev_attr_fan2_min.dev_attr.attr,
  844. &sensor_dev_attr_fan2_alarm.dev_attr.attr,
  845. &sensor_dev_attr_fan2_target.dev_attr.attr,
  846. &sensor_dev_attr_fan3_input.dev_attr.attr,
  847. &sensor_dev_attr_fan3_min.dev_attr.attr,
  848. &sensor_dev_attr_fan3_alarm.dev_attr.attr,
  849. &sensor_dev_attr_fan3_target.dev_attr.attr,
  850. &sensor_dev_attr_pwm1.dev_attr.attr,
  851. &sensor_dev_attr_pwm1_enable.dev_attr.attr,
  852. &sensor_dev_attr_pwm1_mode.dev_attr.attr,
  853. &sensor_dev_attr_pwm2.dev_attr.attr,
  854. &sensor_dev_attr_pwm2_enable.dev_attr.attr,
  855. &sensor_dev_attr_pwm2_mode.dev_attr.attr,
  856. &sensor_dev_attr_pwm3.dev_attr.attr,
  857. &sensor_dev_attr_pwm3_enable.dev_attr.attr,
  858. &sensor_dev_attr_pwm3_mode.dev_attr.attr,
  859. &sensor_dev_attr_temp1_input.dev_attr.attr,
  860. &sensor_dev_attr_temp1_max.dev_attr.attr,
  861. &sensor_dev_attr_temp1_max_hyst.dev_attr.attr,
  862. &sensor_dev_attr_temp1_type.dev_attr.attr,
  863. &sensor_dev_attr_temp2_input.dev_attr.attr,
  864. &sensor_dev_attr_temp2_max.dev_attr.attr,
  865. &sensor_dev_attr_temp2_max_hyst.dev_attr.attr,
  866. &sensor_dev_attr_temp2_type.dev_attr.attr,
  867. &sensor_dev_attr_temp3_input.dev_attr.attr,
  868. &sensor_dev_attr_temp3_max.dev_attr.attr,
  869. &sensor_dev_attr_temp3_max_hyst.dev_attr.attr,
  870. &sensor_dev_attr_temp3_type.dev_attr.attr,
  871. &sensor_dev_attr_in0_alarm.dev_attr.attr,
  872. &sensor_dev_attr_in1_alarm.dev_attr.attr,
  873. &sensor_dev_attr_in2_alarm.dev_attr.attr,
  874. &sensor_dev_attr_in3_alarm.dev_attr.attr,
  875. &sensor_dev_attr_in5_alarm.dev_attr.attr,
  876. &sensor_dev_attr_in6_alarm.dev_attr.attr,
  877. &sensor_dev_attr_in7_alarm.dev_attr.attr,
  878. &dev_attr_alarms_in.attr,
  879. &sensor_dev_attr_temp1_alarm.dev_attr.attr,
  880. &sensor_dev_attr_temp2_alarm.dev_attr.attr,
  881. &sensor_dev_attr_temp3_alarm.dev_attr.attr,
  882. &dev_attr_alarms_temp.attr,
  883. &dev_attr_alarms_fan.attr,
  884. &dev_attr_name.attr,
  885. NULL
  886. };
  887. static const struct attribute_group f71805f_group = {
  888. .attrs = f71805f_attributes,
  889. };
  890. static struct attribute *f71805f_attributes_optin[4][5] = {
  891. {
  892. &sensor_dev_attr_in4_input.dev_attr.attr,
  893. &sensor_dev_attr_in4_max.dev_attr.attr,
  894. &sensor_dev_attr_in4_min.dev_attr.attr,
  895. &sensor_dev_attr_in4_alarm.dev_attr.attr,
  896. NULL
  897. }, {
  898. &sensor_dev_attr_in8_input.dev_attr.attr,
  899. &sensor_dev_attr_in8_max.dev_attr.attr,
  900. &sensor_dev_attr_in8_min.dev_attr.attr,
  901. &sensor_dev_attr_in8_alarm.dev_attr.attr,
  902. NULL
  903. }, {
  904. &sensor_dev_attr_in9_input.dev_attr.attr,
  905. &sensor_dev_attr_in9_max.dev_attr.attr,
  906. &sensor_dev_attr_in9_min.dev_attr.attr,
  907. &sensor_dev_attr_in9_alarm.dev_attr.attr,
  908. NULL
  909. }, {
  910. &sensor_dev_attr_in10_input.dev_attr.attr,
  911. &sensor_dev_attr_in10_max.dev_attr.attr,
  912. &sensor_dev_attr_in10_min.dev_attr.attr,
  913. &sensor_dev_attr_in10_alarm.dev_attr.attr,
  914. NULL
  915. }
  916. };
  917. static const struct attribute_group f71805f_group_optin[4] = {
  918. { .attrs = f71805f_attributes_optin[0] },
  919. { .attrs = f71805f_attributes_optin[1] },
  920. { .attrs = f71805f_attributes_optin[2] },
  921. { .attrs = f71805f_attributes_optin[3] },
  922. };
  923. /* We don't include pwm_freq files in the arrays above, because they must be
  924. created conditionally (only if pwm_mode is 1 == PWM) */
  925. static struct attribute *f71805f_attributes_pwm_freq[] = {
  926. &sensor_dev_attr_pwm1_freq.dev_attr.attr,
  927. &sensor_dev_attr_pwm2_freq.dev_attr.attr,
  928. &sensor_dev_attr_pwm3_freq.dev_attr.attr,
  929. NULL
  930. };
  931. static const struct attribute_group f71805f_group_pwm_freq = {
  932. .attrs = f71805f_attributes_pwm_freq,
  933. };
  934. /* We also need an indexed access to pwmN files to toggle writability */
  935. static struct attribute *f71805f_attr_pwm[] = {
  936. &sensor_dev_attr_pwm1.dev_attr.attr,
  937. &sensor_dev_attr_pwm2.dev_attr.attr,
  938. &sensor_dev_attr_pwm3.dev_attr.attr,
  939. };
  940. /*
  941. * Device registration and initialization
  942. */
  943. static void __devinit f71805f_init_device(struct f71805f_data *data)
  944. {
  945. u8 reg;
  946. int i;
  947. reg = f71805f_read8(data, F71805F_REG_START);
  948. if ((reg & 0x41) != 0x01) {
  949. printk(KERN_DEBUG DRVNAME ": Starting monitoring "
  950. "operations\n");
  951. f71805f_write8(data, F71805F_REG_START, (reg | 0x01) & ~0x40);
  952. }
  953. /* Fan monitoring can be disabled. If it is, we won't be polling
  954. the register values, and won't create the related sysfs files. */
  955. for (i = 0; i < 3; i++) {
  956. data->fan_ctrl[i] = f71805f_read8(data,
  957. F71805F_REG_FAN_CTRL(i));
  958. /* Clear latch full bit, else "speed mode" fan speed control
  959. doesn't work */
  960. if (data->fan_ctrl[i] & FAN_CTRL_LATCH_FULL) {
  961. data->fan_ctrl[i] &= ~FAN_CTRL_LATCH_FULL;
  962. f71805f_write8(data, F71805F_REG_FAN_CTRL(i),
  963. data->fan_ctrl[i]);
  964. }
  965. }
  966. }
  967. static int __devinit f71805f_probe(struct platform_device *pdev)
  968. {
  969. struct f71805f_sio_data *sio_data = pdev->dev.platform_data;
  970. struct f71805f_data *data;
  971. struct resource *res;
  972. int i, err;
  973. static const char *names[] = {
  974. "f71805f",
  975. "f71872f",
  976. };
  977. if (!(data = kzalloc(sizeof(struct f71805f_data), GFP_KERNEL))) {
  978. err = -ENOMEM;
  979. printk(KERN_ERR DRVNAME ": Out of memory\n");
  980. goto exit;
  981. }
  982. res = platform_get_resource(pdev, IORESOURCE_IO, 0);
  983. data->addr = res->start;
  984. data->name = names[sio_data->kind];
  985. mutex_init(&data->update_lock);
  986. platform_set_drvdata(pdev, data);
  987. /* Some voltage inputs depend on chip model and configuration */
  988. switch (sio_data->kind) {
  989. case f71805f:
  990. data->has_in = 0x1ff;
  991. break;
  992. case f71872f:
  993. data->has_in = 0x6ef;
  994. if (sio_data->fnsel1 & 0x01)
  995. data->has_in |= (1 << 4); /* in4 */
  996. if (sio_data->fnsel1 & 0x02)
  997. data->has_in |= (1 << 8); /* in8 */
  998. break;
  999. }
  1000. /* Initialize the F71805F chip */
  1001. f71805f_init_device(data);
  1002. /* Register sysfs interface files */
  1003. if ((err = sysfs_create_group(&pdev->dev.kobj, &f71805f_group)))
  1004. goto exit_free;
  1005. if (data->has_in & (1 << 4)) { /* in4 */
  1006. if ((err = sysfs_create_group(&pdev->dev.kobj,
  1007. &f71805f_group_optin[0])))
  1008. goto exit_remove_files;
  1009. }
  1010. if (data->has_in & (1 << 8)) { /* in8 */
  1011. if ((err = sysfs_create_group(&pdev->dev.kobj,
  1012. &f71805f_group_optin[1])))
  1013. goto exit_remove_files;
  1014. }
  1015. if (data->has_in & (1 << 9)) { /* in9 (F71872F/FG only) */
  1016. if ((err = sysfs_create_group(&pdev->dev.kobj,
  1017. &f71805f_group_optin[2])))
  1018. goto exit_remove_files;
  1019. }
  1020. if (data->has_in & (1 << 10)) { /* in9 (F71872F/FG only) */
  1021. if ((err = sysfs_create_group(&pdev->dev.kobj,
  1022. &f71805f_group_optin[3])))
  1023. goto exit_remove_files;
  1024. }
  1025. for (i = 0; i < 3; i++) {
  1026. /* If control mode is PWM, create pwm_freq file */
  1027. if (!(data->fan_ctrl[i] & FAN_CTRL_DC_MODE)) {
  1028. if ((err = sysfs_create_file(&pdev->dev.kobj,
  1029. f71805f_attributes_pwm_freq[i])))
  1030. goto exit_remove_files;
  1031. }
  1032. /* If PWM is in manual mode, add write permission */
  1033. if (data->fan_ctrl[i] & FAN_CTRL_MODE_MANUAL) {
  1034. if ((err = sysfs_chmod_file(&pdev->dev.kobj,
  1035. f71805f_attr_pwm[i],
  1036. S_IRUGO | S_IWUSR))) {
  1037. dev_err(&pdev->dev, "chmod +w pwm%d failed\n",
  1038. i + 1);
  1039. goto exit_remove_files;
  1040. }
  1041. }
  1042. }
  1043. data->class_dev = hwmon_device_register(&pdev->dev);
  1044. if (IS_ERR(data->class_dev)) {
  1045. err = PTR_ERR(data->class_dev);
  1046. dev_err(&pdev->dev, "Class registration failed (%d)\n", err);
  1047. goto exit_remove_files;
  1048. }
  1049. return 0;
  1050. exit_remove_files:
  1051. sysfs_remove_group(&pdev->dev.kobj, &f71805f_group);
  1052. for (i = 0; i < 4; i++)
  1053. sysfs_remove_group(&pdev->dev.kobj, &f71805f_group_optin[i]);
  1054. sysfs_remove_group(&pdev->dev.kobj, &f71805f_group_pwm_freq);
  1055. exit_free:
  1056. platform_set_drvdata(pdev, NULL);
  1057. kfree(data);
  1058. exit:
  1059. return err;
  1060. }
  1061. static int __devexit f71805f_remove(struct platform_device *pdev)
  1062. {
  1063. struct f71805f_data *data = platform_get_drvdata(pdev);
  1064. int i;
  1065. platform_set_drvdata(pdev, NULL);
  1066. hwmon_device_unregister(data->class_dev);
  1067. sysfs_remove_group(&pdev->dev.kobj, &f71805f_group);
  1068. for (i = 0; i < 4; i++)
  1069. sysfs_remove_group(&pdev->dev.kobj, &f71805f_group_optin[i]);
  1070. sysfs_remove_group(&pdev->dev.kobj, &f71805f_group_pwm_freq);
  1071. kfree(data);
  1072. return 0;
  1073. }
  1074. static struct platform_driver f71805f_driver = {
  1075. .driver = {
  1076. .owner = THIS_MODULE,
  1077. .name = DRVNAME,
  1078. },
  1079. .probe = f71805f_probe,
  1080. .remove = __devexit_p(f71805f_remove),
  1081. };
  1082. static int __init f71805f_device_add(unsigned short address,
  1083. const struct f71805f_sio_data *sio_data)
  1084. {
  1085. struct resource res = {
  1086. .start = address,
  1087. .end = address + REGION_LENGTH - 1,
  1088. .flags = IORESOURCE_IO,
  1089. };
  1090. int err;
  1091. pdev = platform_device_alloc(DRVNAME, address);
  1092. if (!pdev) {
  1093. err = -ENOMEM;
  1094. printk(KERN_ERR DRVNAME ": Device allocation failed\n");
  1095. goto exit;
  1096. }
  1097. res.name = pdev->name;
  1098. err = platform_device_add_resources(pdev, &res, 1);
  1099. if (err) {
  1100. printk(KERN_ERR DRVNAME ": Device resource addition failed "
  1101. "(%d)\n", err);
  1102. goto exit_device_put;
  1103. }
  1104. pdev->dev.platform_data = kmalloc(sizeof(struct f71805f_sio_data),
  1105. GFP_KERNEL);
  1106. if (!pdev->dev.platform_data) {
  1107. err = -ENOMEM;
  1108. printk(KERN_ERR DRVNAME ": Platform data allocation failed\n");
  1109. goto exit_device_put;
  1110. }
  1111. memcpy(pdev->dev.platform_data, sio_data,
  1112. sizeof(struct f71805f_sio_data));
  1113. err = platform_device_add(pdev);
  1114. if (err) {
  1115. printk(KERN_ERR DRVNAME ": Device addition failed (%d)\n",
  1116. err);
  1117. goto exit_kfree_data;
  1118. }
  1119. return 0;
  1120. exit_kfree_data:
  1121. kfree(pdev->dev.platform_data);
  1122. pdev->dev.platform_data = NULL;
  1123. exit_device_put:
  1124. platform_device_put(pdev);
  1125. exit:
  1126. return err;
  1127. }
  1128. static int __init f71805f_find(int sioaddr, unsigned short *address,
  1129. struct f71805f_sio_data *sio_data)
  1130. {
  1131. int err = -ENODEV;
  1132. u16 devid;
  1133. static const char *names[] = {
  1134. "F71805F/FG",
  1135. "F71872F/FG",
  1136. };
  1137. superio_enter(sioaddr);
  1138. devid = superio_inw(sioaddr, SIO_REG_MANID);
  1139. if (devid != SIO_FINTEK_ID)
  1140. goto exit;
  1141. devid = superio_inw(sioaddr, SIO_REG_DEVID);
  1142. switch (devid) {
  1143. case SIO_F71805F_ID:
  1144. sio_data->kind = f71805f;
  1145. break;
  1146. case SIO_F71872F_ID:
  1147. sio_data->kind = f71872f;
  1148. sio_data->fnsel1 = superio_inb(sioaddr, SIO_REG_FNSEL1);
  1149. break;
  1150. default:
  1151. printk(KERN_INFO DRVNAME ": Unsupported Fintek device, "
  1152. "skipping\n");
  1153. goto exit;
  1154. }
  1155. superio_select(sioaddr, F71805F_LD_HWM);
  1156. if (!(superio_inb(sioaddr, SIO_REG_ENABLE) & 0x01)) {
  1157. printk(KERN_WARNING DRVNAME ": Device not activated, "
  1158. "skipping\n");
  1159. goto exit;
  1160. }
  1161. *address = superio_inw(sioaddr, SIO_REG_ADDR);
  1162. if (*address == 0) {
  1163. printk(KERN_WARNING DRVNAME ": Base address not set, "
  1164. "skipping\n");
  1165. goto exit;
  1166. }
  1167. *address &= ~(REGION_LENGTH - 1); /* Ignore 3 LSB */
  1168. err = 0;
  1169. printk(KERN_INFO DRVNAME ": Found %s chip at %#x, revision %u\n",
  1170. names[sio_data->kind], *address,
  1171. superio_inb(sioaddr, SIO_REG_DEVREV));
  1172. exit:
  1173. superio_exit(sioaddr);
  1174. return err;
  1175. }
  1176. static int __init f71805f_init(void)
  1177. {
  1178. int err;
  1179. unsigned short address;
  1180. struct f71805f_sio_data sio_data;
  1181. if (f71805f_find(0x2e, &address, &sio_data)
  1182. && f71805f_find(0x4e, &address, &sio_data))
  1183. return -ENODEV;
  1184. err = platform_driver_register(&f71805f_driver);
  1185. if (err)
  1186. goto exit;
  1187. /* Sets global pdev as a side effect */
  1188. err = f71805f_device_add(address, &sio_data);
  1189. if (err)
  1190. goto exit_driver;
  1191. return 0;
  1192. exit_driver:
  1193. platform_driver_unregister(&f71805f_driver);
  1194. exit:
  1195. return err;
  1196. }
  1197. static void __exit f71805f_exit(void)
  1198. {
  1199. kfree(pdev->dev.platform_data);
  1200. pdev->dev.platform_data = NULL;
  1201. platform_device_unregister(pdev);
  1202. platform_driver_unregister(&f71805f_driver);
  1203. }
  1204. MODULE_AUTHOR("Jean Delvare <khali@linux-fr>");
  1205. MODULE_LICENSE("GPL");
  1206. MODULE_DESCRIPTION("F71805F/F71872F hardware monitoring driver");
  1207. module_init(f71805f_init);
  1208. module_exit(f71805f_exit);