pch_phub.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763
  1. /*
  2. * Copyright (C) 2010 OKI SEMICONDUCTOR CO., LTD.
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License as published by
  6. * the Free Software Foundation; version 2 of the License.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License
  14. * along with this program; if not, write to the Free Software
  15. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
  16. */
  17. #include <linux/module.h>
  18. #include <linux/kernel.h>
  19. #include <linux/types.h>
  20. #include <linux/fs.h>
  21. #include <linux/uaccess.h>
  22. #include <linux/string.h>
  23. #include <linux/pci.h>
  24. #include <linux/io.h>
  25. #include <linux/delay.h>
  26. #include <linux/mutex.h>
  27. #include <linux/if_ether.h>
  28. #include <linux/ctype.h>
  29. #include <linux/dmi.h>
  30. #define PHUB_STATUS 0x00 /* Status Register offset */
  31. #define PHUB_CONTROL 0x04 /* Control Register offset */
  32. #define PHUB_TIMEOUT 0x05 /* Time out value for Status Register */
  33. #define PCH_PHUB_ROM_WRITE_ENABLE 0x01 /* Enabling for writing ROM */
  34. #define PCH_PHUB_ROM_WRITE_DISABLE 0x00 /* Disabling for writing ROM */
  35. #define PCH_PHUB_MAC_START_ADDR 0x20C /* MAC data area start address offset */
  36. #define PCH_PHUB_ROM_START_ADDR_EG20T 0x14 /* ROM data area start address offset
  37. (Intel EG20T PCH)*/
  38. #define PCH_PHUB_ROM_START_ADDR_ML7213 0x400 /* ROM data area start address
  39. offset(OKI SEMICONDUCTOR ML7213)
  40. */
  41. /* MAX number of INT_REDUCE_CONTROL registers */
  42. #define MAX_NUM_INT_REDUCE_CONTROL_REG 128
  43. #define PCI_DEVICE_ID_PCH1_PHUB 0x8801
  44. #define PCH_MINOR_NOS 1
  45. #define CLKCFG_CAN_50MHZ 0x12000000
  46. #define CLKCFG_CANCLK_MASK 0xFF000000
  47. #define CLKCFG_UART_MASK 0xFFFFFF
  48. /* CM-iTC */
  49. #define CLKCFG_UART_48MHZ (1 << 16)
  50. #define CLKCFG_BAUDDIV (2 << 20)
  51. #define CLKCFG_PLL2VCO (8 << 9)
  52. #define CLKCFG_UARTCLKSEL (1 << 18)
  53. /* Macros for ML7213 */
  54. #define PCI_VENDOR_ID_ROHM 0x10db
  55. #define PCI_DEVICE_ID_ROHM_ML7213_PHUB 0x801A
  56. /* Macros for ML7213 */
  57. #define PCI_VENDOR_ID_ROHM 0x10db
  58. #define PCI_DEVICE_ID_ROHM_ML7213_PHUB 0x801A
  59. /* SROM ACCESS Macro */
  60. #define PCH_WORD_ADDR_MASK (~((1 << 2) - 1))
  61. /* Registers address offset */
  62. #define PCH_PHUB_ID_REG 0x0000
  63. #define PCH_PHUB_QUEUE_PRI_VAL_REG 0x0004
  64. #define PCH_PHUB_RC_QUEUE_MAXSIZE_REG 0x0008
  65. #define PCH_PHUB_BRI_QUEUE_MAXSIZE_REG 0x000C
  66. #define PCH_PHUB_COMP_RESP_TIMEOUT_REG 0x0010
  67. #define PCH_PHUB_BUS_SLAVE_CONTROL_REG 0x0014
  68. #define PCH_PHUB_DEADLOCK_AVOID_TYPE_REG 0x0018
  69. #define PCH_PHUB_INTPIN_REG_WPERMIT_REG0 0x0020
  70. #define PCH_PHUB_INTPIN_REG_WPERMIT_REG1 0x0024
  71. #define PCH_PHUB_INTPIN_REG_WPERMIT_REG2 0x0028
  72. #define PCH_PHUB_INTPIN_REG_WPERMIT_REG3 0x002C
  73. #define PCH_PHUB_INT_REDUCE_CONTROL_REG_BASE 0x0040
  74. #define CLKCFG_REG_OFFSET 0x500
  75. #define PCH_PHUB_OROM_SIZE 15360
  76. /**
  77. * struct pch_phub_reg - PHUB register structure
  78. * @phub_id_reg: PHUB_ID register val
  79. * @q_pri_val_reg: QUEUE_PRI_VAL register val
  80. * @rc_q_maxsize_reg: RC_QUEUE_MAXSIZE register val
  81. * @bri_q_maxsize_reg: BRI_QUEUE_MAXSIZE register val
  82. * @comp_resp_timeout_reg: COMP_RESP_TIMEOUT register val
  83. * @bus_slave_control_reg: BUS_SLAVE_CONTROL_REG register val
  84. * @deadlock_avoid_type_reg: DEADLOCK_AVOID_TYPE register val
  85. * @intpin_reg_wpermit_reg0: INTPIN_REG_WPERMIT register 0 val
  86. * @intpin_reg_wpermit_reg1: INTPIN_REG_WPERMIT register 1 val
  87. * @intpin_reg_wpermit_reg2: INTPIN_REG_WPERMIT register 2 val
  88. * @intpin_reg_wpermit_reg3: INTPIN_REG_WPERMIT register 3 val
  89. * @int_reduce_control_reg: INT_REDUCE_CONTROL registers val
  90. * @clkcfg_reg: CLK CFG register val
  91. * @pch_phub_base_address: Register base address
  92. * @pch_phub_extrom_base_address: external rom base address
  93. */
  94. struct pch_phub_reg {
  95. u32 phub_id_reg;
  96. u32 q_pri_val_reg;
  97. u32 rc_q_maxsize_reg;
  98. u32 bri_q_maxsize_reg;
  99. u32 comp_resp_timeout_reg;
  100. u32 bus_slave_control_reg;
  101. u32 deadlock_avoid_type_reg;
  102. u32 intpin_reg_wpermit_reg0;
  103. u32 intpin_reg_wpermit_reg1;
  104. u32 intpin_reg_wpermit_reg2;
  105. u32 intpin_reg_wpermit_reg3;
  106. u32 int_reduce_control_reg[MAX_NUM_INT_REDUCE_CONTROL_REG];
  107. u32 clkcfg_reg;
  108. void __iomem *pch_phub_base_address;
  109. void __iomem *pch_phub_extrom_base_address;
  110. };
  111. /* SROM SPEC for MAC address assignment offset */
  112. static const int pch_phub_mac_offset[ETH_ALEN] = {0x3, 0x2, 0x1, 0x0, 0xb, 0xa};
  113. static DEFINE_MUTEX(pch_phub_mutex);
  114. /**
  115. * pch_phub_read_modify_write_reg() - Reading modifying and writing register
  116. * @reg_addr_offset: Register offset address value.
  117. * @data: Writing value.
  118. * @mask: Mask value.
  119. */
  120. static void pch_phub_read_modify_write_reg(struct pch_phub_reg *chip,
  121. unsigned int reg_addr_offset,
  122. unsigned int data, unsigned int mask)
  123. {
  124. void __iomem *reg_addr = chip->pch_phub_base_address + reg_addr_offset;
  125. iowrite32(((ioread32(reg_addr) & ~mask)) | data, reg_addr);
  126. }
  127. /* pch_phub_save_reg_conf - saves register configuration */
  128. static void pch_phub_save_reg_conf(struct pci_dev *pdev)
  129. {
  130. unsigned int i;
  131. struct pch_phub_reg *chip = pci_get_drvdata(pdev);
  132. void __iomem *p = chip->pch_phub_base_address;
  133. chip->phub_id_reg = ioread32(p + PCH_PHUB_ID_REG);
  134. chip->q_pri_val_reg = ioread32(p + PCH_PHUB_QUEUE_PRI_VAL_REG);
  135. chip->rc_q_maxsize_reg = ioread32(p + PCH_PHUB_RC_QUEUE_MAXSIZE_REG);
  136. chip->bri_q_maxsize_reg = ioread32(p + PCH_PHUB_BRI_QUEUE_MAXSIZE_REG);
  137. chip->comp_resp_timeout_reg =
  138. ioread32(p + PCH_PHUB_COMP_RESP_TIMEOUT_REG);
  139. chip->bus_slave_control_reg =
  140. ioread32(p + PCH_PHUB_BUS_SLAVE_CONTROL_REG);
  141. chip->deadlock_avoid_type_reg =
  142. ioread32(p + PCH_PHUB_DEADLOCK_AVOID_TYPE_REG);
  143. chip->intpin_reg_wpermit_reg0 =
  144. ioread32(p + PCH_PHUB_INTPIN_REG_WPERMIT_REG0);
  145. chip->intpin_reg_wpermit_reg1 =
  146. ioread32(p + PCH_PHUB_INTPIN_REG_WPERMIT_REG1);
  147. chip->intpin_reg_wpermit_reg2 =
  148. ioread32(p + PCH_PHUB_INTPIN_REG_WPERMIT_REG2);
  149. chip->intpin_reg_wpermit_reg3 =
  150. ioread32(p + PCH_PHUB_INTPIN_REG_WPERMIT_REG3);
  151. dev_dbg(&pdev->dev, "%s : "
  152. "chip->phub_id_reg=%x, "
  153. "chip->q_pri_val_reg=%x, "
  154. "chip->rc_q_maxsize_reg=%x, "
  155. "chip->bri_q_maxsize_reg=%x, "
  156. "chip->comp_resp_timeout_reg=%x, "
  157. "chip->bus_slave_control_reg=%x, "
  158. "chip->deadlock_avoid_type_reg=%x, "
  159. "chip->intpin_reg_wpermit_reg0=%x, "
  160. "chip->intpin_reg_wpermit_reg1=%x, "
  161. "chip->intpin_reg_wpermit_reg2=%x, "
  162. "chip->intpin_reg_wpermit_reg3=%x\n", __func__,
  163. chip->phub_id_reg,
  164. chip->q_pri_val_reg,
  165. chip->rc_q_maxsize_reg,
  166. chip->bri_q_maxsize_reg,
  167. chip->comp_resp_timeout_reg,
  168. chip->bus_slave_control_reg,
  169. chip->deadlock_avoid_type_reg,
  170. chip->intpin_reg_wpermit_reg0,
  171. chip->intpin_reg_wpermit_reg1,
  172. chip->intpin_reg_wpermit_reg2,
  173. chip->intpin_reg_wpermit_reg3);
  174. for (i = 0; i < MAX_NUM_INT_REDUCE_CONTROL_REG; i++) {
  175. chip->int_reduce_control_reg[i] =
  176. ioread32(p + PCH_PHUB_INT_REDUCE_CONTROL_REG_BASE + 4 * i);
  177. dev_dbg(&pdev->dev, "%s : "
  178. "chip->int_reduce_control_reg[%d]=%x\n",
  179. __func__, i, chip->int_reduce_control_reg[i]);
  180. }
  181. chip->clkcfg_reg = ioread32(p + CLKCFG_REG_OFFSET);
  182. }
  183. /* pch_phub_restore_reg_conf - restore register configuration */
  184. static void pch_phub_restore_reg_conf(struct pci_dev *pdev)
  185. {
  186. unsigned int i;
  187. struct pch_phub_reg *chip = pci_get_drvdata(pdev);
  188. void __iomem *p;
  189. p = chip->pch_phub_base_address;
  190. iowrite32(chip->phub_id_reg, p + PCH_PHUB_ID_REG);
  191. iowrite32(chip->q_pri_val_reg, p + PCH_PHUB_QUEUE_PRI_VAL_REG);
  192. iowrite32(chip->rc_q_maxsize_reg, p + PCH_PHUB_RC_QUEUE_MAXSIZE_REG);
  193. iowrite32(chip->bri_q_maxsize_reg, p + PCH_PHUB_BRI_QUEUE_MAXSIZE_REG);
  194. iowrite32(chip->comp_resp_timeout_reg,
  195. p + PCH_PHUB_COMP_RESP_TIMEOUT_REG);
  196. iowrite32(chip->bus_slave_control_reg,
  197. p + PCH_PHUB_BUS_SLAVE_CONTROL_REG);
  198. iowrite32(chip->deadlock_avoid_type_reg,
  199. p + PCH_PHUB_DEADLOCK_AVOID_TYPE_REG);
  200. iowrite32(chip->intpin_reg_wpermit_reg0,
  201. p + PCH_PHUB_INTPIN_REG_WPERMIT_REG0);
  202. iowrite32(chip->intpin_reg_wpermit_reg1,
  203. p + PCH_PHUB_INTPIN_REG_WPERMIT_REG1);
  204. iowrite32(chip->intpin_reg_wpermit_reg2,
  205. p + PCH_PHUB_INTPIN_REG_WPERMIT_REG2);
  206. iowrite32(chip->intpin_reg_wpermit_reg3,
  207. p + PCH_PHUB_INTPIN_REG_WPERMIT_REG3);
  208. dev_dbg(&pdev->dev, "%s : "
  209. "chip->phub_id_reg=%x, "
  210. "chip->q_pri_val_reg=%x, "
  211. "chip->rc_q_maxsize_reg=%x, "
  212. "chip->bri_q_maxsize_reg=%x, "
  213. "chip->comp_resp_timeout_reg=%x, "
  214. "chip->bus_slave_control_reg=%x, "
  215. "chip->deadlock_avoid_type_reg=%x, "
  216. "chip->intpin_reg_wpermit_reg0=%x, "
  217. "chip->intpin_reg_wpermit_reg1=%x, "
  218. "chip->intpin_reg_wpermit_reg2=%x, "
  219. "chip->intpin_reg_wpermit_reg3=%x\n", __func__,
  220. chip->phub_id_reg,
  221. chip->q_pri_val_reg,
  222. chip->rc_q_maxsize_reg,
  223. chip->bri_q_maxsize_reg,
  224. chip->comp_resp_timeout_reg,
  225. chip->bus_slave_control_reg,
  226. chip->deadlock_avoid_type_reg,
  227. chip->intpin_reg_wpermit_reg0,
  228. chip->intpin_reg_wpermit_reg1,
  229. chip->intpin_reg_wpermit_reg2,
  230. chip->intpin_reg_wpermit_reg3);
  231. for (i = 0; i < MAX_NUM_INT_REDUCE_CONTROL_REG; i++) {
  232. iowrite32(chip->int_reduce_control_reg[i],
  233. p + PCH_PHUB_INT_REDUCE_CONTROL_REG_BASE + 4 * i);
  234. dev_dbg(&pdev->dev, "%s : "
  235. "chip->int_reduce_control_reg[%d]=%x\n",
  236. __func__, i, chip->int_reduce_control_reg[i]);
  237. }
  238. iowrite32(chip->clkcfg_reg, p + CLKCFG_REG_OFFSET);
  239. }
  240. /**
  241. * pch_phub_read_serial_rom() - Reading Serial ROM
  242. * @offset_address: Serial ROM offset address to read.
  243. * @data: Read buffer for specified Serial ROM value.
  244. */
  245. static void pch_phub_read_serial_rom(struct pch_phub_reg *chip,
  246. unsigned int offset_address, u8 *data)
  247. {
  248. void __iomem *mem_addr = chip->pch_phub_extrom_base_address +
  249. offset_address;
  250. *data = ioread8(mem_addr);
  251. }
  252. /**
  253. * pch_phub_write_serial_rom() - Writing Serial ROM
  254. * @offset_address: Serial ROM offset address.
  255. * @data: Serial ROM value to write.
  256. */
  257. static int pch_phub_write_serial_rom(struct pch_phub_reg *chip,
  258. unsigned int offset_address, u8 data)
  259. {
  260. void __iomem *mem_addr = chip->pch_phub_extrom_base_address +
  261. (offset_address & PCH_WORD_ADDR_MASK);
  262. int i;
  263. unsigned int word_data;
  264. unsigned int pos;
  265. unsigned int mask;
  266. pos = (offset_address % 4) * 8;
  267. mask = ~(0xFF << pos);
  268. iowrite32(PCH_PHUB_ROM_WRITE_ENABLE,
  269. chip->pch_phub_extrom_base_address + PHUB_CONTROL);
  270. word_data = ioread32(mem_addr);
  271. iowrite32((word_data & mask) | (u32)data << pos, mem_addr);
  272. i = 0;
  273. while (ioread8(chip->pch_phub_extrom_base_address +
  274. PHUB_STATUS) != 0x00) {
  275. msleep(1);
  276. if (i == PHUB_TIMEOUT)
  277. return -ETIMEDOUT;
  278. i++;
  279. }
  280. iowrite32(PCH_PHUB_ROM_WRITE_DISABLE,
  281. chip->pch_phub_extrom_base_address + PHUB_CONTROL);
  282. return 0;
  283. }
  284. /**
  285. * pch_phub_read_serial_rom_val() - Read Serial ROM value
  286. * @offset_address: Serial ROM address offset value.
  287. * @data: Serial ROM value to read.
  288. */
  289. static void pch_phub_read_serial_rom_val(struct pch_phub_reg *chip,
  290. unsigned int offset_address, u8 *data)
  291. {
  292. unsigned int mem_addr;
  293. mem_addr = PCH_PHUB_ROM_START_ADDR_EG20T +
  294. pch_phub_mac_offset[offset_address];
  295. pch_phub_read_serial_rom(chip, mem_addr, data);
  296. }
  297. /**
  298. * pch_phub_write_serial_rom_val() - writing Serial ROM value
  299. * @offset_address: Serial ROM address offset value.
  300. * @data: Serial ROM value.
  301. */
  302. static int pch_phub_write_serial_rom_val(struct pch_phub_reg *chip,
  303. unsigned int offset_address, u8 data)
  304. {
  305. int retval;
  306. unsigned int mem_addr;
  307. mem_addr = PCH_PHUB_ROM_START_ADDR_EG20T +
  308. pch_phub_mac_offset[offset_address];
  309. retval = pch_phub_write_serial_rom(chip, mem_addr, data);
  310. return retval;
  311. }
  312. /* pch_phub_gbe_serial_rom_conf - makes Serial ROM header format configuration
  313. * for Gigabit Ethernet MAC address
  314. */
  315. static int pch_phub_gbe_serial_rom_conf(struct pch_phub_reg *chip)
  316. {
  317. int retval;
  318. retval = pch_phub_write_serial_rom(chip, 0x0b, 0xbc);
  319. retval |= pch_phub_write_serial_rom(chip, 0x0a, 0x10);
  320. retval |= pch_phub_write_serial_rom(chip, 0x09, 0x01);
  321. retval |= pch_phub_write_serial_rom(chip, 0x08, 0x02);
  322. retval |= pch_phub_write_serial_rom(chip, 0x0f, 0x00);
  323. retval |= pch_phub_write_serial_rom(chip, 0x0e, 0x00);
  324. retval |= pch_phub_write_serial_rom(chip, 0x0d, 0x00);
  325. retval |= pch_phub_write_serial_rom(chip, 0x0c, 0x80);
  326. retval |= pch_phub_write_serial_rom(chip, 0x13, 0xbc);
  327. retval |= pch_phub_write_serial_rom(chip, 0x12, 0x10);
  328. retval |= pch_phub_write_serial_rom(chip, 0x11, 0x01);
  329. retval |= pch_phub_write_serial_rom(chip, 0x10, 0x18);
  330. retval |= pch_phub_write_serial_rom(chip, 0x1b, 0xbc);
  331. retval |= pch_phub_write_serial_rom(chip, 0x1a, 0x10);
  332. retval |= pch_phub_write_serial_rom(chip, 0x19, 0x01);
  333. retval |= pch_phub_write_serial_rom(chip, 0x18, 0x19);
  334. retval |= pch_phub_write_serial_rom(chip, 0x23, 0xbc);
  335. retval |= pch_phub_write_serial_rom(chip, 0x22, 0x10);
  336. retval |= pch_phub_write_serial_rom(chip, 0x21, 0x01);
  337. retval |= pch_phub_write_serial_rom(chip, 0x20, 0x3a);
  338. retval |= pch_phub_write_serial_rom(chip, 0x27, 0x01);
  339. retval |= pch_phub_write_serial_rom(chip, 0x26, 0x00);
  340. retval |= pch_phub_write_serial_rom(chip, 0x25, 0x00);
  341. retval |= pch_phub_write_serial_rom(chip, 0x24, 0x00);
  342. return retval;
  343. }
  344. /**
  345. * pch_phub_read_gbe_mac_addr() - Read Gigabit Ethernet MAC address
  346. * @offset_address: Gigabit Ethernet MAC address offset value.
  347. * @data: Buffer of the Gigabit Ethernet MAC address value.
  348. */
  349. static void pch_phub_read_gbe_mac_addr(struct pch_phub_reg *chip, u8 *data)
  350. {
  351. int i;
  352. for (i = 0; i < ETH_ALEN; i++)
  353. pch_phub_read_serial_rom_val(chip, i, &data[i]);
  354. }
  355. /**
  356. * pch_phub_write_gbe_mac_addr() - Write MAC address
  357. * @offset_address: Gigabit Ethernet MAC address offset value.
  358. * @data: Gigabit Ethernet MAC address value.
  359. */
  360. static int pch_phub_write_gbe_mac_addr(struct pch_phub_reg *chip, u8 *data)
  361. {
  362. int retval;
  363. int i;
  364. retval = pch_phub_gbe_serial_rom_conf(chip);
  365. if (retval)
  366. return retval;
  367. for (i = 0; i < ETH_ALEN; i++) {
  368. retval = pch_phub_write_serial_rom_val(chip, i, data[i]);
  369. if (retval)
  370. return retval;
  371. }
  372. return retval;
  373. }
  374. static ssize_t pch_phub_bin_read(struct file *filp, struct kobject *kobj,
  375. struct bin_attribute *attr, char *buf,
  376. loff_t off, size_t count)
  377. {
  378. unsigned int rom_signature;
  379. unsigned char rom_length;
  380. unsigned int tmp;
  381. unsigned int addr_offset;
  382. unsigned int orom_size;
  383. int ret;
  384. int err;
  385. struct pch_phub_reg *chip =
  386. dev_get_drvdata(container_of(kobj, struct device, kobj));
  387. ret = mutex_lock_interruptible(&pch_phub_mutex);
  388. if (ret) {
  389. err = -ERESTARTSYS;
  390. goto return_err_nomutex;
  391. }
  392. /* Get Rom signature */
  393. pch_phub_read_serial_rom(chip, 0x80, (unsigned char *)&rom_signature);
  394. rom_signature &= 0xff;
  395. pch_phub_read_serial_rom(chip, 0x81, (unsigned char *)&tmp);
  396. rom_signature |= (tmp & 0xff) << 8;
  397. if (rom_signature == 0xAA55) {
  398. pch_phub_read_serial_rom(chip, 0x82, &rom_length);
  399. orom_size = rom_length * 512;
  400. if (orom_size < off) {
  401. addr_offset = 0;
  402. goto return_ok;
  403. }
  404. if (orom_size < count) {
  405. addr_offset = 0;
  406. goto return_ok;
  407. }
  408. for (addr_offset = 0; addr_offset < count; addr_offset++) {
  409. pch_phub_read_serial_rom(chip, 0x80 + addr_offset + off,
  410. &buf[addr_offset]);
  411. }
  412. } else {
  413. err = -ENODATA;
  414. goto return_err;
  415. }
  416. return_ok:
  417. mutex_unlock(&pch_phub_mutex);
  418. return addr_offset;
  419. return_err:
  420. mutex_unlock(&pch_phub_mutex);
  421. return_err_nomutex:
  422. return err;
  423. }
  424. static ssize_t pch_phub_bin_write(struct file *filp, struct kobject *kobj,
  425. struct bin_attribute *attr,
  426. char *buf, loff_t off, size_t count)
  427. {
  428. int err;
  429. unsigned int addr_offset;
  430. int ret;
  431. struct pch_phub_reg *chip =
  432. dev_get_drvdata(container_of(kobj, struct device, kobj));
  433. ret = mutex_lock_interruptible(&pch_phub_mutex);
  434. if (ret)
  435. return -ERESTARTSYS;
  436. if (off > PCH_PHUB_OROM_SIZE) {
  437. addr_offset = 0;
  438. goto return_ok;
  439. }
  440. if (count > PCH_PHUB_OROM_SIZE) {
  441. addr_offset = 0;
  442. goto return_ok;
  443. }
  444. for (addr_offset = 0; addr_offset < count; addr_offset++) {
  445. if (PCH_PHUB_OROM_SIZE < off + addr_offset)
  446. goto return_ok;
  447. ret = pch_phub_write_serial_rom(chip, 0x80 + addr_offset + off,
  448. buf[addr_offset]);
  449. if (ret) {
  450. err = ret;
  451. goto return_err;
  452. }
  453. }
  454. return_ok:
  455. mutex_unlock(&pch_phub_mutex);
  456. return addr_offset;
  457. return_err:
  458. mutex_unlock(&pch_phub_mutex);
  459. return err;
  460. }
  461. static ssize_t show_pch_mac(struct device *dev, struct device_attribute *attr,
  462. char *buf)
  463. {
  464. u8 mac[8];
  465. struct pch_phub_reg *chip = dev_get_drvdata(dev);
  466. pch_phub_read_gbe_mac_addr(chip, mac);
  467. return sprintf(buf, "%02x:%02x:%02x:%02x:%02x:%02x\n",
  468. mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
  469. }
  470. static ssize_t store_pch_mac(struct device *dev, struct device_attribute *attr,
  471. const char *buf, size_t count)
  472. {
  473. u8 mac[6];
  474. struct pch_phub_reg *chip = dev_get_drvdata(dev);
  475. if (count != 18)
  476. return -EINVAL;
  477. sscanf(buf, "%02x:%02x:%02x:%02x:%02x:%02x",
  478. (u32 *)&mac[0], (u32 *)&mac[1], (u32 *)&mac[2], (u32 *)&mac[3],
  479. (u32 *)&mac[4], (u32 *)&mac[5]);
  480. pch_phub_write_gbe_mac_addr(chip, mac);
  481. return count;
  482. }
  483. static DEVICE_ATTR(pch_mac, S_IRUGO | S_IWUSR, show_pch_mac, store_pch_mac);
  484. static struct bin_attribute pch_bin_attr = {
  485. .attr = {
  486. .name = "pch_firmware",
  487. .mode = S_IRUGO | S_IWUSR,
  488. },
  489. .size = PCH_PHUB_OROM_SIZE + 1,
  490. .read = pch_phub_bin_read,
  491. .write = pch_phub_bin_write,
  492. };
  493. static int __devinit pch_phub_probe(struct pci_dev *pdev,
  494. const struct pci_device_id *id)
  495. {
  496. int retval;
  497. int ret;
  498. ssize_t rom_size;
  499. struct pch_phub_reg *chip;
  500. chip = kzalloc(sizeof(struct pch_phub_reg), GFP_KERNEL);
  501. if (chip == NULL)
  502. return -ENOMEM;
  503. ret = pci_enable_device(pdev);
  504. if (ret) {
  505. dev_err(&pdev->dev,
  506. "%s : pci_enable_device FAILED(ret=%d)", __func__, ret);
  507. goto err_pci_enable_dev;
  508. }
  509. dev_dbg(&pdev->dev, "%s : pci_enable_device returns %d\n", __func__,
  510. ret);
  511. ret = pci_request_regions(pdev, KBUILD_MODNAME);
  512. if (ret) {
  513. dev_err(&pdev->dev,
  514. "%s : pci_request_regions FAILED(ret=%d)", __func__, ret);
  515. goto err_req_regions;
  516. }
  517. dev_dbg(&pdev->dev, "%s : "
  518. "pci_request_regions returns %d\n", __func__, ret);
  519. chip->pch_phub_base_address = pci_iomap(pdev, 1, 0);
  520. if (chip->pch_phub_base_address == 0) {
  521. dev_err(&pdev->dev, "%s : pci_iomap FAILED", __func__);
  522. ret = -ENOMEM;
  523. goto err_pci_iomap;
  524. }
  525. dev_dbg(&pdev->dev, "%s : pci_iomap SUCCESS and value "
  526. "in pch_phub_base_address variable is %p\n", __func__,
  527. chip->pch_phub_base_address);
  528. chip->pch_phub_extrom_base_address = pci_map_rom(pdev, &rom_size);
  529. if (chip->pch_phub_extrom_base_address == 0) {
  530. dev_err(&pdev->dev, "%s : pci_map_rom FAILED", __func__);
  531. ret = -ENOMEM;
  532. goto err_pci_map;
  533. }
  534. dev_dbg(&pdev->dev, "%s : "
  535. "pci_map_rom SUCCESS and value in "
  536. "pch_phub_extrom_base_address variable is %p\n", __func__,
  537. chip->pch_phub_extrom_base_address);
  538. if (id->driver_data == 1) {
  539. retval = sysfs_create_file(&pdev->dev.kobj,
  540. &dev_attr_pch_mac.attr);
  541. if (retval)
  542. goto err_sysfs_create;
  543. retval = sysfs_create_bin_file(&pdev->dev.kobj, &pch_bin_attr);
  544. if (retval)
  545. goto exit_bin_attr;
  546. pch_phub_read_modify_write_reg(chip,
  547. (unsigned int)CLKCFG_REG_OFFSET,
  548. CLKCFG_CAN_50MHZ,
  549. CLKCFG_CANCLK_MASK);
  550. /* quirk for CM-iTC board */
  551. if (strstr(dmi_get_system_info(DMI_BOARD_NAME), "CM-iTC"))
  552. pch_phub_read_modify_write_reg(chip,
  553. (unsigned int)CLKCFG_REG_OFFSET,
  554. CLKCFG_UART_48MHZ | CLKCFG_BAUDDIV |
  555. CLKCFG_PLL2VCO | CLKCFG_UARTCLKSEL,
  556. CLKCFG_UART_MASK);
  557. /* set the prefech value */
  558. iowrite32(0x000affaa, chip->pch_phub_base_address + 0x14);
  559. /* set the interrupt delay value */
  560. iowrite32(0x25, chip->pch_phub_base_address + 0x44);
  561. } else if (id->driver_data == 2) {
  562. retval = sysfs_create_bin_file(&pdev->dev.kobj, &pch_bin_attr);
  563. if (retval)
  564. goto err_sysfs_create;
  565. /* set the prefech value
  566. * Device2(USB OHCI #1/ USB EHCI #1/ USB Device):a
  567. * Device4(SDIO #0,1,2):f
  568. * Device6(SATA 2):f
  569. * Device8(USB OHCI #0/ USB EHCI #0):a
  570. */
  571. iowrite32(0x000affa0, chip->pch_phub_base_address + 0x14);
  572. }
  573. pci_set_drvdata(pdev, chip);
  574. return 0;
  575. exit_bin_attr:
  576. sysfs_remove_file(&pdev->dev.kobj, &dev_attr_pch_mac.attr);
  577. err_sysfs_create:
  578. pci_unmap_rom(pdev, chip->pch_phub_extrom_base_address);
  579. err_pci_map:
  580. pci_iounmap(pdev, chip->pch_phub_base_address);
  581. err_pci_iomap:
  582. pci_release_regions(pdev);
  583. err_req_regions:
  584. pci_disable_device(pdev);
  585. err_pci_enable_dev:
  586. kfree(chip);
  587. dev_err(&pdev->dev, "%s returns %d\n", __func__, ret);
  588. return ret;
  589. }
  590. static void __devexit pch_phub_remove(struct pci_dev *pdev)
  591. {
  592. struct pch_phub_reg *chip = pci_get_drvdata(pdev);
  593. sysfs_remove_file(&pdev->dev.kobj, &dev_attr_pch_mac.attr);
  594. sysfs_remove_bin_file(&pdev->dev.kobj, &pch_bin_attr);
  595. pci_unmap_rom(pdev, chip->pch_phub_extrom_base_address);
  596. pci_iounmap(pdev, chip->pch_phub_base_address);
  597. pci_release_regions(pdev);
  598. pci_disable_device(pdev);
  599. kfree(chip);
  600. }
  601. #ifdef CONFIG_PM
  602. static int pch_phub_suspend(struct pci_dev *pdev, pm_message_t state)
  603. {
  604. int ret;
  605. pch_phub_save_reg_conf(pdev);
  606. ret = pci_save_state(pdev);
  607. if (ret) {
  608. dev_err(&pdev->dev,
  609. " %s -pci_save_state returns %d\n", __func__, ret);
  610. return ret;
  611. }
  612. pci_enable_wake(pdev, PCI_D3hot, 0);
  613. pci_disable_device(pdev);
  614. pci_set_power_state(pdev, pci_choose_state(pdev, state));
  615. return 0;
  616. }
  617. static int pch_phub_resume(struct pci_dev *pdev)
  618. {
  619. int ret;
  620. pci_set_power_state(pdev, PCI_D0);
  621. pci_restore_state(pdev);
  622. ret = pci_enable_device(pdev);
  623. if (ret) {
  624. dev_err(&pdev->dev,
  625. "%s-pci_enable_device failed(ret=%d) ", __func__, ret);
  626. return ret;
  627. }
  628. pci_enable_wake(pdev, PCI_D3hot, 0);
  629. pch_phub_restore_reg_conf(pdev);
  630. return 0;
  631. }
  632. #else
  633. #define pch_phub_suspend NULL
  634. #define pch_phub_resume NULL
  635. #endif /* CONFIG_PM */
  636. static struct pci_device_id pch_phub_pcidev_id[] = {
  637. { PCI_VDEVICE(INTEL, PCI_DEVICE_ID_PCH1_PHUB), 1, },
  638. { PCI_VDEVICE(ROHM, PCI_DEVICE_ID_ROHM_ML7213_PHUB), 2, },
  639. { }
  640. };
  641. MODULE_DEVICE_TABLE(pci, pch_phub_pcidev_id);
  642. static struct pci_driver pch_phub_driver = {
  643. .name = "pch_phub",
  644. .id_table = pch_phub_pcidev_id,
  645. .probe = pch_phub_probe,
  646. .remove = __devexit_p(pch_phub_remove),
  647. .suspend = pch_phub_suspend,
  648. .resume = pch_phub_resume
  649. };
  650. static int __init pch_phub_pci_init(void)
  651. {
  652. return pci_register_driver(&pch_phub_driver);
  653. }
  654. static void __exit pch_phub_pci_exit(void)
  655. {
  656. pci_unregister_driver(&pch_phub_driver);
  657. }
  658. module_init(pch_phub_pci_init);
  659. module_exit(pch_phub_pci_exit);
  660. MODULE_DESCRIPTION("PCH Packet Hub PCI Driver");
  661. MODULE_LICENSE("GPL");