qeth_core_sys.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705
  1. /*
  2. * drivers/s390/net/qeth_core_sys.c
  3. *
  4. * Copyright IBM Corp. 2007
  5. * Author(s): Utz Bacher <utz.bacher@de.ibm.com>,
  6. * Frank Pavlic <fpavlic@de.ibm.com>,
  7. * Thomas Spatzier <tspat@de.ibm.com>,
  8. * Frank Blaschka <frank.blaschka@de.ibm.com>
  9. */
  10. #define KMSG_COMPONENT "qeth"
  11. #define pr_fmt(fmt) KMSG_COMPONENT ": " fmt
  12. #include <linux/list.h>
  13. #include <linux/rwsem.h>
  14. #include <asm/ebcdic.h>
  15. #include "qeth_core.h"
  16. static ssize_t qeth_dev_state_show(struct device *dev,
  17. struct device_attribute *attr, char *buf)
  18. {
  19. struct qeth_card *card = dev_get_drvdata(dev);
  20. if (!card)
  21. return -EINVAL;
  22. switch (card->state) {
  23. case CARD_STATE_DOWN:
  24. return sprintf(buf, "DOWN\n");
  25. case CARD_STATE_HARDSETUP:
  26. return sprintf(buf, "HARDSETUP\n");
  27. case CARD_STATE_SOFTSETUP:
  28. return sprintf(buf, "SOFTSETUP\n");
  29. case CARD_STATE_UP:
  30. if (card->lan_online)
  31. return sprintf(buf, "UP (LAN ONLINE)\n");
  32. else
  33. return sprintf(buf, "UP (LAN OFFLINE)\n");
  34. case CARD_STATE_RECOVER:
  35. return sprintf(buf, "RECOVER\n");
  36. default:
  37. return sprintf(buf, "UNKNOWN\n");
  38. }
  39. }
  40. static DEVICE_ATTR(state, 0444, qeth_dev_state_show, NULL);
  41. static ssize_t qeth_dev_chpid_show(struct device *dev,
  42. struct device_attribute *attr, char *buf)
  43. {
  44. struct qeth_card *card = dev_get_drvdata(dev);
  45. if (!card)
  46. return -EINVAL;
  47. return sprintf(buf, "%02X\n", card->info.chpid);
  48. }
  49. static DEVICE_ATTR(chpid, 0444, qeth_dev_chpid_show, NULL);
  50. static ssize_t qeth_dev_if_name_show(struct device *dev,
  51. struct device_attribute *attr, char *buf)
  52. {
  53. struct qeth_card *card = dev_get_drvdata(dev);
  54. if (!card)
  55. return -EINVAL;
  56. return sprintf(buf, "%s\n", QETH_CARD_IFNAME(card));
  57. }
  58. static DEVICE_ATTR(if_name, 0444, qeth_dev_if_name_show, NULL);
  59. static ssize_t qeth_dev_card_type_show(struct device *dev,
  60. struct device_attribute *attr, char *buf)
  61. {
  62. struct qeth_card *card = dev_get_drvdata(dev);
  63. if (!card)
  64. return -EINVAL;
  65. return sprintf(buf, "%s\n", qeth_get_cardname_short(card));
  66. }
  67. static DEVICE_ATTR(card_type, 0444, qeth_dev_card_type_show, NULL);
  68. static inline const char *qeth_get_bufsize_str(struct qeth_card *card)
  69. {
  70. if (card->qdio.in_buf_size == 16384)
  71. return "16k";
  72. else if (card->qdio.in_buf_size == 24576)
  73. return "24k";
  74. else if (card->qdio.in_buf_size == 32768)
  75. return "32k";
  76. else if (card->qdio.in_buf_size == 40960)
  77. return "40k";
  78. else
  79. return "64k";
  80. }
  81. static ssize_t qeth_dev_inbuf_size_show(struct device *dev,
  82. struct device_attribute *attr, char *buf)
  83. {
  84. struct qeth_card *card = dev_get_drvdata(dev);
  85. if (!card)
  86. return -EINVAL;
  87. return sprintf(buf, "%s\n", qeth_get_bufsize_str(card));
  88. }
  89. static DEVICE_ATTR(inbuf_size, 0444, qeth_dev_inbuf_size_show, NULL);
  90. static ssize_t qeth_dev_portno_show(struct device *dev,
  91. struct device_attribute *attr, char *buf)
  92. {
  93. struct qeth_card *card = dev_get_drvdata(dev);
  94. if (!card)
  95. return -EINVAL;
  96. return sprintf(buf, "%i\n", card->info.portno);
  97. }
  98. static ssize_t qeth_dev_portno_store(struct device *dev,
  99. struct device_attribute *attr, const char *buf, size_t count)
  100. {
  101. struct qeth_card *card = dev_get_drvdata(dev);
  102. char *tmp;
  103. unsigned int portno, limit;
  104. int rc = 0;
  105. if (!card)
  106. return -EINVAL;
  107. mutex_lock(&card->conf_mutex);
  108. if ((card->state != CARD_STATE_DOWN) &&
  109. (card->state != CARD_STATE_RECOVER)) {
  110. rc = -EPERM;
  111. goto out;
  112. }
  113. portno = simple_strtoul(buf, &tmp, 16);
  114. if (portno > QETH_MAX_PORTNO) {
  115. rc = -EINVAL;
  116. goto out;
  117. }
  118. limit = (card->ssqd.pcnt ? card->ssqd.pcnt - 1 : card->ssqd.pcnt);
  119. if (portno > limit) {
  120. rc = -EINVAL;
  121. goto out;
  122. }
  123. card->info.portno = portno;
  124. out:
  125. mutex_unlock(&card->conf_mutex);
  126. return rc ? rc : count;
  127. }
  128. static DEVICE_ATTR(portno, 0644, qeth_dev_portno_show, qeth_dev_portno_store);
  129. static ssize_t qeth_dev_portname_show(struct device *dev,
  130. struct device_attribute *attr, char *buf)
  131. {
  132. struct qeth_card *card = dev_get_drvdata(dev);
  133. char portname[9] = {0, };
  134. if (!card)
  135. return -EINVAL;
  136. if (card->info.portname_required) {
  137. memcpy(portname, card->info.portname + 1, 8);
  138. EBCASC(portname, 8);
  139. return sprintf(buf, "%s\n", portname);
  140. } else
  141. return sprintf(buf, "no portname required\n");
  142. }
  143. static ssize_t qeth_dev_portname_store(struct device *dev,
  144. struct device_attribute *attr, const char *buf, size_t count)
  145. {
  146. struct qeth_card *card = dev_get_drvdata(dev);
  147. char *tmp;
  148. int i, rc = 0;
  149. if (!card)
  150. return -EINVAL;
  151. mutex_lock(&card->conf_mutex);
  152. if ((card->state != CARD_STATE_DOWN) &&
  153. (card->state != CARD_STATE_RECOVER)) {
  154. rc = -EPERM;
  155. goto out;
  156. }
  157. tmp = strsep((char **) &buf, "\n");
  158. if ((strlen(tmp) > 8) || (strlen(tmp) == 0)) {
  159. rc = -EINVAL;
  160. goto out;
  161. }
  162. card->info.portname[0] = strlen(tmp);
  163. /* for beauty reasons */
  164. for (i = 1; i < 9; i++)
  165. card->info.portname[i] = ' ';
  166. strcpy(card->info.portname + 1, tmp);
  167. ASCEBC(card->info.portname + 1, 8);
  168. out:
  169. mutex_unlock(&card->conf_mutex);
  170. return rc ? rc : count;
  171. }
  172. static DEVICE_ATTR(portname, 0644, qeth_dev_portname_show,
  173. qeth_dev_portname_store);
  174. static ssize_t qeth_dev_prioqing_show(struct device *dev,
  175. struct device_attribute *attr, char *buf)
  176. {
  177. struct qeth_card *card = dev_get_drvdata(dev);
  178. if (!card)
  179. return -EINVAL;
  180. switch (card->qdio.do_prio_queueing) {
  181. case QETH_PRIO_Q_ING_PREC:
  182. return sprintf(buf, "%s\n", "by precedence");
  183. case QETH_PRIO_Q_ING_TOS:
  184. return sprintf(buf, "%s\n", "by type of service");
  185. default:
  186. return sprintf(buf, "always queue %i\n",
  187. card->qdio.default_out_queue);
  188. }
  189. }
  190. static ssize_t qeth_dev_prioqing_store(struct device *dev,
  191. struct device_attribute *attr, const char *buf, size_t count)
  192. {
  193. struct qeth_card *card = dev_get_drvdata(dev);
  194. char *tmp;
  195. int rc = 0;
  196. if (!card)
  197. return -EINVAL;
  198. mutex_lock(&card->conf_mutex);
  199. if ((card->state != CARD_STATE_DOWN) &&
  200. (card->state != CARD_STATE_RECOVER)) {
  201. rc = -EPERM;
  202. goto out;
  203. }
  204. /* check if 1920 devices are supported ,
  205. * if though we have to permit priority queueing
  206. */
  207. if (card->qdio.no_out_queues == 1) {
  208. card->qdio.do_prio_queueing = QETH_PRIOQ_DEFAULT;
  209. rc = -EPERM;
  210. goto out;
  211. }
  212. tmp = strsep((char **) &buf, "\n");
  213. if (!strcmp(tmp, "prio_queueing_prec"))
  214. card->qdio.do_prio_queueing = QETH_PRIO_Q_ING_PREC;
  215. else if (!strcmp(tmp, "prio_queueing_tos"))
  216. card->qdio.do_prio_queueing = QETH_PRIO_Q_ING_TOS;
  217. else if (!strcmp(tmp, "no_prio_queueing:0")) {
  218. card->qdio.do_prio_queueing = QETH_NO_PRIO_QUEUEING;
  219. card->qdio.default_out_queue = 0;
  220. } else if (!strcmp(tmp, "no_prio_queueing:1")) {
  221. card->qdio.do_prio_queueing = QETH_NO_PRIO_QUEUEING;
  222. card->qdio.default_out_queue = 1;
  223. } else if (!strcmp(tmp, "no_prio_queueing:2")) {
  224. card->qdio.do_prio_queueing = QETH_NO_PRIO_QUEUEING;
  225. card->qdio.default_out_queue = 2;
  226. } else if (!strcmp(tmp, "no_prio_queueing:3")) {
  227. card->qdio.do_prio_queueing = QETH_NO_PRIO_QUEUEING;
  228. card->qdio.default_out_queue = 3;
  229. } else if (!strcmp(tmp, "no_prio_queueing")) {
  230. card->qdio.do_prio_queueing = QETH_NO_PRIO_QUEUEING;
  231. card->qdio.default_out_queue = QETH_DEFAULT_QUEUE;
  232. } else
  233. rc = -EINVAL;
  234. out:
  235. mutex_unlock(&card->conf_mutex);
  236. return rc ? rc : count;
  237. }
  238. static DEVICE_ATTR(priority_queueing, 0644, qeth_dev_prioqing_show,
  239. qeth_dev_prioqing_store);
  240. static ssize_t qeth_dev_bufcnt_show(struct device *dev,
  241. struct device_attribute *attr, char *buf)
  242. {
  243. struct qeth_card *card = dev_get_drvdata(dev);
  244. if (!card)
  245. return -EINVAL;
  246. return sprintf(buf, "%i\n", card->qdio.in_buf_pool.buf_count);
  247. }
  248. static ssize_t qeth_dev_bufcnt_store(struct device *dev,
  249. struct device_attribute *attr, const char *buf, size_t count)
  250. {
  251. struct qeth_card *card = dev_get_drvdata(dev);
  252. char *tmp;
  253. int cnt, old_cnt;
  254. int rc = 0;
  255. if (!card)
  256. return -EINVAL;
  257. mutex_lock(&card->conf_mutex);
  258. if ((card->state != CARD_STATE_DOWN) &&
  259. (card->state != CARD_STATE_RECOVER)) {
  260. rc = -EPERM;
  261. goto out;
  262. }
  263. old_cnt = card->qdio.in_buf_pool.buf_count;
  264. cnt = simple_strtoul(buf, &tmp, 10);
  265. cnt = (cnt < QETH_IN_BUF_COUNT_MIN) ? QETH_IN_BUF_COUNT_MIN :
  266. ((cnt > QETH_IN_BUF_COUNT_MAX) ? QETH_IN_BUF_COUNT_MAX : cnt);
  267. if (old_cnt != cnt) {
  268. rc = qeth_realloc_buffer_pool(card, cnt);
  269. }
  270. out:
  271. mutex_unlock(&card->conf_mutex);
  272. return rc ? rc : count;
  273. }
  274. static DEVICE_ATTR(buffer_count, 0644, qeth_dev_bufcnt_show,
  275. qeth_dev_bufcnt_store);
  276. static ssize_t qeth_dev_recover_store(struct device *dev,
  277. struct device_attribute *attr, const char *buf, size_t count)
  278. {
  279. struct qeth_card *card = dev_get_drvdata(dev);
  280. char *tmp;
  281. int i;
  282. if (!card)
  283. return -EINVAL;
  284. if (card->state != CARD_STATE_UP)
  285. return -EPERM;
  286. i = simple_strtoul(buf, &tmp, 16);
  287. if (i == 1)
  288. qeth_schedule_recovery(card);
  289. return count;
  290. }
  291. static DEVICE_ATTR(recover, 0200, NULL, qeth_dev_recover_store);
  292. static ssize_t qeth_dev_performance_stats_show(struct device *dev,
  293. struct device_attribute *attr, char *buf)
  294. {
  295. struct qeth_card *card = dev_get_drvdata(dev);
  296. if (!card)
  297. return -EINVAL;
  298. return sprintf(buf, "%i\n", card->options.performance_stats ? 1:0);
  299. }
  300. static ssize_t qeth_dev_performance_stats_store(struct device *dev,
  301. struct device_attribute *attr, const char *buf, size_t count)
  302. {
  303. struct qeth_card *card = dev_get_drvdata(dev);
  304. char *tmp;
  305. int i, rc = 0;
  306. if (!card)
  307. return -EINVAL;
  308. mutex_lock(&card->conf_mutex);
  309. i = simple_strtoul(buf, &tmp, 16);
  310. if ((i == 0) || (i == 1)) {
  311. if (i == card->options.performance_stats)
  312. goto out;
  313. card->options.performance_stats = i;
  314. if (i == 0)
  315. memset(&card->perf_stats, 0,
  316. sizeof(struct qeth_perf_stats));
  317. card->perf_stats.initial_rx_packets = card->stats.rx_packets;
  318. card->perf_stats.initial_tx_packets = card->stats.tx_packets;
  319. } else
  320. rc = -EINVAL;
  321. out:
  322. mutex_unlock(&card->conf_mutex);
  323. return rc ? rc : count;
  324. }
  325. static DEVICE_ATTR(performance_stats, 0644, qeth_dev_performance_stats_show,
  326. qeth_dev_performance_stats_store);
  327. static ssize_t qeth_dev_layer2_show(struct device *dev,
  328. struct device_attribute *attr, char *buf)
  329. {
  330. struct qeth_card *card = dev_get_drvdata(dev);
  331. if (!card)
  332. return -EINVAL;
  333. return sprintf(buf, "%i\n", card->options.layer2);
  334. }
  335. static ssize_t qeth_dev_layer2_store(struct device *dev,
  336. struct device_attribute *attr, const char *buf, size_t count)
  337. {
  338. struct qeth_card *card = dev_get_drvdata(dev);
  339. char *tmp;
  340. int i, rc = 0;
  341. enum qeth_discipline_id newdis;
  342. if (!card)
  343. return -EINVAL;
  344. mutex_lock(&card->discipline_mutex);
  345. if (card->state != CARD_STATE_DOWN) {
  346. rc = -EPERM;
  347. goto out;
  348. }
  349. i = simple_strtoul(buf, &tmp, 16);
  350. switch (i) {
  351. case 0:
  352. newdis = QETH_DISCIPLINE_LAYER3;
  353. break;
  354. case 1:
  355. newdis = QETH_DISCIPLINE_LAYER2;
  356. break;
  357. default:
  358. rc = -EINVAL;
  359. goto out;
  360. }
  361. if (card->options.layer2 == newdis)
  362. goto out;
  363. else {
  364. card->info.mac_bits = 0;
  365. if (card->discipline.ccwgdriver) {
  366. card->discipline.ccwgdriver->remove(card->gdev);
  367. qeth_core_free_discipline(card);
  368. }
  369. }
  370. rc = qeth_core_load_discipline(card, newdis);
  371. if (rc)
  372. goto out;
  373. rc = card->discipline.ccwgdriver->probe(card->gdev);
  374. out:
  375. mutex_unlock(&card->discipline_mutex);
  376. return rc ? rc : count;
  377. }
  378. static DEVICE_ATTR(layer2, 0644, qeth_dev_layer2_show,
  379. qeth_dev_layer2_store);
  380. #define ATTR_QETH_ISOLATION_NONE ("none")
  381. #define ATTR_QETH_ISOLATION_FWD ("forward")
  382. #define ATTR_QETH_ISOLATION_DROP ("drop")
  383. static ssize_t qeth_dev_isolation_show(struct device *dev,
  384. struct device_attribute *attr, char *buf)
  385. {
  386. struct qeth_card *card = dev_get_drvdata(dev);
  387. if (!card)
  388. return -EINVAL;
  389. switch (card->options.isolation) {
  390. case ISOLATION_MODE_NONE:
  391. return snprintf(buf, 6, "%s\n", ATTR_QETH_ISOLATION_NONE);
  392. case ISOLATION_MODE_FWD:
  393. return snprintf(buf, 9, "%s\n", ATTR_QETH_ISOLATION_FWD);
  394. case ISOLATION_MODE_DROP:
  395. return snprintf(buf, 6, "%s\n", ATTR_QETH_ISOLATION_DROP);
  396. default:
  397. return snprintf(buf, 5, "%s\n", "N/A");
  398. }
  399. }
  400. static ssize_t qeth_dev_isolation_store(struct device *dev,
  401. struct device_attribute *attr, const char *buf, size_t count)
  402. {
  403. struct qeth_card *card = dev_get_drvdata(dev);
  404. enum qeth_ipa_isolation_modes isolation;
  405. int rc = 0;
  406. char *tmp, *curtoken;
  407. curtoken = (char *) buf;
  408. if (!card)
  409. return -EINVAL;
  410. mutex_lock(&card->conf_mutex);
  411. /* check for unknown, too, in case we do not yet know who we are */
  412. if (card->info.type != QETH_CARD_TYPE_OSD &&
  413. card->info.type != QETH_CARD_TYPE_OSX &&
  414. card->info.type != QETH_CARD_TYPE_UNKNOWN) {
  415. rc = -EOPNOTSUPP;
  416. dev_err(&card->gdev->dev, "Adapter does not "
  417. "support QDIO data connection isolation\n");
  418. goto out;
  419. }
  420. /* parse input into isolation mode */
  421. tmp = strsep(&curtoken, "\n");
  422. if (!strcmp(tmp, ATTR_QETH_ISOLATION_NONE)) {
  423. isolation = ISOLATION_MODE_NONE;
  424. } else if (!strcmp(tmp, ATTR_QETH_ISOLATION_FWD)) {
  425. isolation = ISOLATION_MODE_FWD;
  426. } else if (!strcmp(tmp, ATTR_QETH_ISOLATION_DROP)) {
  427. isolation = ISOLATION_MODE_DROP;
  428. } else {
  429. rc = -EINVAL;
  430. goto out;
  431. }
  432. rc = count;
  433. /* defer IP assist if device is offline (until discipline->set_online)*/
  434. card->options.isolation = isolation;
  435. if (card->state == CARD_STATE_SOFTSETUP ||
  436. card->state == CARD_STATE_UP) {
  437. int ipa_rc = qeth_set_access_ctrl_online(card);
  438. if (ipa_rc != 0)
  439. rc = ipa_rc;
  440. }
  441. out:
  442. mutex_unlock(&card->conf_mutex);
  443. return rc;
  444. }
  445. static DEVICE_ATTR(isolation, 0644, qeth_dev_isolation_show,
  446. qeth_dev_isolation_store);
  447. static ssize_t qeth_dev_blkt_show(char *buf, struct qeth_card *card, int value)
  448. {
  449. if (!card)
  450. return -EINVAL;
  451. return sprintf(buf, "%i\n", value);
  452. }
  453. static ssize_t qeth_dev_blkt_store(struct qeth_card *card,
  454. const char *buf, size_t count, int *value, int max_value)
  455. {
  456. char *tmp;
  457. int i, rc = 0;
  458. if (!card)
  459. return -EINVAL;
  460. mutex_lock(&card->conf_mutex);
  461. if ((card->state != CARD_STATE_DOWN) &&
  462. (card->state != CARD_STATE_RECOVER)) {
  463. rc = -EPERM;
  464. goto out;
  465. }
  466. i = simple_strtoul(buf, &tmp, 10);
  467. if (i <= max_value)
  468. *value = i;
  469. else
  470. rc = -EINVAL;
  471. out:
  472. mutex_unlock(&card->conf_mutex);
  473. return rc ? rc : count;
  474. }
  475. static ssize_t qeth_dev_blkt_total_show(struct device *dev,
  476. struct device_attribute *attr, char *buf)
  477. {
  478. struct qeth_card *card = dev_get_drvdata(dev);
  479. return qeth_dev_blkt_show(buf, card, card->info.blkt.time_total);
  480. }
  481. static ssize_t qeth_dev_blkt_total_store(struct device *dev,
  482. struct device_attribute *attr, const char *buf, size_t count)
  483. {
  484. struct qeth_card *card = dev_get_drvdata(dev);
  485. return qeth_dev_blkt_store(card, buf, count,
  486. &card->info.blkt.time_total, 5000);
  487. }
  488. static DEVICE_ATTR(total, 0644, qeth_dev_blkt_total_show,
  489. qeth_dev_blkt_total_store);
  490. static ssize_t qeth_dev_blkt_inter_show(struct device *dev,
  491. struct device_attribute *attr, char *buf)
  492. {
  493. struct qeth_card *card = dev_get_drvdata(dev);
  494. return qeth_dev_blkt_show(buf, card, card->info.blkt.inter_packet);
  495. }
  496. static ssize_t qeth_dev_blkt_inter_store(struct device *dev,
  497. struct device_attribute *attr, const char *buf, size_t count)
  498. {
  499. struct qeth_card *card = dev_get_drvdata(dev);
  500. return qeth_dev_blkt_store(card, buf, count,
  501. &card->info.blkt.inter_packet, 1000);
  502. }
  503. static DEVICE_ATTR(inter, 0644, qeth_dev_blkt_inter_show,
  504. qeth_dev_blkt_inter_store);
  505. static ssize_t qeth_dev_blkt_inter_jumbo_show(struct device *dev,
  506. struct device_attribute *attr, char *buf)
  507. {
  508. struct qeth_card *card = dev_get_drvdata(dev);
  509. return qeth_dev_blkt_show(buf, card,
  510. card->info.blkt.inter_packet_jumbo);
  511. }
  512. static ssize_t qeth_dev_blkt_inter_jumbo_store(struct device *dev,
  513. struct device_attribute *attr, const char *buf, size_t count)
  514. {
  515. struct qeth_card *card = dev_get_drvdata(dev);
  516. return qeth_dev_blkt_store(card, buf, count,
  517. &card->info.blkt.inter_packet_jumbo, 1000);
  518. }
  519. static DEVICE_ATTR(inter_jumbo, 0644, qeth_dev_blkt_inter_jumbo_show,
  520. qeth_dev_blkt_inter_jumbo_store);
  521. static struct attribute *qeth_blkt_device_attrs[] = {
  522. &dev_attr_total.attr,
  523. &dev_attr_inter.attr,
  524. &dev_attr_inter_jumbo.attr,
  525. NULL,
  526. };
  527. static struct attribute_group qeth_device_blkt_group = {
  528. .name = "blkt",
  529. .attrs = qeth_blkt_device_attrs,
  530. };
  531. static struct attribute *qeth_device_attrs[] = {
  532. &dev_attr_state.attr,
  533. &dev_attr_chpid.attr,
  534. &dev_attr_if_name.attr,
  535. &dev_attr_card_type.attr,
  536. &dev_attr_inbuf_size.attr,
  537. &dev_attr_portno.attr,
  538. &dev_attr_portname.attr,
  539. &dev_attr_priority_queueing.attr,
  540. &dev_attr_buffer_count.attr,
  541. &dev_attr_recover.attr,
  542. &dev_attr_performance_stats.attr,
  543. &dev_attr_layer2.attr,
  544. &dev_attr_isolation.attr,
  545. NULL,
  546. };
  547. static struct attribute_group qeth_device_attr_group = {
  548. .attrs = qeth_device_attrs,
  549. };
  550. static struct attribute *qeth_osn_device_attrs[] = {
  551. &dev_attr_state.attr,
  552. &dev_attr_chpid.attr,
  553. &dev_attr_if_name.attr,
  554. &dev_attr_card_type.attr,
  555. &dev_attr_buffer_count.attr,
  556. &dev_attr_recover.attr,
  557. NULL,
  558. };
  559. static struct attribute_group qeth_osn_device_attr_group = {
  560. .attrs = qeth_osn_device_attrs,
  561. };
  562. int qeth_core_create_device_attributes(struct device *dev)
  563. {
  564. int ret;
  565. ret = sysfs_create_group(&dev->kobj, &qeth_device_attr_group);
  566. if (ret)
  567. return ret;
  568. ret = sysfs_create_group(&dev->kobj, &qeth_device_blkt_group);
  569. if (ret)
  570. sysfs_remove_group(&dev->kobj, &qeth_device_attr_group);
  571. return 0;
  572. }
  573. void qeth_core_remove_device_attributes(struct device *dev)
  574. {
  575. sysfs_remove_group(&dev->kobj, &qeth_device_attr_group);
  576. sysfs_remove_group(&dev->kobj, &qeth_device_blkt_group);
  577. }
  578. int qeth_core_create_osn_attributes(struct device *dev)
  579. {
  580. return sysfs_create_group(&dev->kobj, &qeth_osn_device_attr_group);
  581. }
  582. void qeth_core_remove_osn_attributes(struct device *dev)
  583. {
  584. sysfs_remove_group(&dev->kobj, &qeth_osn_device_attr_group);
  585. return;
  586. }