2 * linux/drivers/s390/net/qeth_main.c
4 * Linux on zSeries OSA Express and HiperSockets support
6 * Copyright 2000,2003 IBM Corporation
8 * Author(s): Original Code written by
9 * Utz Bacher (utz.bacher@de.ibm.com)
11 * Frank Pavlic (fpavlic@de.ibm.com) and
12 * Thomas Spatzier <tspat@de.ibm.com>
14 * This program is free software; you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License as published by
16 * the Free Software Foundation; either version 2, or (at your option)
19 * This program is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
24 * You should have received a copy of the GNU General Public License
25 * along with this program; if not, write to the Free Software
26 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
30 #include <linux/module.h>
31 #include <linux/moduleparam.h>
32 #include <linux/string.h>
33 #include <linux/errno.h>
36 #include <linux/inetdevice.h>
37 #include <linux/netdevice.h>
38 #include <linux/sched.h>
39 #include <linux/workqueue.h>
40 #include <linux/kernel.h>
41 #include <linux/slab.h>
42 #include <linux/interrupt.h>
43 #include <linux/tcp.h>
44 #include <linux/icmp.h>
45 #include <linux/skbuff.h>
47 #include <linux/igmp.h>
48 #include <linux/init.h>
49 #include <linux/reboot.h>
50 #include <linux/mii.h>
51 #include <linux/rcupdate.h>
52 #include <linux/ethtool.h>
56 #include <net/route.h>
58 #include <asm/ebcdic.h>
61 #include <asm/timex.h>
62 #include <asm/semaphore.h>
63 #include <asm/uaccess.h>
64 #include <asm/s390_rdev.h>
69 #include "qeth_eddp.h"
72 static const char *version
= "qeth S/390 OSA-Express driver";
75 * Debug Facility Stuff
77 static debug_info_t
*qeth_dbf_setup
= NULL
;
78 static debug_info_t
*qeth_dbf_data
= NULL
;
79 static debug_info_t
*qeth_dbf_misc
= NULL
;
80 static debug_info_t
*qeth_dbf_control
= NULL
;
81 debug_info_t
*qeth_dbf_trace
= NULL
;
82 static debug_info_t
*qeth_dbf_sense
= NULL
;
83 static debug_info_t
*qeth_dbf_qerr
= NULL
;
85 DEFINE_PER_CPU(char[256], qeth_dbf_txt_buf
);
87 static struct lock_class_key qdio_out_skb_queue_key
;
90 * some more definitions and declarations
92 static unsigned int known_devices
[][10] = QETH_MODELLIST_ARRAY
;
94 /* list of our cards */
95 struct qeth_card_list_struct qeth_card_list
;
96 /*process list want to be notified*/
97 spinlock_t qeth_notify_lock
;
98 struct list_head qeth_notify_list
;
100 static void qeth_send_control_data_cb(struct qeth_channel
*,
101 struct qeth_cmd_buffer
*);
104 * here we go with function implementation
107 qeth_init_qdio_info(struct qeth_card
*card
);
110 qeth_init_qdio_queues(struct qeth_card
*card
);
113 qeth_alloc_qdio_buffers(struct qeth_card
*card
);
116 qeth_free_qdio_buffers(struct qeth_card
*);
119 qeth_clear_qdio_buffers(struct qeth_card
*);
122 qeth_clear_ip_list(struct qeth_card
*, int, int);
125 qeth_clear_ipacmd_list(struct qeth_card
*);
128 qeth_qdio_clear_card(struct qeth_card
*, int);
131 qeth_clear_working_pool_list(struct qeth_card
*);
134 qeth_clear_cmd_buffers(struct qeth_channel
*);
137 qeth_stop(struct net_device
*);
140 qeth_clear_ipato_list(struct qeth_card
*);
143 qeth_is_addr_covered_by_ipato(struct qeth_card
*, struct qeth_ipaddr
*);
146 qeth_irq_tasklet(unsigned long);
149 qeth_set_online(struct ccwgroup_device
*);
152 __qeth_set_online(struct ccwgroup_device
*gdev
, int recovery_mode
);
154 static struct qeth_ipaddr
*
155 qeth_get_addr_buffer(enum qeth_prot_versions
);
158 qeth_set_multicast_list(struct net_device
*);
161 qeth_setadp_promisc_mode(struct qeth_card
*);
164 qeth_hard_header_parse(const struct sk_buff
*skb
, unsigned char *haddr
);
167 qeth_notify_processes(void)
169 /*notify all registered processes */
170 struct qeth_notify_list_struct
*n_entry
;
172 QETH_DBF_TEXT(trace
,3,"procnoti");
173 spin_lock(&qeth_notify_lock
);
174 list_for_each_entry(n_entry
, &qeth_notify_list
, list
) {
175 send_sig(n_entry
->signum
, n_entry
->task
, 1);
177 spin_unlock(&qeth_notify_lock
);
181 qeth_notifier_unregister(struct task_struct
*p
)
183 struct qeth_notify_list_struct
*n_entry
, *tmp
;
185 QETH_DBF_TEXT(trace
, 2, "notunreg");
186 spin_lock(&qeth_notify_lock
);
187 list_for_each_entry_safe(n_entry
, tmp
, &qeth_notify_list
, list
) {
188 if (n_entry
->task
== p
) {
189 list_del(&n_entry
->list
);
195 spin_unlock(&qeth_notify_lock
);
199 qeth_notifier_register(struct task_struct
*p
, int signum
)
201 struct qeth_notify_list_struct
*n_entry
;
203 /*check first if entry already exists*/
204 spin_lock(&qeth_notify_lock
);
205 list_for_each_entry(n_entry
, &qeth_notify_list
, list
) {
206 if (n_entry
->task
== p
) {
207 n_entry
->signum
= signum
;
208 spin_unlock(&qeth_notify_lock
);
212 spin_unlock(&qeth_notify_lock
);
214 n_entry
= (struct qeth_notify_list_struct
*)
215 kmalloc(sizeof(struct qeth_notify_list_struct
),GFP_KERNEL
);
219 n_entry
->signum
= signum
;
220 spin_lock(&qeth_notify_lock
);
221 list_add(&n_entry
->list
,&qeth_notify_list
);
222 spin_unlock(&qeth_notify_lock
);
228 * free channel command buffers
231 qeth_clean_channel(struct qeth_channel
*channel
)
235 QETH_DBF_TEXT(setup
, 2, "freech");
236 for (cnt
= 0; cnt
< QETH_CMD_BUFFER_NO
; cnt
++)
237 kfree(channel
->iob
[cnt
].data
);
244 qeth_free_card(struct qeth_card
*card
)
247 QETH_DBF_TEXT(setup
, 2, "freecrd");
248 QETH_DBF_HEX(setup
, 2, &card
, sizeof(void *));
249 qeth_clean_channel(&card
->read
);
250 qeth_clean_channel(&card
->write
);
252 free_netdev(card
->dev
);
253 qeth_clear_ip_list(card
, 0, 0);
254 qeth_clear_ipato_list(card
);
255 kfree(card
->ip_tbd_list
);
256 qeth_free_qdio_buffers(card
);
261 * alloc memory for command buffer per channel
264 qeth_setup_channel(struct qeth_channel
*channel
)
268 QETH_DBF_TEXT(setup
, 2, "setupch");
269 for (cnt
=0; cnt
< QETH_CMD_BUFFER_NO
; cnt
++) {
270 channel
->iob
[cnt
].data
= (char *)
271 kmalloc(QETH_BUFSIZE
, GFP_DMA
|GFP_KERNEL
);
272 if (channel
->iob
[cnt
].data
== NULL
)
274 channel
->iob
[cnt
].state
= BUF_STATE_FREE
;
275 channel
->iob
[cnt
].channel
= channel
;
276 channel
->iob
[cnt
].callback
= qeth_send_control_data_cb
;
277 channel
->iob
[cnt
].rc
= 0;
279 if (cnt
< QETH_CMD_BUFFER_NO
) {
281 kfree(channel
->iob
[cnt
].data
);
285 channel
->io_buf_no
= 0;
286 atomic_set(&channel
->irq_pending
, 0);
287 spin_lock_init(&channel
->iob_lock
);
289 init_waitqueue_head(&channel
->wait_q
);
290 channel
->irq_tasklet
.data
= (unsigned long) channel
;
291 channel
->irq_tasklet
.func
= qeth_irq_tasklet
;
296 * alloc memory for card structure
298 static struct qeth_card
*
299 qeth_alloc_card(void)
301 struct qeth_card
*card
;
303 QETH_DBF_TEXT(setup
, 2, "alloccrd");
304 card
= kzalloc(sizeof(struct qeth_card
), GFP_DMA
|GFP_KERNEL
);
307 QETH_DBF_HEX(setup
, 2, &card
, sizeof(void *));
308 if (qeth_setup_channel(&card
->read
)) {
312 if (qeth_setup_channel(&card
->write
)) {
313 qeth_clean_channel(&card
->read
);
321 __qeth_check_irb_error(struct ccw_device
*cdev
, unsigned long intparm
,
327 switch (PTR_ERR(irb
)) {
329 PRINT_WARN("i/o-error on device %s\n", cdev
->dev
.bus_id
);
330 QETH_DBF_TEXT(trace
, 2, "ckirberr");
331 QETH_DBF_TEXT_(trace
, 2, " rc%d", -EIO
);
334 PRINT_WARN("timeout on device %s\n", cdev
->dev
.bus_id
);
335 QETH_DBF_TEXT(trace
, 2, "ckirberr");
336 QETH_DBF_TEXT_(trace
, 2, " rc%d", -ETIMEDOUT
);
337 if (intparm
== QETH_RCD_PARM
) {
338 struct qeth_card
*card
= CARD_FROM_CDEV(cdev
);
340 if (card
&& (card
->data
.ccwdev
== cdev
)) {
341 card
->data
.state
= CH_STATE_DOWN
;
342 wake_up(&card
->wait_q
);
347 PRINT_WARN("unknown error %ld on device %s\n", PTR_ERR(irb
),
349 QETH_DBF_TEXT(trace
, 2, "ckirberr");
350 QETH_DBF_TEXT(trace
, 2, " rc???");
356 qeth_get_problem(struct ccw_device
*cdev
, struct irb
*irb
)
361 sense
= (char *) irb
->ecw
;
362 cstat
= irb
->scsw
.cstat
;
363 dstat
= irb
->scsw
.dstat
;
365 if (cstat
& (SCHN_STAT_CHN_CTRL_CHK
| SCHN_STAT_INTF_CTRL_CHK
|
366 SCHN_STAT_CHN_DATA_CHK
| SCHN_STAT_CHAIN_CHECK
|
367 SCHN_STAT_PROT_CHECK
| SCHN_STAT_PROG_CHECK
)) {
368 QETH_DBF_TEXT(trace
,2, "CGENCHK");
369 PRINT_WARN("check on device %s, dstat=x%x, cstat=x%x ",
370 cdev
->dev
.bus_id
, dstat
, cstat
);
371 HEXDUMP16(WARN
, "irb: ", irb
);
372 HEXDUMP16(WARN
, "irb: ", ((char *) irb
) + 32);
376 if (dstat
& DEV_STAT_UNIT_CHECK
) {
377 if (sense
[SENSE_RESETTING_EVENT_BYTE
] &
378 SENSE_RESETTING_EVENT_FLAG
) {
379 QETH_DBF_TEXT(trace
,2,"REVIND");
382 if (sense
[SENSE_COMMAND_REJECT_BYTE
] &
383 SENSE_COMMAND_REJECT_FLAG
) {
384 QETH_DBF_TEXT(trace
,2,"CMDREJi");
387 if ((sense
[2] == 0xaf) && (sense
[3] == 0xfe)) {
388 QETH_DBF_TEXT(trace
,2,"AFFE");
391 if ((!sense
[0]) && (!sense
[1]) && (!sense
[2]) && (!sense
[3])) {
392 QETH_DBF_TEXT(trace
,2,"ZEROSEN");
395 QETH_DBF_TEXT(trace
,2,"DGENCHK");
400 static int qeth_issue_next_read(struct qeth_card
*);
406 qeth_irq(struct ccw_device
*cdev
, unsigned long intparm
, struct irb
*irb
)
410 struct qeth_cmd_buffer
*buffer
;
411 struct qeth_channel
*channel
;
412 struct qeth_card
*card
;
414 QETH_DBF_TEXT(trace
,5,"irq");
416 if (__qeth_check_irb_error(cdev
, intparm
, irb
))
418 cstat
= irb
->scsw
.cstat
;
419 dstat
= irb
->scsw
.dstat
;
421 card
= CARD_FROM_CDEV(cdev
);
425 if (card
->read
.ccwdev
== cdev
){
426 channel
= &card
->read
;
427 QETH_DBF_TEXT(trace
,5,"read");
428 } else if (card
->write
.ccwdev
== cdev
) {
429 channel
= &card
->write
;
430 QETH_DBF_TEXT(trace
,5,"write");
432 channel
= &card
->data
;
433 QETH_DBF_TEXT(trace
,5,"data");
435 atomic_set(&channel
->irq_pending
, 0);
437 if (irb
->scsw
.fctl
& (SCSW_FCTL_CLEAR_FUNC
))
438 channel
->state
= CH_STATE_STOPPED
;
440 if (irb
->scsw
.fctl
& (SCSW_FCTL_HALT_FUNC
))
441 channel
->state
= CH_STATE_HALTED
;
443 /*let's wake up immediately on data channel*/
444 if ((channel
== &card
->data
) && (intparm
!= 0) &&
445 (intparm
!= QETH_RCD_PARM
))
448 if (intparm
== QETH_CLEAR_CHANNEL_PARM
) {
449 QETH_DBF_TEXT(trace
, 6, "clrchpar");
450 /* we don't have to handle this further */
453 if (intparm
== QETH_HALT_CHANNEL_PARM
) {
454 QETH_DBF_TEXT(trace
, 6, "hltchpar");
455 /* we don't have to handle this further */
458 if ((dstat
& DEV_STAT_UNIT_EXCEP
) ||
459 (dstat
& DEV_STAT_UNIT_CHECK
) ||
461 if (irb
->esw
.esw0
.erw
.cons
) {
462 /* TODO: we should make this s390dbf */
463 PRINT_WARN("sense data available on channel %s.\n",
464 CHANNEL_ID(channel
));
465 PRINT_WARN(" cstat 0x%X\n dstat 0x%X\n", cstat
, dstat
);
466 HEXDUMP16(WARN
,"irb: ",irb
);
467 HEXDUMP16(WARN
,"sense data: ",irb
->ecw
);
469 if (intparm
== QETH_RCD_PARM
) {
470 channel
->state
= CH_STATE_DOWN
;
473 rc
= qeth_get_problem(cdev
,irb
);
475 qeth_schedule_recovery(card
);
480 if (intparm
== QETH_RCD_PARM
) {
481 channel
->state
= CH_STATE_RCD_DONE
;
485 buffer
= (struct qeth_cmd_buffer
*) __va((addr_t
)intparm
);
486 buffer
->state
= BUF_STATE_PROCESSED
;
488 if (channel
== &card
->data
)
491 if (channel
== &card
->read
&&
492 channel
->state
== CH_STATE_UP
)
493 qeth_issue_next_read(card
);
495 qeth_irq_tasklet((unsigned long)channel
);
498 wake_up(&card
->wait_q
);
502 * tasklet function scheduled from irq handler
505 qeth_irq_tasklet(unsigned long data
)
507 struct qeth_card
*card
;
508 struct qeth_channel
*channel
;
509 struct qeth_cmd_buffer
*iob
;
512 QETH_DBF_TEXT(trace
,5,"irqtlet");
513 channel
= (struct qeth_channel
*) data
;
515 index
= channel
->buf_no
;
516 card
= CARD_FROM_CDEV(channel
->ccwdev
);
517 while (iob
[index
].state
== BUF_STATE_PROCESSED
) {
518 if (iob
[index
].callback
!=NULL
) {
519 iob
[index
].callback(channel
,iob
+ index
);
521 index
= (index
+ 1) % QETH_CMD_BUFFER_NO
;
523 channel
->buf_no
= index
;
524 wake_up(&card
->wait_q
);
527 static int qeth_stop_card(struct qeth_card
*, int);
530 __qeth_set_offline(struct ccwgroup_device
*cgdev
, int recovery_mode
)
532 struct qeth_card
*card
= (struct qeth_card
*) cgdev
->dev
.driver_data
;
533 int rc
= 0, rc2
= 0, rc3
= 0;
534 enum qeth_card_states recover_flag
;
536 QETH_DBF_TEXT(setup
, 3, "setoffl");
537 QETH_DBF_HEX(setup
, 3, &card
, sizeof(void *));
539 if (card
->dev
&& netif_carrier_ok(card
->dev
))
540 netif_carrier_off(card
->dev
);
541 recover_flag
= card
->state
;
542 if (qeth_stop_card(card
, recovery_mode
) == -ERESTARTSYS
){
543 PRINT_WARN("Stopping card %s interrupted by user!\n",
547 rc
= ccw_device_set_offline(CARD_DDEV(card
));
548 rc2
= ccw_device_set_offline(CARD_WDEV(card
));
549 rc3
= ccw_device_set_offline(CARD_RDEV(card
));
551 rc
= (rc2
) ? rc2
: rc3
;
553 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
554 if (recover_flag
== CARD_STATE_UP
)
555 card
->state
= CARD_STATE_RECOVER
;
556 qeth_notify_processes();
561 qeth_set_offline(struct ccwgroup_device
*cgdev
)
563 return __qeth_set_offline(cgdev
, 0);
567 qeth_threads_running(struct qeth_card
*card
, unsigned long threads
);
571 qeth_remove_device(struct ccwgroup_device
*cgdev
)
573 struct qeth_card
*card
= (struct qeth_card
*) cgdev
->dev
.driver_data
;
576 QETH_DBF_TEXT(setup
, 3, "rmdev");
577 QETH_DBF_HEX(setup
, 3, &card
, sizeof(void *));
582 wait_event(card
->wait_q
, qeth_threads_running(card
, 0xffffffff) == 0);
584 if (cgdev
->state
== CCWGROUP_ONLINE
){
585 card
->use_hard_stop
= 1;
586 qeth_set_offline(cgdev
);
588 /* remove form our internal list */
589 write_lock_irqsave(&qeth_card_list
.rwlock
, flags
);
590 list_del(&card
->list
);
591 write_unlock_irqrestore(&qeth_card_list
.rwlock
, flags
);
593 unregister_netdev(card
->dev
);
594 qeth_remove_device_attributes(&cgdev
->dev
);
595 qeth_free_card(card
);
596 cgdev
->dev
.driver_data
= NULL
;
597 put_device(&cgdev
->dev
);
601 qeth_register_addr_entry(struct qeth_card
*, struct qeth_ipaddr
*);
603 qeth_deregister_addr_entry(struct qeth_card
*, struct qeth_ipaddr
*);
606 * Add/remove address to/from card's ip list, i.e. try to add or remove
607 * reference to/from an IP address that is already registered on the card.
609 * 0 address was on card and its reference count has been adjusted,
610 * but is still > 0, so nothing has to be done
611 * also returns 0 if card was not on card and the todo was to delete
612 * the address -> there is also nothing to be done
613 * 1 address was not on card and the todo is to add it to the card's ip
615 * -1 address was on card and its reference count has been decremented
616 * to <= 0 by the todo -> address must be removed from card
619 __qeth_ref_ip_on_card(struct qeth_card
*card
, struct qeth_ipaddr
*todo
,
620 struct qeth_ipaddr
**__addr
)
622 struct qeth_ipaddr
*addr
;
625 list_for_each_entry(addr
, &card
->ip_list
, entry
) {
626 if (card
->options
.layer2
) {
627 if ((addr
->type
== todo
->type
) &&
628 (memcmp(&addr
->mac
, &todo
->mac
,
629 OSA_ADDR_LEN
) == 0)) {
635 if ((addr
->proto
== QETH_PROT_IPV4
) &&
636 (todo
->proto
== QETH_PROT_IPV4
) &&
637 (addr
->type
== todo
->type
) &&
638 (addr
->u
.a4
.addr
== todo
->u
.a4
.addr
) &&
639 (addr
->u
.a4
.mask
== todo
->u
.a4
.mask
)) {
643 if ((addr
->proto
== QETH_PROT_IPV6
) &&
644 (todo
->proto
== QETH_PROT_IPV6
) &&
645 (addr
->type
== todo
->type
) &&
646 (addr
->u
.a6
.pfxlen
== todo
->u
.a6
.pfxlen
) &&
647 (memcmp(&addr
->u
.a6
.addr
, &todo
->u
.a6
.addr
,
648 sizeof(struct in6_addr
)) == 0)) {
654 addr
->users
+= todo
->users
;
655 if (addr
->users
<= 0){
659 /* for VIPA and RXIP limit refcount to 1 */
660 if (addr
->type
!= QETH_IP_TYPE_NORMAL
)
665 if (todo
->users
> 0) {
666 /* for VIPA and RXIP limit refcount to 1 */
667 if (todo
->type
!= QETH_IP_TYPE_NORMAL
)
675 __qeth_address_exists_in_list(struct list_head
*list
, struct qeth_ipaddr
*addr
,
678 struct qeth_ipaddr
*tmp
;
680 list_for_each_entry(tmp
, list
, entry
) {
681 if ((tmp
->proto
== QETH_PROT_IPV4
) &&
682 (addr
->proto
== QETH_PROT_IPV4
) &&
683 ((same_type
&& (tmp
->type
== addr
->type
)) ||
684 (!same_type
&& (tmp
->type
!= addr
->type
)) ) &&
685 (tmp
->u
.a4
.addr
== addr
->u
.a4
.addr
) ){
688 if ((tmp
->proto
== QETH_PROT_IPV6
) &&
689 (addr
->proto
== QETH_PROT_IPV6
) &&
690 ((same_type
&& (tmp
->type
== addr
->type
)) ||
691 (!same_type
&& (tmp
->type
!= addr
->type
)) ) &&
692 (memcmp(&tmp
->u
.a6
.addr
, &addr
->u
.a6
.addr
,
693 sizeof(struct in6_addr
)) == 0) ) {
701 * Add IP to be added to todo list. If there is already an "add todo"
702 * in this list we just incremenent the reference count.
703 * Returns 0 if we just incremented reference count.
706 __qeth_insert_ip_todo(struct qeth_card
*card
, struct qeth_ipaddr
*addr
, int add
)
708 struct qeth_ipaddr
*tmp
, *t
;
711 list_for_each_entry_safe(tmp
, t
, card
->ip_tbd_list
, entry
) {
712 if ((addr
->type
== QETH_IP_TYPE_DEL_ALL_MC
) &&
713 (tmp
->type
== QETH_IP_TYPE_DEL_ALL_MC
))
715 if (card
->options
.layer2
) {
716 if ((tmp
->type
== addr
->type
) &&
717 (tmp
->is_multicast
== addr
->is_multicast
) &&
718 (memcmp(&tmp
->mac
, &addr
->mac
,
719 OSA_ADDR_LEN
) == 0)) {
725 if ((tmp
->proto
== QETH_PROT_IPV4
) &&
726 (addr
->proto
== QETH_PROT_IPV4
) &&
727 (tmp
->type
== addr
->type
) &&
728 (tmp
->is_multicast
== addr
->is_multicast
) &&
729 (tmp
->u
.a4
.addr
== addr
->u
.a4
.addr
) &&
730 (tmp
->u
.a4
.mask
== addr
->u
.a4
.mask
)) {
734 if ((tmp
->proto
== QETH_PROT_IPV6
) &&
735 (addr
->proto
== QETH_PROT_IPV6
) &&
736 (tmp
->type
== addr
->type
) &&
737 (tmp
->is_multicast
== addr
->is_multicast
) &&
738 (tmp
->u
.a6
.pfxlen
== addr
->u
.a6
.pfxlen
) &&
739 (memcmp(&tmp
->u
.a6
.addr
, &addr
->u
.a6
.addr
,
740 sizeof(struct in6_addr
)) == 0)) {
746 if (addr
->users
!= 0)
747 tmp
->users
+= addr
->users
;
749 tmp
->users
+= add
? 1:-1;
750 if (tmp
->users
== 0) {
751 list_del(&tmp
->entry
);
756 if (addr
->type
== QETH_IP_TYPE_DEL_ALL_MC
)
757 list_add(&addr
->entry
, card
->ip_tbd_list
);
759 if (addr
->users
== 0)
760 addr
->users
+= add
? 1:-1;
761 if (add
&& (addr
->type
== QETH_IP_TYPE_NORMAL
) &&
762 qeth_is_addr_covered_by_ipato(card
, addr
)){
763 QETH_DBF_TEXT(trace
, 2, "tkovaddr");
764 addr
->set_flags
|= QETH_IPA_SETIP_TAKEOVER_FLAG
;
766 list_add_tail(&addr
->entry
, card
->ip_tbd_list
);
773 * Remove IP address from list
776 qeth_delete_ip(struct qeth_card
*card
, struct qeth_ipaddr
*addr
)
781 QETH_DBF_TEXT(trace
, 4, "delip");
783 if (card
->options
.layer2
)
784 QETH_DBF_HEX(trace
, 4, &addr
->mac
, 6);
785 else if (addr
->proto
== QETH_PROT_IPV4
)
786 QETH_DBF_HEX(trace
, 4, &addr
->u
.a4
.addr
, 4);
788 QETH_DBF_HEX(trace
, 4, &addr
->u
.a6
.addr
, 8);
789 QETH_DBF_HEX(trace
, 4, ((char *)&addr
->u
.a6
.addr
) + 8, 8);
791 spin_lock_irqsave(&card
->ip_lock
, flags
);
792 rc
= __qeth_insert_ip_todo(card
, addr
, 0);
793 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
798 qeth_add_ip(struct qeth_card
*card
, struct qeth_ipaddr
*addr
)
803 QETH_DBF_TEXT(trace
, 4, "addip");
804 if (card
->options
.layer2
)
805 QETH_DBF_HEX(trace
, 4, &addr
->mac
, 6);
806 else if (addr
->proto
== QETH_PROT_IPV4
)
807 QETH_DBF_HEX(trace
, 4, &addr
->u
.a4
.addr
, 4);
809 QETH_DBF_HEX(trace
, 4, &addr
->u
.a6
.addr
, 8);
810 QETH_DBF_HEX(trace
, 4, ((char *)&addr
->u
.a6
.addr
) + 8, 8);
812 spin_lock_irqsave(&card
->ip_lock
, flags
);
813 rc
= __qeth_insert_ip_todo(card
, addr
, 1);
814 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
819 __qeth_delete_all_mc(struct qeth_card
*card
, unsigned long *flags
)
821 struct qeth_ipaddr
*addr
, *tmp
;
824 list_for_each_entry_safe(addr
, tmp
, &card
->ip_list
, entry
) {
825 if (addr
->is_multicast
) {
826 list_del(&addr
->entry
);
827 spin_unlock_irqrestore(&card
->ip_lock
, *flags
);
828 rc
= qeth_deregister_addr_entry(card
, addr
);
829 spin_lock_irqsave(&card
->ip_lock
, *flags
);
834 list_add(&addr
->entry
, &card
->ip_list
);
840 qeth_set_ip_addr_list(struct qeth_card
*card
)
842 struct list_head
*tbd_list
;
843 struct qeth_ipaddr
*todo
, *addr
;
847 QETH_DBF_TEXT(trace
, 2, "sdiplist");
848 QETH_DBF_HEX(trace
, 2, &card
, sizeof(void *));
850 spin_lock_irqsave(&card
->ip_lock
, flags
);
851 tbd_list
= card
->ip_tbd_list
;
852 card
->ip_tbd_list
= kmalloc(sizeof(struct list_head
), GFP_ATOMIC
);
853 if (!card
->ip_tbd_list
) {
854 QETH_DBF_TEXT(trace
, 0, "silnomem");
855 card
->ip_tbd_list
= tbd_list
;
856 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
859 INIT_LIST_HEAD(card
->ip_tbd_list
);
861 while (!list_empty(tbd_list
)){
862 todo
= list_entry(tbd_list
->next
, struct qeth_ipaddr
, entry
);
863 list_del(&todo
->entry
);
864 if (todo
->type
== QETH_IP_TYPE_DEL_ALL_MC
){
865 __qeth_delete_all_mc(card
, &flags
);
869 rc
= __qeth_ref_ip_on_card(card
, todo
, &addr
);
871 /* nothing to be done; only adjusted refcount */
873 } else if (rc
== 1) {
874 /* new entry to be added to on-card list */
875 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
876 rc
= qeth_register_addr_entry(card
, todo
);
877 spin_lock_irqsave(&card
->ip_lock
, flags
);
879 list_add_tail(&todo
->entry
, &card
->ip_list
);
882 } else if (rc
== -1) {
883 /* on-card entry to be removed */
884 list_del_init(&addr
->entry
);
885 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
886 rc
= qeth_deregister_addr_entry(card
, addr
);
887 spin_lock_irqsave(&card
->ip_lock
, flags
);
891 list_add_tail(&addr
->entry
, &card
->ip_list
);
895 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
899 static void qeth_delete_mc_addresses(struct qeth_card
*);
900 static void qeth_add_multicast_ipv4(struct qeth_card
*);
901 static void qeth_layer2_add_multicast(struct qeth_card
*);
902 #ifdef CONFIG_QETH_IPV6
903 static void qeth_add_multicast_ipv6(struct qeth_card
*);
907 qeth_set_thread_start_bit(struct qeth_card
*card
, unsigned long thread
)
911 spin_lock_irqsave(&card
->thread_mask_lock
, flags
);
912 if ( !(card
->thread_allowed_mask
& thread
) ||
913 (card
->thread_start_mask
& thread
) ) {
914 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
917 card
->thread_start_mask
|= thread
;
918 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
923 qeth_clear_thread_start_bit(struct qeth_card
*card
, unsigned long thread
)
927 spin_lock_irqsave(&card
->thread_mask_lock
, flags
);
928 card
->thread_start_mask
&= ~thread
;
929 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
930 wake_up(&card
->wait_q
);
934 qeth_clear_thread_running_bit(struct qeth_card
*card
, unsigned long thread
)
938 spin_lock_irqsave(&card
->thread_mask_lock
, flags
);
939 card
->thread_running_mask
&= ~thread
;
940 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
941 wake_up(&card
->wait_q
);
945 __qeth_do_run_thread(struct qeth_card
*card
, unsigned long thread
)
950 spin_lock_irqsave(&card
->thread_mask_lock
, flags
);
951 if (card
->thread_start_mask
& thread
){
952 if ((card
->thread_allowed_mask
& thread
) &&
953 !(card
->thread_running_mask
& thread
)){
955 card
->thread_start_mask
&= ~thread
;
956 card
->thread_running_mask
|= thread
;
960 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
965 qeth_do_run_thread(struct qeth_card
*card
, unsigned long thread
)
969 wait_event(card
->wait_q
,
970 (rc
= __qeth_do_run_thread(card
, thread
)) >= 0);
975 qeth_recover(void *ptr
)
977 struct qeth_card
*card
;
980 card
= (struct qeth_card
*) ptr
;
981 daemonize("qeth_recover");
982 QETH_DBF_TEXT(trace
,2,"recover1");
983 QETH_DBF_HEX(trace
, 2, &card
, sizeof(void *));
984 if (!qeth_do_run_thread(card
, QETH_RECOVER_THREAD
))
986 QETH_DBF_TEXT(trace
,2,"recover2");
987 PRINT_WARN("Recovery of device %s started ...\n",
989 card
->use_hard_stop
= 1;
990 __qeth_set_offline(card
->gdev
,1);
991 rc
= __qeth_set_online(card
->gdev
,1);
992 /* don't run another scheduled recovery */
993 qeth_clear_thread_start_bit(card
, QETH_RECOVER_THREAD
);
994 qeth_clear_thread_running_bit(card
, QETH_RECOVER_THREAD
);
996 PRINT_INFO("Device %s successfully recovered!\n",
999 PRINT_INFO("Device %s could not be recovered!\n",
1005 qeth_schedule_recovery(struct qeth_card
*card
)
1007 QETH_DBF_TEXT(trace
,2,"startrec");
1008 if (qeth_set_thread_start_bit(card
, QETH_RECOVER_THREAD
) == 0)
1009 schedule_work(&card
->kernel_thread_starter
);
1013 qeth_do_start_thread(struct qeth_card
*card
, unsigned long thread
)
1015 unsigned long flags
;
1018 spin_lock_irqsave(&card
->thread_mask_lock
, flags
);
1019 QETH_DBF_TEXT_(trace
, 4, " %02x%02x%02x",
1020 (u8
) card
->thread_start_mask
,
1021 (u8
) card
->thread_allowed_mask
,
1022 (u8
) card
->thread_running_mask
);
1023 rc
= (card
->thread_start_mask
& thread
);
1024 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
1029 qeth_start_kernel_thread(struct work_struct
*work
)
1031 struct qeth_card
*card
= container_of(work
, struct qeth_card
, kernel_thread_starter
);
1032 QETH_DBF_TEXT(trace
, 2, "strthrd");
1034 if (card
->read
.state
!= CH_STATE_UP
&&
1035 card
->write
.state
!= CH_STATE_UP
)
1037 if (qeth_do_start_thread(card
, QETH_RECOVER_THREAD
))
1038 kernel_thread(qeth_recover
, (void *) card
, SIGCHLD
);
1043 qeth_set_intial_options(struct qeth_card
*card
)
1045 card
->options
.route4
.type
= NO_ROUTER
;
1046 #ifdef CONFIG_QETH_IPV6
1047 card
->options
.route6
.type
= NO_ROUTER
;
1048 #endif /* QETH_IPV6 */
1049 card
->options
.checksum_type
= QETH_CHECKSUM_DEFAULT
;
1050 card
->options
.broadcast_mode
= QETH_TR_BROADCAST_ALLRINGS
;
1051 card
->options
.macaddr_mode
= QETH_TR_MACADDR_NONCANONICAL
;
1052 card
->options
.fake_broadcast
= 0;
1053 card
->options
.add_hhlen
= DEFAULT_ADD_HHLEN
;
1054 card
->options
.fake_ll
= 0;
1055 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
1056 card
->options
.layer2
= 1;
1058 card
->options
.layer2
= 0;
1059 card
->options
.performance_stats
= 0;
1060 card
->options
.rx_sg_cb
= QETH_RX_SG_CB
;
1064 * initialize channels ,card and all state machines
1067 qeth_setup_card(struct qeth_card
*card
)
1070 QETH_DBF_TEXT(setup
, 2, "setupcrd");
1071 QETH_DBF_HEX(setup
, 2, &card
, sizeof(void *));
1073 card
->read
.state
= CH_STATE_DOWN
;
1074 card
->write
.state
= CH_STATE_DOWN
;
1075 card
->data
.state
= CH_STATE_DOWN
;
1076 card
->state
= CARD_STATE_DOWN
;
1077 card
->lan_online
= 0;
1078 card
->use_hard_stop
= 0;
1080 #ifdef CONFIG_QETH_VLAN
1081 spin_lock_init(&card
->vlanlock
);
1082 card
->vlangrp
= NULL
;
1084 spin_lock_init(&card
->lock
);
1085 spin_lock_init(&card
->ip_lock
);
1086 spin_lock_init(&card
->thread_mask_lock
);
1087 card
->thread_start_mask
= 0;
1088 card
->thread_allowed_mask
= 0;
1089 card
->thread_running_mask
= 0;
1090 INIT_WORK(&card
->kernel_thread_starter
, qeth_start_kernel_thread
);
1091 INIT_LIST_HEAD(&card
->ip_list
);
1092 card
->ip_tbd_list
= kmalloc(sizeof(struct list_head
), GFP_KERNEL
);
1093 if (!card
->ip_tbd_list
) {
1094 QETH_DBF_TEXT(setup
, 0, "iptbdnom");
1097 INIT_LIST_HEAD(card
->ip_tbd_list
);
1098 INIT_LIST_HEAD(&card
->cmd_waiter_list
);
1099 init_waitqueue_head(&card
->wait_q
);
1100 /* intial options */
1101 qeth_set_intial_options(card
);
1102 /* IP address takeover */
1103 INIT_LIST_HEAD(&card
->ipato
.entries
);
1104 card
->ipato
.enabled
= 0;
1105 card
->ipato
.invert4
= 0;
1106 card
->ipato
.invert6
= 0;
1107 /* init QDIO stuff */
1108 qeth_init_qdio_info(card
);
1113 is_1920_device (struct qeth_card
*card
)
1115 int single_queue
= 0;
1116 struct ccw_device
*ccwdev
;
1117 struct channelPath_dsc
{
1128 QETH_DBF_TEXT(setup
, 2, "chk_1920");
1130 ccwdev
= card
->data
.ccwdev
;
1131 chp_dsc
= (struct channelPath_dsc
*)ccw_device_get_chp_desc(ccwdev
, 0);
1132 if (chp_dsc
!= NULL
) {
1133 /* CHPP field bit 6 == 1 -> single queue */
1134 single_queue
= ((chp_dsc
->chpp
& 0x02) == 0x02);
1137 QETH_DBF_TEXT_(setup
, 2, "rc:%x", single_queue
);
1138 return single_queue
;
1142 qeth_determine_card_type(struct qeth_card
*card
)
1146 QETH_DBF_TEXT(setup
, 2, "detcdtyp");
1148 card
->qdio
.do_prio_queueing
= QETH_PRIOQ_DEFAULT
;
1149 card
->qdio
.default_out_queue
= QETH_DEFAULT_QUEUE
;
1150 while (known_devices
[i
][4]) {
1151 if ((CARD_RDEV(card
)->id
.dev_type
== known_devices
[i
][2]) &&
1152 (CARD_RDEV(card
)->id
.dev_model
== known_devices
[i
][3])) {
1153 card
->info
.type
= known_devices
[i
][4];
1154 card
->qdio
.no_out_queues
= known_devices
[i
][8];
1155 card
->info
.is_multicast_different
= known_devices
[i
][9];
1156 if (is_1920_device(card
)) {
1157 PRINT_INFO("Priority Queueing not able "
1158 "due to hardware limitations!\n");
1159 card
->qdio
.no_out_queues
= 1;
1160 card
->qdio
.default_out_queue
= 0;
1166 card
->info
.type
= QETH_CARD_TYPE_UNKNOWN
;
1167 PRINT_ERR("unknown card type on device %s\n", CARD_BUS_ID(card
));
1172 qeth_probe_device(struct ccwgroup_device
*gdev
)
1174 struct qeth_card
*card
;
1176 unsigned long flags
;
1179 QETH_DBF_TEXT(setup
, 2, "probedev");
1182 if (!get_device(dev
))
1185 QETH_DBF_TEXT_(setup
, 2, "%s", gdev
->dev
.bus_id
);
1187 card
= qeth_alloc_card();
1190 QETH_DBF_TEXT_(setup
, 2, "1err%d", -ENOMEM
);
1193 card
->read
.ccwdev
= gdev
->cdev
[0];
1194 card
->write
.ccwdev
= gdev
->cdev
[1];
1195 card
->data
.ccwdev
= gdev
->cdev
[2];
1196 gdev
->dev
.driver_data
= card
;
1198 gdev
->cdev
[0]->handler
= qeth_irq
;
1199 gdev
->cdev
[1]->handler
= qeth_irq
;
1200 gdev
->cdev
[2]->handler
= qeth_irq
;
1202 if ((rc
= qeth_determine_card_type(card
))){
1203 PRINT_WARN("%s: not a valid card type\n", __func__
);
1204 QETH_DBF_TEXT_(setup
, 2, "3err%d", rc
);
1206 qeth_free_card(card
);
1209 if ((rc
= qeth_setup_card(card
))){
1210 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
1212 qeth_free_card(card
);
1215 rc
= qeth_create_device_attributes(dev
);
1218 qeth_free_card(card
);
1221 /* insert into our internal list */
1222 write_lock_irqsave(&qeth_card_list
.rwlock
, flags
);
1223 list_add_tail(&card
->list
, &qeth_card_list
.list
);
1224 write_unlock_irqrestore(&qeth_card_list
.rwlock
, flags
);
1229 static int qeth_read_conf_data(struct qeth_card
*card
, void **buffer
,
1235 struct qeth_channel
*channel
= &card
->data
;
1236 unsigned long flags
;
1239 * scan for RCD command in extended SenseID data
1241 ciw
= ccw_device_get_ciw(channel
->ccwdev
, CIW_TYPE_RCD
);
1242 if (!ciw
|| ciw
->cmd
== 0)
1244 rcd_buf
= kzalloc(ciw
->count
, GFP_KERNEL
| GFP_DMA
);
1248 channel
->ccw
.cmd_code
= ciw
->cmd
;
1249 channel
->ccw
.cda
= (__u32
) __pa (rcd_buf
);
1250 channel
->ccw
.count
= ciw
->count
;
1251 channel
->ccw
.flags
= CCW_FLAG_SLI
;
1252 channel
->state
= CH_STATE_RCD
;
1253 spin_lock_irqsave(get_ccwdev_lock(channel
->ccwdev
), flags
);
1254 ret
= ccw_device_start_timeout(channel
->ccwdev
, &channel
->ccw
,
1255 QETH_RCD_PARM
, LPM_ANYPATH
, 0,
1257 spin_unlock_irqrestore(get_ccwdev_lock(channel
->ccwdev
), flags
);
1259 wait_event(card
->wait_q
,
1260 (channel
->state
== CH_STATE_RCD_DONE
||
1261 channel
->state
== CH_STATE_DOWN
));
1262 if (channel
->state
== CH_STATE_DOWN
)
1265 channel
->state
= CH_STATE_DOWN
;
1271 *length
= ciw
->count
;
1278 qeth_get_unitaddr(struct qeth_card
*card
)
1284 QETH_DBF_TEXT(setup
, 2, "getunit");
1285 rc
= qeth_read_conf_data(card
, (void **) &prcd
, &length
);
1287 PRINT_ERR("qeth_read_conf_data for device %s returned %i\n",
1288 CARD_DDEV_ID(card
), rc
);
1291 card
->info
.chpid
= prcd
[30];
1292 card
->info
.unit_addr2
= prcd
[31];
1293 card
->info
.cula
= prcd
[63];
1294 card
->info
.guestlan
= ((prcd
[0x10] == _ascebc
['V']) &&
1295 (prcd
[0x11] == _ascebc
['M']));
1301 qeth_init_tokens(struct qeth_card
*card
)
1303 card
->token
.issuer_rm_w
= 0x00010103UL
;
1304 card
->token
.cm_filter_w
= 0x00010108UL
;
1305 card
->token
.cm_connection_w
= 0x0001010aUL
;
1306 card
->token
.ulp_filter_w
= 0x0001010bUL
;
1307 card
->token
.ulp_connection_w
= 0x0001010dUL
;
1311 raw_devno_from_bus_id(char *id
)
1313 id
+= (strlen(id
) - 4);
1314 return (__u16
) simple_strtoul(id
, &id
, 16);
1320 qeth_setup_ccw(struct qeth_channel
*channel
,unsigned char *iob
, __u32 len
)
1322 struct qeth_card
*card
;
1324 QETH_DBF_TEXT(trace
, 4, "setupccw");
1325 card
= CARD_FROM_CDEV(channel
->ccwdev
);
1326 if (channel
== &card
->read
)
1327 memcpy(&channel
->ccw
, READ_CCW
, sizeof(struct ccw1
));
1329 memcpy(&channel
->ccw
, WRITE_CCW
, sizeof(struct ccw1
));
1330 channel
->ccw
.count
= len
;
1331 channel
->ccw
.cda
= (__u32
) __pa(iob
);
1335 * get free buffer for ccws (IDX activation, lancmds,ipassists...)
1337 static struct qeth_cmd_buffer
*
1338 __qeth_get_buffer(struct qeth_channel
*channel
)
1342 QETH_DBF_TEXT(trace
, 6, "getbuff");
1343 index
= channel
->io_buf_no
;
1345 if (channel
->iob
[index
].state
== BUF_STATE_FREE
) {
1346 channel
->iob
[index
].state
= BUF_STATE_LOCKED
;
1347 channel
->io_buf_no
= (channel
->io_buf_no
+ 1) %
1349 memset(channel
->iob
[index
].data
, 0, QETH_BUFSIZE
);
1350 return channel
->iob
+ index
;
1352 index
= (index
+ 1) % QETH_CMD_BUFFER_NO
;
1353 } while(index
!= channel
->io_buf_no
);
1359 * release command buffer
1362 qeth_release_buffer(struct qeth_channel
*channel
, struct qeth_cmd_buffer
*iob
)
1364 unsigned long flags
;
1366 QETH_DBF_TEXT(trace
, 6, "relbuff");
1367 spin_lock_irqsave(&channel
->iob_lock
, flags
);
1368 memset(iob
->data
, 0, QETH_BUFSIZE
);
1369 iob
->state
= BUF_STATE_FREE
;
1370 iob
->callback
= qeth_send_control_data_cb
;
1372 spin_unlock_irqrestore(&channel
->iob_lock
, flags
);
1375 static struct qeth_cmd_buffer
*
1376 qeth_get_buffer(struct qeth_channel
*channel
)
1378 struct qeth_cmd_buffer
*buffer
= NULL
;
1379 unsigned long flags
;
1381 spin_lock_irqsave(&channel
->iob_lock
, flags
);
1382 buffer
= __qeth_get_buffer(channel
);
1383 spin_unlock_irqrestore(&channel
->iob_lock
, flags
);
1387 static struct qeth_cmd_buffer
*
1388 qeth_wait_for_buffer(struct qeth_channel
*channel
)
1390 struct qeth_cmd_buffer
*buffer
;
1391 wait_event(channel
->wait_q
,
1392 ((buffer
= qeth_get_buffer(channel
)) != NULL
));
1397 qeth_clear_cmd_buffers(struct qeth_channel
*channel
)
1401 for (cnt
=0; cnt
< QETH_CMD_BUFFER_NO
; cnt
++)
1402 qeth_release_buffer(channel
,&channel
->iob
[cnt
]);
1403 channel
->buf_no
= 0;
1404 channel
->io_buf_no
= 0;
1408 * start IDX for read and write channel
1411 qeth_idx_activate_get_answer(struct qeth_channel
*channel
,
1412 void (*idx_reply_cb
)(struct qeth_channel
*,
1413 struct qeth_cmd_buffer
*))
1415 struct qeth_cmd_buffer
*iob
;
1416 unsigned long flags
;
1418 struct qeth_card
*card
;
1420 QETH_DBF_TEXT(setup
, 2, "idxanswr");
1421 card
= CARD_FROM_CDEV(channel
->ccwdev
);
1422 iob
= qeth_get_buffer(channel
);
1423 iob
->callback
= idx_reply_cb
;
1424 memcpy(&channel
->ccw
, READ_CCW
, sizeof(struct ccw1
));
1425 channel
->ccw
.count
= QETH_BUFSIZE
;
1426 channel
->ccw
.cda
= (__u32
) __pa(iob
->data
);
1428 wait_event(card
->wait_q
,
1429 atomic_cmpxchg(&channel
->irq_pending
, 0, 1) == 0);
1430 QETH_DBF_TEXT(setup
, 6, "noirqpnd");
1431 spin_lock_irqsave(get_ccwdev_lock(channel
->ccwdev
), flags
);
1432 rc
= ccw_device_start(channel
->ccwdev
,
1433 &channel
->ccw
,(addr_t
) iob
, 0, 0);
1434 spin_unlock_irqrestore(get_ccwdev_lock(channel
->ccwdev
), flags
);
1437 PRINT_ERR("qeth: Error2 in activating channel rc=%d\n",rc
);
1438 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
1439 atomic_set(&channel
->irq_pending
, 0);
1440 wake_up(&card
->wait_q
);
1443 rc
= wait_event_interruptible_timeout(card
->wait_q
,
1444 channel
->state
== CH_STATE_UP
, QETH_TIMEOUT
);
1445 if (rc
== -ERESTARTSYS
)
1447 if (channel
->state
!= CH_STATE_UP
){
1449 QETH_DBF_TEXT_(setup
, 2, "3err%d", rc
);
1450 qeth_clear_cmd_buffers(channel
);
1457 qeth_idx_activate_channel(struct qeth_channel
*channel
,
1458 void (*idx_reply_cb
)(struct qeth_channel
*,
1459 struct qeth_cmd_buffer
*))
1461 struct qeth_card
*card
;
1462 struct qeth_cmd_buffer
*iob
;
1463 unsigned long flags
;
1467 card
= CARD_FROM_CDEV(channel
->ccwdev
);
1469 QETH_DBF_TEXT(setup
, 2, "idxactch");
1471 iob
= qeth_get_buffer(channel
);
1472 iob
->callback
= idx_reply_cb
;
1473 memcpy(&channel
->ccw
, WRITE_CCW
, sizeof(struct ccw1
));
1474 channel
->ccw
.count
= IDX_ACTIVATE_SIZE
;
1475 channel
->ccw
.cda
= (__u32
) __pa(iob
->data
);
1476 if (channel
== &card
->write
) {
1477 memcpy(iob
->data
, IDX_ACTIVATE_WRITE
, IDX_ACTIVATE_SIZE
);
1478 memcpy(QETH_TRANSPORT_HEADER_SEQ_NO(iob
->data
),
1479 &card
->seqno
.trans_hdr
, QETH_SEQ_NO_LENGTH
);
1480 card
->seqno
.trans_hdr
++;
1482 memcpy(iob
->data
, IDX_ACTIVATE_READ
, IDX_ACTIVATE_SIZE
);
1483 memcpy(QETH_TRANSPORT_HEADER_SEQ_NO(iob
->data
),
1484 &card
->seqno
.trans_hdr
, QETH_SEQ_NO_LENGTH
);
1486 memcpy(QETH_IDX_ACT_ISSUER_RM_TOKEN(iob
->data
),
1487 &card
->token
.issuer_rm_w
,QETH_MPC_TOKEN_LENGTH
);
1488 memcpy(QETH_IDX_ACT_FUNC_LEVEL(iob
->data
),
1489 &card
->info
.func_level
,sizeof(__u16
));
1490 temp
= raw_devno_from_bus_id(CARD_DDEV_ID(card
));
1491 memcpy(QETH_IDX_ACT_QDIO_DEV_CUA(iob
->data
), &temp
, 2);
1492 temp
= (card
->info
.cula
<< 8) + card
->info
.unit_addr2
;
1493 memcpy(QETH_IDX_ACT_QDIO_DEV_REALADDR(iob
->data
), &temp
, 2);
1495 wait_event(card
->wait_q
,
1496 atomic_cmpxchg(&channel
->irq_pending
, 0, 1) == 0);
1497 QETH_DBF_TEXT(setup
, 6, "noirqpnd");
1498 spin_lock_irqsave(get_ccwdev_lock(channel
->ccwdev
), flags
);
1499 rc
= ccw_device_start(channel
->ccwdev
,
1500 &channel
->ccw
,(addr_t
) iob
, 0, 0);
1501 spin_unlock_irqrestore(get_ccwdev_lock(channel
->ccwdev
), flags
);
1504 PRINT_ERR("qeth: Error1 in activating channel. rc=%d\n",rc
);
1505 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
1506 atomic_set(&channel
->irq_pending
, 0);
1507 wake_up(&card
->wait_q
);
1510 rc
= wait_event_interruptible_timeout(card
->wait_q
,
1511 channel
->state
== CH_STATE_ACTIVATING
, QETH_TIMEOUT
);
1512 if (rc
== -ERESTARTSYS
)
1514 if (channel
->state
!= CH_STATE_ACTIVATING
) {
1515 PRINT_WARN("qeth: IDX activate timed out!\n");
1516 QETH_DBF_TEXT_(setup
, 2, "2err%d", -ETIME
);
1517 qeth_clear_cmd_buffers(channel
);
1520 return qeth_idx_activate_get_answer(channel
,idx_reply_cb
);
1524 qeth_peer_func_level(int level
)
1526 if ((level
& 0xff) == 8)
1527 return (level
& 0xff) + 0x400;
1528 if (((level
>> 8) & 3) == 1)
1529 return (level
& 0xff) + 0x200;
1534 qeth_idx_write_cb(struct qeth_channel
*channel
, struct qeth_cmd_buffer
*iob
)
1536 struct qeth_card
*card
;
1539 QETH_DBF_TEXT(setup
,2, "idxwrcb");
1541 if (channel
->state
== CH_STATE_DOWN
) {
1542 channel
->state
= CH_STATE_ACTIVATING
;
1545 card
= CARD_FROM_CDEV(channel
->ccwdev
);
1547 if (!(QETH_IS_IDX_ACT_POS_REPLY(iob
->data
))) {
1548 if (QETH_IDX_ACT_CAUSE_CODE(iob
->data
) == 0x19)
1549 PRINT_ERR("IDX_ACTIVATE on write channel device %s: "
1550 "adapter exclusively used by another host\n",
1551 CARD_WDEV_ID(card
));
1553 PRINT_ERR("IDX_ACTIVATE on write channel device %s: "
1554 "negative reply\n", CARD_WDEV_ID(card
));
1557 memcpy(&temp
, QETH_IDX_ACT_FUNC_LEVEL(iob
->data
), 2);
1558 if ((temp
& ~0x0100) != qeth_peer_func_level(card
->info
.func_level
)) {
1559 PRINT_WARN("IDX_ACTIVATE on write channel device %s: "
1560 "function level mismatch "
1561 "(sent: 0x%x, received: 0x%x)\n",
1562 CARD_WDEV_ID(card
), card
->info
.func_level
, temp
);
1565 channel
->state
= CH_STATE_UP
;
1567 qeth_release_buffer(channel
, iob
);
1571 qeth_check_idx_response(unsigned char *buffer
)
1576 QETH_DBF_HEX(control
, 2, buffer
, QETH_DBF_CONTROL_LEN
);
1577 if ((buffer
[2] & 0xc0) == 0xc0) {
1578 PRINT_WARN("received an IDX TERMINATE "
1579 "with cause code 0x%02x%s\n",
1581 ((buffer
[4] == 0x22) ?
1582 " -- try another portname" : ""));
1583 QETH_DBF_TEXT(trace
, 2, "ckidxres");
1584 QETH_DBF_TEXT(trace
, 2, " idxterm");
1585 QETH_DBF_TEXT_(trace
, 2, " rc%d", -EIO
);
1592 qeth_idx_read_cb(struct qeth_channel
*channel
, struct qeth_cmd_buffer
*iob
)
1594 struct qeth_card
*card
;
1597 QETH_DBF_TEXT(setup
, 2, "idxrdcb");
1598 if (channel
->state
== CH_STATE_DOWN
) {
1599 channel
->state
= CH_STATE_ACTIVATING
;
1603 card
= CARD_FROM_CDEV(channel
->ccwdev
);
1604 if (qeth_check_idx_response(iob
->data
)) {
1607 if (!(QETH_IS_IDX_ACT_POS_REPLY(iob
->data
))) {
1608 if (QETH_IDX_ACT_CAUSE_CODE(iob
->data
) == 0x19)
1609 PRINT_ERR("IDX_ACTIVATE on read channel device %s: "
1610 "adapter exclusively used by another host\n",
1611 CARD_RDEV_ID(card
));
1613 PRINT_ERR("IDX_ACTIVATE on read channel device %s: "
1614 "negative reply\n", CARD_RDEV_ID(card
));
1619 * temporary fix for microcode bug
1620 * to revert it,replace OR by AND
1622 if ( (!QETH_IDX_NO_PORTNAME_REQUIRED(iob
->data
)) ||
1623 (card
->info
.type
== QETH_CARD_TYPE_OSAE
) )
1624 card
->info
.portname_required
= 1;
1626 memcpy(&temp
, QETH_IDX_ACT_FUNC_LEVEL(iob
->data
), 2);
1627 if (temp
!= qeth_peer_func_level(card
->info
.func_level
)) {
1628 PRINT_WARN("IDX_ACTIVATE on read channel device %s: function "
1629 "level mismatch (sent: 0x%x, received: 0x%x)\n",
1630 CARD_RDEV_ID(card
), card
->info
.func_level
, temp
);
1633 memcpy(&card
->token
.issuer_rm_r
,
1634 QETH_IDX_ACT_ISSUER_RM_TOKEN(iob
->data
),
1635 QETH_MPC_TOKEN_LENGTH
);
1636 memcpy(&card
->info
.mcl_level
[0],
1637 QETH_IDX_REPLY_LEVEL(iob
->data
), QETH_MCL_LENGTH
);
1638 channel
->state
= CH_STATE_UP
;
1640 qeth_release_buffer(channel
,iob
);
1644 qeth_issue_next_read(struct qeth_card
*card
)
1647 struct qeth_cmd_buffer
*iob
;
1649 QETH_DBF_TEXT(trace
,5,"issnxrd");
1650 if (card
->read
.state
!= CH_STATE_UP
)
1652 iob
= qeth_get_buffer(&card
->read
);
1654 PRINT_WARN("issue_next_read failed: no iob available!\n");
1657 qeth_setup_ccw(&card
->read
, iob
->data
, QETH_BUFSIZE
);
1658 QETH_DBF_TEXT(trace
, 6, "noirqpnd");
1659 rc
= ccw_device_start(card
->read
.ccwdev
, &card
->read
.ccw
,
1660 (addr_t
) iob
, 0, 0);
1662 PRINT_ERR("Error in starting next read ccw! rc=%i\n", rc
);
1663 atomic_set(&card
->read
.irq_pending
, 0);
1664 qeth_schedule_recovery(card
);
1665 wake_up(&card
->wait_q
);
1670 static struct qeth_reply
*
1671 qeth_alloc_reply(struct qeth_card
*card
)
1673 struct qeth_reply
*reply
;
1675 reply
= kzalloc(sizeof(struct qeth_reply
), GFP_ATOMIC
);
1677 atomic_set(&reply
->refcnt
, 1);
1678 atomic_set(&reply
->received
, 0);
1685 qeth_get_reply(struct qeth_reply
*reply
)
1687 WARN_ON(atomic_read(&reply
->refcnt
) <= 0);
1688 atomic_inc(&reply
->refcnt
);
1692 qeth_put_reply(struct qeth_reply
*reply
)
1694 WARN_ON(atomic_read(&reply
->refcnt
) <= 0);
1695 if (atomic_dec_and_test(&reply
->refcnt
))
1700 qeth_issue_ipa_msg(struct qeth_ipa_cmd
*cmd
, struct qeth_card
*card
)
1706 com
= cmd
->hdr
.command
;
1707 rc
= cmd
->hdr
.return_code
;
1708 ipa_name
= qeth_get_ipa_cmd_name(com
);
1710 PRINT_ERR("%s(x%X) for %s returned x%X \"%s\"\n", ipa_name
, com
,
1711 QETH_CARD_IFNAME(card
), rc
, qeth_get_ipa_msg(rc
));
1714 static struct qeth_ipa_cmd
*
1715 qeth_check_ipa_data(struct qeth_card
*card
, struct qeth_cmd_buffer
*iob
)
1717 struct qeth_ipa_cmd
*cmd
= NULL
;
1719 QETH_DBF_TEXT(trace
,5,"chkipad");
1720 if (IS_IPA(iob
->data
)){
1721 cmd
= (struct qeth_ipa_cmd
*) PDU_ENCAPSULATION(iob
->data
);
1722 if (IS_IPA_REPLY(cmd
)) {
1723 if (cmd
->hdr
.return_code
)
1724 qeth_issue_ipa_msg(cmd
, card
);
1728 switch (cmd
->hdr
.command
) {
1729 case IPA_CMD_STOPLAN
:
1730 PRINT_WARN("Link failure on %s (CHPID 0x%X) - "
1731 "there is a network problem or "
1732 "someone pulled the cable or "
1733 "disabled the port.\n",
1734 QETH_CARD_IFNAME(card
),
1736 card
->lan_online
= 0;
1737 if (card
->dev
&& netif_carrier_ok(card
->dev
))
1738 netif_carrier_off(card
->dev
);
1740 case IPA_CMD_STARTLAN
:
1741 PRINT_INFO("Link reestablished on %s "
1742 "(CHPID 0x%X). Scheduling "
1743 "IP address reset.\n",
1744 QETH_CARD_IFNAME(card
),
1746 netif_carrier_on(card
->dev
);
1747 qeth_schedule_recovery(card
);
1749 case IPA_CMD_MODCCID
:
1751 case IPA_CMD_REGISTER_LOCAL_ADDR
:
1752 QETH_DBF_TEXT(trace
,3, "irla");
1754 case IPA_CMD_UNREGISTER_LOCAL_ADDR
:
1755 QETH_DBF_TEXT(trace
,3, "urla");
1758 PRINT_WARN("Received data is IPA "
1759 "but not a reply!\n");
1768 * wake all waiting ipa commands
1771 qeth_clear_ipacmd_list(struct qeth_card
*card
)
1773 struct qeth_reply
*reply
, *r
;
1774 unsigned long flags
;
1776 QETH_DBF_TEXT(trace
, 4, "clipalst");
1778 spin_lock_irqsave(&card
->lock
, flags
);
1779 list_for_each_entry_safe(reply
, r
, &card
->cmd_waiter_list
, list
) {
1780 qeth_get_reply(reply
);
1782 atomic_inc(&reply
->received
);
1783 list_del_init(&reply
->list
);
1784 wake_up(&reply
->wait_q
);
1785 qeth_put_reply(reply
);
1787 spin_unlock_irqrestore(&card
->lock
, flags
);
1791 qeth_send_control_data_cb(struct qeth_channel
*channel
,
1792 struct qeth_cmd_buffer
*iob
)
1794 struct qeth_card
*card
;
1795 struct qeth_reply
*reply
, *r
;
1796 struct qeth_ipa_cmd
*cmd
;
1797 unsigned long flags
;
1800 QETH_DBF_TEXT(trace
,4,"sndctlcb");
1802 card
= CARD_FROM_CDEV(channel
->ccwdev
);
1803 if (qeth_check_idx_response(iob
->data
)) {
1804 qeth_clear_ipacmd_list(card
);
1805 qeth_schedule_recovery(card
);
1809 cmd
= qeth_check_ipa_data(card
, iob
);
1810 if ((cmd
== NULL
) && (card
->state
!= CARD_STATE_DOWN
))
1812 /*in case of OSN : check if cmd is set */
1813 if (card
->info
.type
== QETH_CARD_TYPE_OSN
&&
1815 cmd
->hdr
.command
!= IPA_CMD_STARTLAN
&&
1816 card
->osn_info
.assist_cb
!= NULL
) {
1817 card
->osn_info
.assist_cb(card
->dev
, cmd
);
1821 spin_lock_irqsave(&card
->lock
, flags
);
1822 list_for_each_entry_safe(reply
, r
, &card
->cmd_waiter_list
, list
) {
1823 if ((reply
->seqno
== QETH_IDX_COMMAND_SEQNO
) ||
1824 ((cmd
) && (reply
->seqno
== cmd
->hdr
.seqno
))) {
1825 qeth_get_reply(reply
);
1826 list_del_init(&reply
->list
);
1827 spin_unlock_irqrestore(&card
->lock
, flags
);
1829 if (reply
->callback
!= NULL
) {
1831 reply
->offset
= (__u16
)((char*)cmd
-
1833 keep_reply
= reply
->callback(card
,
1835 (unsigned long)cmd
);
1837 keep_reply
= reply
->callback(card
,
1839 (unsigned long)iob
);
1842 reply
->rc
= (u16
) cmd
->hdr
.return_code
;
1844 reply
->rc
= iob
->rc
;
1846 spin_lock_irqsave(&card
->lock
, flags
);
1847 list_add_tail(&reply
->list
,
1848 &card
->cmd_waiter_list
);
1849 spin_unlock_irqrestore(&card
->lock
, flags
);
1851 atomic_inc(&reply
->received
);
1852 wake_up(&reply
->wait_q
);
1854 qeth_put_reply(reply
);
1858 spin_unlock_irqrestore(&card
->lock
, flags
);
1860 memcpy(&card
->seqno
.pdu_hdr_ack
,
1861 QETH_PDU_HEADER_SEQ_NO(iob
->data
),
1862 QETH_SEQ_NO_LENGTH
);
1863 qeth_release_buffer(channel
,iob
);
1867 qeth_prepare_control_data(struct qeth_card
*card
, int len
,
1868 struct qeth_cmd_buffer
*iob
)
1870 qeth_setup_ccw(&card
->write
,iob
->data
,len
);
1871 iob
->callback
= qeth_release_buffer
;
1873 memcpy(QETH_TRANSPORT_HEADER_SEQ_NO(iob
->data
),
1874 &card
->seqno
.trans_hdr
, QETH_SEQ_NO_LENGTH
);
1875 card
->seqno
.trans_hdr
++;
1876 memcpy(QETH_PDU_HEADER_SEQ_NO(iob
->data
),
1877 &card
->seqno
.pdu_hdr
, QETH_SEQ_NO_LENGTH
);
1878 card
->seqno
.pdu_hdr
++;
1879 memcpy(QETH_PDU_HEADER_ACK_SEQ_NO(iob
->data
),
1880 &card
->seqno
.pdu_hdr_ack
, QETH_SEQ_NO_LENGTH
);
1881 QETH_DBF_HEX(control
, 2, iob
->data
, QETH_DBF_CONTROL_LEN
);
1885 qeth_send_control_data(struct qeth_card
*card
, int len
,
1886 struct qeth_cmd_buffer
*iob
,
1888 (struct qeth_card
*, struct qeth_reply
*, unsigned long),
1893 unsigned long flags
;
1894 struct qeth_reply
*reply
= NULL
;
1895 unsigned long timeout
;
1897 QETH_DBF_TEXT(trace
, 2, "sendctl");
1899 reply
= qeth_alloc_reply(card
);
1901 PRINT_WARN("Could no alloc qeth_reply!\n");
1904 reply
->callback
= reply_cb
;
1905 reply
->param
= reply_param
;
1906 if (card
->state
== CARD_STATE_DOWN
)
1907 reply
->seqno
= QETH_IDX_COMMAND_SEQNO
;
1909 reply
->seqno
= card
->seqno
.ipa
++;
1910 init_waitqueue_head(&reply
->wait_q
);
1911 spin_lock_irqsave(&card
->lock
, flags
);
1912 list_add_tail(&reply
->list
, &card
->cmd_waiter_list
);
1913 spin_unlock_irqrestore(&card
->lock
, flags
);
1914 QETH_DBF_HEX(control
, 2, iob
->data
, QETH_DBF_CONTROL_LEN
);
1916 while (atomic_cmpxchg(&card
->write
.irq_pending
, 0, 1)) ;
1917 qeth_prepare_control_data(card
, len
, iob
);
1919 if (IS_IPA(iob
->data
))
1920 timeout
= jiffies
+ QETH_IPA_TIMEOUT
;
1922 timeout
= jiffies
+ QETH_TIMEOUT
;
1924 QETH_DBF_TEXT(trace
, 6, "noirqpnd");
1925 spin_lock_irqsave(get_ccwdev_lock(card
->write
.ccwdev
), flags
);
1926 rc
= ccw_device_start(card
->write
.ccwdev
, &card
->write
.ccw
,
1927 (addr_t
) iob
, 0, 0);
1928 spin_unlock_irqrestore(get_ccwdev_lock(card
->write
.ccwdev
), flags
);
1930 PRINT_WARN("qeth_send_control_data: "
1931 "ccw_device_start rc = %i\n", rc
);
1932 QETH_DBF_TEXT_(trace
, 2, " err%d", rc
);
1933 spin_lock_irqsave(&card
->lock
, flags
);
1934 list_del_init(&reply
->list
);
1935 qeth_put_reply(reply
);
1936 spin_unlock_irqrestore(&card
->lock
, flags
);
1937 qeth_release_buffer(iob
->channel
, iob
);
1938 atomic_set(&card
->write
.irq_pending
, 0);
1939 wake_up(&card
->wait_q
);
1942 while (!atomic_read(&reply
->received
)) {
1943 if (time_after(jiffies
, timeout
)) {
1944 spin_lock_irqsave(&reply
->card
->lock
, flags
);
1945 list_del_init(&reply
->list
);
1946 spin_unlock_irqrestore(&reply
->card
->lock
, flags
);
1948 atomic_inc(&reply
->received
);
1949 wake_up(&reply
->wait_q
);
1954 qeth_put_reply(reply
);
1959 qeth_osn_send_control_data(struct qeth_card
*card
, int len
,
1960 struct qeth_cmd_buffer
*iob
)
1962 unsigned long flags
;
1965 QETH_DBF_TEXT(trace
, 5, "osndctrd");
1967 wait_event(card
->wait_q
,
1968 atomic_cmpxchg(&card
->write
.irq_pending
, 0, 1) == 0);
1969 qeth_prepare_control_data(card
, len
, iob
);
1970 QETH_DBF_TEXT(trace
, 6, "osnoirqp");
1971 spin_lock_irqsave(get_ccwdev_lock(card
->write
.ccwdev
), flags
);
1972 rc
= ccw_device_start(card
->write
.ccwdev
, &card
->write
.ccw
,
1973 (addr_t
) iob
, 0, 0);
1974 spin_unlock_irqrestore(get_ccwdev_lock(card
->write
.ccwdev
), flags
);
1976 PRINT_WARN("qeth_osn_send_control_data: "
1977 "ccw_device_start rc = %i\n", rc
);
1978 QETH_DBF_TEXT_(trace
, 2, " err%d", rc
);
1979 qeth_release_buffer(iob
->channel
, iob
);
1980 atomic_set(&card
->write
.irq_pending
, 0);
1981 wake_up(&card
->wait_q
);
1987 qeth_prepare_ipa_cmd(struct qeth_card
*card
, struct qeth_cmd_buffer
*iob
,
1990 memcpy(iob
->data
, IPA_PDU_HEADER
, IPA_PDU_HEADER_SIZE
);
1991 memcpy(QETH_IPA_CMD_PROT_TYPE(iob
->data
),&prot_type
,1);
1992 memcpy(QETH_IPA_CMD_DEST_ADDR(iob
->data
),
1993 &card
->token
.ulp_connection_r
, QETH_MPC_TOKEN_LENGTH
);
1997 qeth_osn_send_ipa_cmd(struct qeth_card
*card
, struct qeth_cmd_buffer
*iob
,
2002 QETH_DBF_TEXT(trace
,4,"osndipa");
2004 qeth_prepare_ipa_cmd(card
, iob
, QETH_PROT_OSN2
);
2005 s1
= (u16
)(IPA_PDU_HEADER_SIZE
+ data_len
);
2007 memcpy(QETH_IPA_PDU_LEN_TOTAL(iob
->data
), &s1
, 2);
2008 memcpy(QETH_IPA_PDU_LEN_PDU1(iob
->data
), &s2
, 2);
2009 memcpy(QETH_IPA_PDU_LEN_PDU2(iob
->data
), &s2
, 2);
2010 memcpy(QETH_IPA_PDU_LEN_PDU3(iob
->data
), &s2
, 2);
2011 return qeth_osn_send_control_data(card
, s1
, iob
);
2015 qeth_send_ipa_cmd(struct qeth_card
*card
, struct qeth_cmd_buffer
*iob
,
2017 (struct qeth_card
*,struct qeth_reply
*, unsigned long),
2023 QETH_DBF_TEXT(trace
,4,"sendipa");
2025 if (card
->options
.layer2
)
2026 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
2027 prot_type
= QETH_PROT_OSN2
;
2029 prot_type
= QETH_PROT_LAYER2
;
2031 prot_type
= QETH_PROT_TCPIP
;
2032 qeth_prepare_ipa_cmd(card
,iob
,prot_type
);
2033 rc
= qeth_send_control_data(card
, IPA_CMD_LENGTH
, iob
,
2034 reply_cb
, reply_param
);
2040 qeth_cm_enable_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
2043 struct qeth_cmd_buffer
*iob
;
2045 QETH_DBF_TEXT(setup
, 2, "cmenblcb");
2047 iob
= (struct qeth_cmd_buffer
*) data
;
2048 memcpy(&card
->token
.cm_filter_r
,
2049 QETH_CM_ENABLE_RESP_FILTER_TOKEN(iob
->data
),
2050 QETH_MPC_TOKEN_LENGTH
);
2051 QETH_DBF_TEXT_(setup
, 2, " rc%d", iob
->rc
);
2056 qeth_cm_enable(struct qeth_card
*card
)
2059 struct qeth_cmd_buffer
*iob
;
2061 QETH_DBF_TEXT(setup
,2,"cmenable");
2063 iob
= qeth_wait_for_buffer(&card
->write
);
2064 memcpy(iob
->data
, CM_ENABLE
, CM_ENABLE_SIZE
);
2065 memcpy(QETH_CM_ENABLE_ISSUER_RM_TOKEN(iob
->data
),
2066 &card
->token
.issuer_rm_r
, QETH_MPC_TOKEN_LENGTH
);
2067 memcpy(QETH_CM_ENABLE_FILTER_TOKEN(iob
->data
),
2068 &card
->token
.cm_filter_w
, QETH_MPC_TOKEN_LENGTH
);
2070 rc
= qeth_send_control_data(card
, CM_ENABLE_SIZE
, iob
,
2071 qeth_cm_enable_cb
, NULL
);
2076 qeth_cm_setup_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
2080 struct qeth_cmd_buffer
*iob
;
2082 QETH_DBF_TEXT(setup
, 2, "cmsetpcb");
2084 iob
= (struct qeth_cmd_buffer
*) data
;
2085 memcpy(&card
->token
.cm_connection_r
,
2086 QETH_CM_SETUP_RESP_DEST_ADDR(iob
->data
),
2087 QETH_MPC_TOKEN_LENGTH
);
2088 QETH_DBF_TEXT_(setup
, 2, " rc%d", iob
->rc
);
2093 qeth_cm_setup(struct qeth_card
*card
)
2096 struct qeth_cmd_buffer
*iob
;
2098 QETH_DBF_TEXT(setup
,2,"cmsetup");
2100 iob
= qeth_wait_for_buffer(&card
->write
);
2101 memcpy(iob
->data
, CM_SETUP
, CM_SETUP_SIZE
);
2102 memcpy(QETH_CM_SETUP_DEST_ADDR(iob
->data
),
2103 &card
->token
.issuer_rm_r
, QETH_MPC_TOKEN_LENGTH
);
2104 memcpy(QETH_CM_SETUP_CONNECTION_TOKEN(iob
->data
),
2105 &card
->token
.cm_connection_w
, QETH_MPC_TOKEN_LENGTH
);
2106 memcpy(QETH_CM_SETUP_FILTER_TOKEN(iob
->data
),
2107 &card
->token
.cm_filter_r
, QETH_MPC_TOKEN_LENGTH
);
2108 rc
= qeth_send_control_data(card
, CM_SETUP_SIZE
, iob
,
2109 qeth_cm_setup_cb
, NULL
);
2115 qeth_ulp_enable_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
2119 __u16 mtu
, framesize
;
2122 struct qeth_cmd_buffer
*iob
;
2124 QETH_DBF_TEXT(setup
, 2, "ulpenacb");
2126 iob
= (struct qeth_cmd_buffer
*) data
;
2127 memcpy(&card
->token
.ulp_filter_r
,
2128 QETH_ULP_ENABLE_RESP_FILTER_TOKEN(iob
->data
),
2129 QETH_MPC_TOKEN_LENGTH
);
2130 if (qeth_get_mtu_out_of_mpc(card
->info
.type
)) {
2131 memcpy(&framesize
, QETH_ULP_ENABLE_RESP_MAX_MTU(iob
->data
), 2);
2132 mtu
= qeth_get_mtu_outof_framesize(framesize
);
2135 QETH_DBF_TEXT_(setup
, 2, " rc%d", iob
->rc
);
2138 card
->info
.max_mtu
= mtu
;
2139 card
->info
.initial_mtu
= mtu
;
2140 card
->qdio
.in_buf_size
= mtu
+ 2 * PAGE_SIZE
;
2142 card
->info
.initial_mtu
= qeth_get_initial_mtu_for_card(card
);
2143 card
->info
.max_mtu
= qeth_get_max_mtu_for_card(card
->info
.type
);
2144 card
->qdio
.in_buf_size
= QETH_IN_BUF_SIZE_DEFAULT
;
2147 memcpy(&len
, QETH_ULP_ENABLE_RESP_DIFINFO_LEN(iob
->data
), 2);
2148 if (len
>= QETH_MPC_DIFINFO_LEN_INDICATES_LINK_TYPE
) {
2150 QETH_ULP_ENABLE_RESP_LINK_TYPE(iob
->data
), 1);
2151 card
->info
.link_type
= link_type
;
2153 card
->info
.link_type
= 0;
2154 QETH_DBF_TEXT_(setup
, 2, " rc%d", iob
->rc
);
2159 qeth_ulp_enable(struct qeth_card
*card
)
2163 struct qeth_cmd_buffer
*iob
;
2165 /*FIXME: trace view callbacks*/
2166 QETH_DBF_TEXT(setup
,2,"ulpenabl");
2168 iob
= qeth_wait_for_buffer(&card
->write
);
2169 memcpy(iob
->data
, ULP_ENABLE
, ULP_ENABLE_SIZE
);
2171 *(QETH_ULP_ENABLE_LINKNUM(iob
->data
)) =
2172 (__u8
) card
->info
.portno
;
2173 if (card
->options
.layer2
)
2174 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
2175 prot_type
= QETH_PROT_OSN2
;
2177 prot_type
= QETH_PROT_LAYER2
;
2179 prot_type
= QETH_PROT_TCPIP
;
2181 memcpy(QETH_ULP_ENABLE_PROT_TYPE(iob
->data
),&prot_type
,1);
2182 memcpy(QETH_ULP_ENABLE_DEST_ADDR(iob
->data
),
2183 &card
->token
.cm_connection_r
, QETH_MPC_TOKEN_LENGTH
);
2184 memcpy(QETH_ULP_ENABLE_FILTER_TOKEN(iob
->data
),
2185 &card
->token
.ulp_filter_w
, QETH_MPC_TOKEN_LENGTH
);
2186 memcpy(QETH_ULP_ENABLE_PORTNAME_AND_LL(iob
->data
),
2187 card
->info
.portname
, 9);
2188 rc
= qeth_send_control_data(card
, ULP_ENABLE_SIZE
, iob
,
2189 qeth_ulp_enable_cb
, NULL
);
2195 qeth_ulp_setup_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
2198 struct qeth_cmd_buffer
*iob
;
2200 QETH_DBF_TEXT(setup
, 2, "ulpstpcb");
2202 iob
= (struct qeth_cmd_buffer
*) data
;
2203 memcpy(&card
->token
.ulp_connection_r
,
2204 QETH_ULP_SETUP_RESP_CONNECTION_TOKEN(iob
->data
),
2205 QETH_MPC_TOKEN_LENGTH
);
2206 QETH_DBF_TEXT_(setup
, 2, " rc%d", iob
->rc
);
2211 qeth_ulp_setup(struct qeth_card
*card
)
2215 struct qeth_cmd_buffer
*iob
;
2216 struct ccw_dev_id dev_id
;
2218 QETH_DBF_TEXT(setup
,2,"ulpsetup");
2220 iob
= qeth_wait_for_buffer(&card
->write
);
2221 memcpy(iob
->data
, ULP_SETUP
, ULP_SETUP_SIZE
);
2223 memcpy(QETH_ULP_SETUP_DEST_ADDR(iob
->data
),
2224 &card
->token
.cm_connection_r
, QETH_MPC_TOKEN_LENGTH
);
2225 memcpy(QETH_ULP_SETUP_CONNECTION_TOKEN(iob
->data
),
2226 &card
->token
.ulp_connection_w
, QETH_MPC_TOKEN_LENGTH
);
2227 memcpy(QETH_ULP_SETUP_FILTER_TOKEN(iob
->data
),
2228 &card
->token
.ulp_filter_r
, QETH_MPC_TOKEN_LENGTH
);
2230 ccw_device_get_id(CARD_DDEV(card
), &dev_id
);
2231 memcpy(QETH_ULP_SETUP_CUA(iob
->data
), &dev_id
.devno
, 2);
2232 temp
= (card
->info
.cula
<< 8) + card
->info
.unit_addr2
;
2233 memcpy(QETH_ULP_SETUP_REAL_DEVADDR(iob
->data
), &temp
, 2);
2234 rc
= qeth_send_control_data(card
, ULP_SETUP_SIZE
, iob
,
2235 qeth_ulp_setup_cb
, NULL
);
2240 qeth_check_qdio_errors(struct qdio_buffer
*buf
, unsigned int qdio_error
,
2241 unsigned int siga_error
, const char *dbftext
)
2243 if (qdio_error
|| siga_error
) {
2244 QETH_DBF_TEXT(trace
, 2, dbftext
);
2245 QETH_DBF_TEXT(qerr
, 2, dbftext
);
2246 QETH_DBF_TEXT_(qerr
, 2, " F15=%02X",
2247 buf
->element
[15].flags
& 0xff);
2248 QETH_DBF_TEXT_(qerr
, 2, " F14=%02X",
2249 buf
->element
[14].flags
& 0xff);
2250 QETH_DBF_TEXT_(qerr
, 2, " qerr=%X", qdio_error
);
2251 QETH_DBF_TEXT_(qerr
, 2, " serr=%X", siga_error
);
2257 static struct sk_buff
*
2258 qeth_get_skb(unsigned int length
, struct qeth_hdr
*hdr
)
2260 struct sk_buff
* skb
;
2264 if (hdr
->hdr
.osn
.id
== QETH_HEADER_TYPE_OSN
)
2265 add_len
= sizeof(struct qeth_hdr
);
2266 #ifdef CONFIG_QETH_VLAN
2268 add_len
= VLAN_HLEN
;
2270 skb
= dev_alloc_skb(length
+ add_len
);
2272 skb_reserve(skb
, add_len
);
2277 qeth_create_skb_frag(struct qdio_buffer_element
*element
,
2278 struct sk_buff
**pskb
,
2279 int offset
, int *pfrag
, int data_len
)
2281 struct page
*page
= virt_to_page(element
->addr
);
2283 /* the upper protocol layers assume that there is data in the
2284 * skb itself. Copy a small amount (64 bytes) to make them
2286 *pskb
= dev_alloc_skb(64 + QETH_FAKE_LL_LEN_ETH
);
2289 skb_reserve(*pskb
, QETH_FAKE_LL_LEN_ETH
);
2290 if (data_len
<= 64) {
2291 memcpy(skb_put(*pskb
, data_len
), element
->addr
+ offset
,
2295 memcpy(skb_put(*pskb
, 64), element
->addr
+ offset
, 64);
2296 skb_fill_page_desc(*pskb
, *pfrag
, page
, offset
+ 64,
2298 (*pskb
)->data_len
+= data_len
- 64;
2299 (*pskb
)->len
+= data_len
- 64;
2300 (*pskb
)->truesize
+= data_len
- 64;
2304 skb_fill_page_desc(*pskb
, *pfrag
, page
, offset
, data_len
);
2305 (*pskb
)->data_len
+= data_len
;
2306 (*pskb
)->len
+= data_len
;
2307 (*pskb
)->truesize
+= data_len
;
2313 static inline struct qeth_buffer_pool_entry
*
2314 qeth_find_free_buffer_pool_entry(struct qeth_card
*card
)
2316 struct list_head
*plh
;
2317 struct qeth_buffer_pool_entry
*entry
;
2321 if (list_empty(&card
->qdio
.in_buf_pool
.entry_list
))
2324 list_for_each(plh
, &card
->qdio
.in_buf_pool
.entry_list
) {
2325 entry
= list_entry(plh
, struct qeth_buffer_pool_entry
, list
);
2327 for (i
= 0; i
< QETH_MAX_BUFFER_ELEMENTS(card
); ++i
) {
2328 if (page_count(virt_to_page(entry
->elements
[i
])) > 1) {
2334 list_del_init(&entry
->list
);
2339 /* no free buffer in pool so take first one and swap pages */
2340 entry
= list_entry(card
->qdio
.in_buf_pool
.entry_list
.next
,
2341 struct qeth_buffer_pool_entry
, list
);
2342 for (i
= 0; i
< QETH_MAX_BUFFER_ELEMENTS(card
); ++i
) {
2343 if (page_count(virt_to_page(entry
->elements
[i
])) > 1) {
2344 page
= alloc_page(GFP_ATOMIC
|GFP_DMA
);
2348 free_page((unsigned long)entry
->elements
[i
]);
2349 entry
->elements
[i
] = page_address(page
);
2350 if (card
->options
.performance_stats
)
2351 card
->perf_stats
.sg_alloc_page_rx
++;
2355 list_del_init(&entry
->list
);
2359 static struct sk_buff
*
2360 qeth_get_next_skb(struct qeth_card
*card
, struct qdio_buffer
*buffer
,
2361 struct qdio_buffer_element
**__element
, int *__offset
,
2362 struct qeth_hdr
**hdr
)
2364 struct qdio_buffer_element
*element
= *__element
;
2365 int offset
= *__offset
;
2366 struct sk_buff
*skb
= NULL
;
2373 QETH_DBF_TEXT(trace
,6,"nextskb");
2374 /* qeth_hdr must not cross element boundaries */
2375 if (element
->length
< offset
+ sizeof(struct qeth_hdr
)){
2376 if (qeth_is_last_sbale(element
))
2380 if (element
->length
< sizeof(struct qeth_hdr
))
2383 *hdr
= element
->addr
+ offset
;
2385 offset
+= sizeof(struct qeth_hdr
);
2386 if (card
->options
.layer2
)
2387 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
2388 skb_len
= (*hdr
)->hdr
.osn
.pdu_length
;
2390 skb_len
= (*hdr
)->hdr
.l2
.pkt_length
;
2392 skb_len
= (*hdr
)->hdr
.l3
.length
;
2396 if ((skb_len
>= card
->options
.rx_sg_cb
) &&
2397 (!(card
->info
.type
== QETH_CARD_TYPE_OSN
)) &&
2398 (!atomic_read(&card
->force_alloc_skb
))) {
2401 if (card
->options
.fake_ll
) {
2402 if (card
->dev
->type
== ARPHRD_IEEE802_TR
) {
2403 if (!(skb
= qeth_get_skb(skb_len
+
2404 QETH_FAKE_LL_LEN_TR
, *hdr
)))
2406 skb_reserve(skb
, QETH_FAKE_LL_LEN_TR
);
2408 if (!(skb
= qeth_get_skb(skb_len
+
2409 QETH_FAKE_LL_LEN_ETH
, *hdr
)))
2411 skb_reserve(skb
, QETH_FAKE_LL_LEN_ETH
);
2414 skb
= qeth_get_skb(skb_len
, *hdr
);
2420 data_ptr
= element
->addr
+ offset
;
2422 data_len
= min(skb_len
, (int)(element
->length
- offset
));
2425 if (qeth_create_skb_frag(element
, &skb
, offset
,
2429 memcpy(skb_put(skb
, data_len
), data_ptr
,
2433 skb_len
-= data_len
;
2435 if (qeth_is_last_sbale(element
)){
2436 QETH_DBF_TEXT(trace
,4,"unexeob");
2437 QETH_DBF_TEXT_(trace
,4,"%s",CARD_BUS_ID(card
));
2438 QETH_DBF_TEXT(qerr
,2,"unexeob");
2439 QETH_DBF_TEXT_(qerr
,2,"%s",CARD_BUS_ID(card
));
2440 QETH_DBF_HEX(misc
,4,buffer
,sizeof(*buffer
));
2441 dev_kfree_skb_any(skb
);
2442 card
->stats
.rx_errors
++;
2447 data_ptr
= element
->addr
;
2452 *__element
= element
;
2454 if (use_rx_sg
&& card
->options
.performance_stats
) {
2455 card
->perf_stats
.sg_skbs_rx
++;
2456 card
->perf_stats
.sg_frags_rx
+= skb_shinfo(skb
)->nr_frags
;
2460 if (net_ratelimit()){
2461 PRINT_WARN("No memory for packet received on %s.\n",
2462 QETH_CARD_IFNAME(card
));
2463 QETH_DBF_TEXT(trace
,2,"noskbmem");
2464 QETH_DBF_TEXT_(trace
,2,"%s",CARD_BUS_ID(card
));
2466 card
->stats
.rx_dropped
++;
2471 qeth_type_trans(struct sk_buff
*skb
, struct net_device
*dev
)
2473 struct qeth_card
*card
;
2476 QETH_DBF_TEXT(trace
,6,"typtrans");
2478 card
= (struct qeth_card
*)dev
->priv
;
2480 if ((card
->info
.link_type
== QETH_LINK_TYPE_HSTR
) ||
2481 (card
->info
.link_type
== QETH_LINK_TYPE_LANE_TR
))
2482 return tr_type_trans(skb
,dev
);
2483 #endif /* CONFIG_TR */
2484 skb_reset_mac_header(skb
);
2485 skb_pull(skb
, ETH_HLEN
);
2488 if (*eth
->h_dest
& 1) {
2489 if (memcmp(eth
->h_dest
, dev
->broadcast
, ETH_ALEN
) == 0)
2490 skb
->pkt_type
= PACKET_BROADCAST
;
2492 skb
->pkt_type
= PACKET_MULTICAST
;
2493 } else if (memcmp(eth
->h_dest
, dev
->dev_addr
, ETH_ALEN
))
2494 skb
->pkt_type
= PACKET_OTHERHOST
;
2496 if (ntohs(eth
->h_proto
) >= 1536)
2497 return eth
->h_proto
;
2498 if (*(unsigned short *) (skb
->data
) == 0xFFFF)
2499 return htons(ETH_P_802_3
);
2500 return htons(ETH_P_802_2
);
2504 qeth_rebuild_skb_fake_ll_tr(struct qeth_card
*card
, struct sk_buff
*skb
,
2505 struct qeth_hdr
*hdr
)
2507 struct trh_hdr
*fake_hdr
;
2508 struct trllc
*fake_llc
;
2509 struct iphdr
*ip_hdr
;
2511 QETH_DBF_TEXT(trace
,5,"skbfktr");
2512 skb_set_mac_header(skb
, (int)-QETH_FAKE_LL_LEN_TR
);
2513 /* this is a fake ethernet header */
2514 fake_hdr
= tr_hdr(skb
);
2516 /* the destination MAC address */
2517 switch (skb
->pkt_type
){
2518 case PACKET_MULTICAST
:
2519 switch (skb
->protocol
){
2520 #ifdef CONFIG_QETH_IPV6
2521 case __constant_htons(ETH_P_IPV6
):
2522 ndisc_mc_map((struct in6_addr
*)
2523 skb
->data
+ QETH_FAKE_LL_V6_ADDR_POS
,
2524 fake_hdr
->daddr
, card
->dev
, 0);
2526 #endif /* CONFIG_QETH_IPV6 */
2527 case __constant_htons(ETH_P_IP
):
2528 ip_hdr
= (struct iphdr
*)skb
->data
;
2529 ip_tr_mc_map(ip_hdr
->daddr
, fake_hdr
->daddr
);
2532 memcpy(fake_hdr
->daddr
, card
->dev
->dev_addr
, TR_ALEN
);
2535 case PACKET_BROADCAST
:
2536 memset(fake_hdr
->daddr
, 0xff, TR_ALEN
);
2539 memcpy(fake_hdr
->daddr
, card
->dev
->dev_addr
, TR_ALEN
);
2541 /* the source MAC address */
2542 if (hdr
->hdr
.l3
.ext_flags
& QETH_HDR_EXT_SRC_MAC_ADDR
)
2543 memcpy(fake_hdr
->saddr
, &hdr
->hdr
.l3
.dest_addr
[2], TR_ALEN
);
2545 memset(fake_hdr
->saddr
, 0, TR_ALEN
);
2547 fake_llc
= (struct trllc
*)&(fake_hdr
->rcf
);
2548 fake_llc
->dsap
= EXTENDED_SAP
;
2549 fake_llc
->ssap
= EXTENDED_SAP
;
2550 fake_llc
->llc
= UI_CMD
;
2551 fake_llc
->protid
[0] = 0;
2552 fake_llc
->protid
[1] = 0;
2553 fake_llc
->protid
[2] = 0;
2554 fake_llc
->ethertype
= ETH_P_IP
;
2558 qeth_rebuild_skb_fake_ll_eth(struct qeth_card
*card
, struct sk_buff
*skb
,
2559 struct qeth_hdr
*hdr
)
2561 struct ethhdr
*fake_hdr
;
2562 struct iphdr
*ip_hdr
;
2564 QETH_DBF_TEXT(trace
,5,"skbfketh");
2565 skb_set_mac_header(skb
, -QETH_FAKE_LL_LEN_ETH
);
2566 /* this is a fake ethernet header */
2567 fake_hdr
= eth_hdr(skb
);
2569 /* the destination MAC address */
2570 switch (skb
->pkt_type
){
2571 case PACKET_MULTICAST
:
2572 switch (skb
->protocol
){
2573 #ifdef CONFIG_QETH_IPV6
2574 case __constant_htons(ETH_P_IPV6
):
2575 ndisc_mc_map((struct in6_addr
*)
2576 skb
->data
+ QETH_FAKE_LL_V6_ADDR_POS
,
2577 fake_hdr
->h_dest
, card
->dev
, 0);
2579 #endif /* CONFIG_QETH_IPV6 */
2580 case __constant_htons(ETH_P_IP
):
2581 ip_hdr
= (struct iphdr
*)skb
->data
;
2582 ip_eth_mc_map(ip_hdr
->daddr
, fake_hdr
->h_dest
);
2585 memcpy(fake_hdr
->h_dest
, card
->dev
->dev_addr
, ETH_ALEN
);
2588 case PACKET_BROADCAST
:
2589 memset(fake_hdr
->h_dest
, 0xff, ETH_ALEN
);
2592 memcpy(fake_hdr
->h_dest
, card
->dev
->dev_addr
, ETH_ALEN
);
2594 /* the source MAC address */
2595 if (hdr
->hdr
.l3
.ext_flags
& QETH_HDR_EXT_SRC_MAC_ADDR
)
2596 memcpy(fake_hdr
->h_source
, &hdr
->hdr
.l3
.dest_addr
[2], ETH_ALEN
);
2598 memset(fake_hdr
->h_source
, 0, ETH_ALEN
);
2600 fake_hdr
->h_proto
= skb
->protocol
;
2604 qeth_rebuild_skb_fake_ll(struct qeth_card
*card
, struct sk_buff
*skb
,
2605 struct qeth_hdr
*hdr
)
2607 if (card
->dev
->type
== ARPHRD_IEEE802_TR
)
2608 qeth_rebuild_skb_fake_ll_tr(card
, skb
, hdr
);
2610 qeth_rebuild_skb_fake_ll_eth(card
, skb
, hdr
);
2614 qeth_layer2_rebuild_skb(struct qeth_card
*card
, struct sk_buff
*skb
,
2615 struct qeth_hdr
*hdr
)
2617 skb
->pkt_type
= PACKET_HOST
;
2618 skb
->protocol
= qeth_type_trans(skb
, skb
->dev
);
2619 if (card
->options
.checksum_type
== NO_CHECKSUMMING
)
2620 skb
->ip_summed
= CHECKSUM_UNNECESSARY
;
2622 skb
->ip_summed
= CHECKSUM_NONE
;
2623 *((__u32
*)skb
->cb
) = ++card
->seqno
.pkt_seqno
;
2627 qeth_rebuild_skb(struct qeth_card
*card
, struct sk_buff
*skb
,
2628 struct qeth_hdr
*hdr
)
2630 unsigned short vlan_id
= 0;
2631 #ifdef CONFIG_QETH_IPV6
2632 if (hdr
->hdr
.l3
.flags
& QETH_HDR_PASSTHRU
) {
2633 skb
->pkt_type
= PACKET_HOST
;
2634 skb
->protocol
= qeth_type_trans(skb
, card
->dev
);
2637 #endif /* CONFIG_QETH_IPV6 */
2638 skb
->protocol
= htons((hdr
->hdr
.l3
.flags
& QETH_HDR_IPV6
)? ETH_P_IPV6
:
2640 switch (hdr
->hdr
.l3
.flags
& QETH_HDR_CAST_MASK
){
2641 case QETH_CAST_UNICAST
:
2642 skb
->pkt_type
= PACKET_HOST
;
2644 case QETH_CAST_MULTICAST
:
2645 skb
->pkt_type
= PACKET_MULTICAST
;
2646 card
->stats
.multicast
++;
2648 case QETH_CAST_BROADCAST
:
2649 skb
->pkt_type
= PACKET_BROADCAST
;
2650 card
->stats
.multicast
++;
2652 case QETH_CAST_ANYCAST
:
2653 case QETH_CAST_NOCAST
:
2655 skb
->pkt_type
= PACKET_HOST
;
2658 if (hdr
->hdr
.l3
.ext_flags
&
2659 (QETH_HDR_EXT_VLAN_FRAME
| QETH_HDR_EXT_INCLUDE_VLAN_TAG
)) {
2660 vlan_id
= (hdr
->hdr
.l3
.ext_flags
& QETH_HDR_EXT_VLAN_FRAME
)?
2661 hdr
->hdr
.l3
.vlan_id
: *((u16
*)&hdr
->hdr
.l3
.dest_addr
[12]);
2664 if (card
->options
.fake_ll
)
2665 qeth_rebuild_skb_fake_ll(card
, skb
, hdr
);
2667 skb_reset_mac_header(skb
);
2668 skb
->ip_summed
= card
->options
.checksum_type
;
2669 if (card
->options
.checksum_type
== HW_CHECKSUMMING
){
2670 if ( (hdr
->hdr
.l3
.ext_flags
&
2671 (QETH_HDR_EXT_CSUM_HDR_REQ
|
2672 QETH_HDR_EXT_CSUM_TRANSP_REQ
)) ==
2673 (QETH_HDR_EXT_CSUM_HDR_REQ
|
2674 QETH_HDR_EXT_CSUM_TRANSP_REQ
) )
2675 skb
->ip_summed
= CHECKSUM_UNNECESSARY
;
2677 skb
->ip_summed
= SW_CHECKSUMMING
;
2683 qeth_process_inbound_buffer(struct qeth_card
*card
,
2684 struct qeth_qdio_buffer
*buf
, int index
)
2686 struct qdio_buffer_element
*element
;
2687 struct sk_buff
*skb
;
2688 struct qeth_hdr
*hdr
;
2693 /* get first element of current buffer */
2694 element
= (struct qdio_buffer_element
*)&buf
->buffer
->element
[0];
2696 if (card
->options
.performance_stats
)
2697 card
->perf_stats
.bufs_rec
++;
2698 while((skb
= qeth_get_next_skb(card
, buf
->buffer
, &element
,
2700 skb
->dev
= card
->dev
;
2701 if (hdr
->hdr
.l2
.id
== QETH_HEADER_TYPE_LAYER2
)
2702 qeth_layer2_rebuild_skb(card
, skb
, hdr
);
2703 else if (hdr
->hdr
.l3
.id
== QETH_HEADER_TYPE_LAYER3
)
2704 vlan_tag
= qeth_rebuild_skb(card
, skb
, hdr
);
2705 else if (hdr
->hdr
.osn
.id
== QETH_HEADER_TYPE_OSN
) {
2706 skb_push(skb
, sizeof(struct qeth_hdr
));
2707 skb_copy_to_linear_data(skb
, hdr
,
2708 sizeof(struct qeth_hdr
));
2709 } else { /* unknown header type */
2710 dev_kfree_skb_any(skb
);
2711 QETH_DBF_TEXT(trace
, 3, "inbunkno");
2712 QETH_DBF_HEX(control
, 3, hdr
, QETH_DBF_CONTROL_LEN
);
2715 /* is device UP ? */
2716 if (!(card
->dev
->flags
& IFF_UP
)){
2717 dev_kfree_skb_any(skb
);
2720 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
2721 rxrc
= card
->osn_info
.data_cb(skb
);
2723 #ifdef CONFIG_QETH_VLAN
2726 vlan_hwaccel_rx(skb
, card
->vlangrp
, vlan_tag
);
2728 dev_kfree_skb_any(skb
);
2733 rxrc
= netif_rx(skb
);
2734 card
->dev
->last_rx
= jiffies
;
2735 card
->stats
.rx_packets
++;
2736 card
->stats
.rx_bytes
+= skb
->len
;
2741 qeth_init_input_buffer(struct qeth_card
*card
, struct qeth_qdio_buffer
*buf
)
2743 struct qeth_buffer_pool_entry
*pool_entry
;
2746 pool_entry
= qeth_find_free_buffer_pool_entry(card
);
2750 * since the buffer is accessed only from the input_tasklet
2751 * there shouldn't be a need to synchronize; also, since we use
2752 * the QETH_IN_BUF_REQUEUE_THRESHOLD we should never run out off
2755 BUG_ON(!pool_entry
);
2757 buf
->pool_entry
= pool_entry
;
2758 for(i
= 0; i
< QETH_MAX_BUFFER_ELEMENTS(card
); ++i
){
2759 buf
->buffer
->element
[i
].length
= PAGE_SIZE
;
2760 buf
->buffer
->element
[i
].addr
= pool_entry
->elements
[i
];
2761 if (i
== QETH_MAX_BUFFER_ELEMENTS(card
) - 1)
2762 buf
->buffer
->element
[i
].flags
= SBAL_FLAGS_LAST_ENTRY
;
2764 buf
->buffer
->element
[i
].flags
= 0;
2766 buf
->state
= QETH_QDIO_BUF_EMPTY
;
2771 qeth_clear_output_buffer(struct qeth_qdio_out_q
*queue
,
2772 struct qeth_qdio_out_buffer
*buf
)
2775 struct sk_buff
*skb
;
2777 /* is PCI flag set on buffer? */
2778 if (buf
->buffer
->element
[0].flags
& 0x40)
2779 atomic_dec(&queue
->set_pci_flags_count
);
2781 while ((skb
= skb_dequeue(&buf
->skb_list
))){
2782 atomic_dec(&skb
->users
);
2783 dev_kfree_skb_any(skb
);
2785 qeth_eddp_buf_release_contexts(buf
);
2786 for(i
= 0; i
< QETH_MAX_BUFFER_ELEMENTS(queue
->card
); ++i
){
2787 buf
->buffer
->element
[i
].length
= 0;
2788 buf
->buffer
->element
[i
].addr
= NULL
;
2789 buf
->buffer
->element
[i
].flags
= 0;
2791 buf
->next_element_to_fill
= 0;
2792 atomic_set(&buf
->state
, QETH_QDIO_BUF_EMPTY
);
2796 qeth_queue_input_buffer(struct qeth_card
*card
, int index
)
2798 struct qeth_qdio_q
*queue
= card
->qdio
.in_q
;
2804 QETH_DBF_TEXT(trace
,6,"queinbuf");
2805 count
= (index
< queue
->next_buf_to_init
)?
2806 card
->qdio
.in_buf_pool
.buf_count
-
2807 (queue
->next_buf_to_init
- index
) :
2808 card
->qdio
.in_buf_pool
.buf_count
-
2809 (queue
->next_buf_to_init
+ QDIO_MAX_BUFFERS_PER_Q
- index
);
2810 /* only requeue at a certain threshold to avoid SIGAs */
2811 if (count
>= QETH_IN_BUF_REQUEUE_THRESHOLD(card
)){
2812 for (i
= queue
->next_buf_to_init
;
2813 i
< queue
->next_buf_to_init
+ count
; ++i
) {
2814 if (qeth_init_input_buffer(card
,
2815 &queue
->bufs
[i
% QDIO_MAX_BUFFERS_PER_Q
])) {
2822 if (newcount
< count
) {
2823 /* we are in memory shortage so we switch back to
2824 traditional skb allocation and drop packages */
2825 if (!atomic_read(&card
->force_alloc_skb
) &&
2827 PRINT_WARN("Switch to alloc skb\n");
2828 atomic_set(&card
->force_alloc_skb
, 3);
2831 if ((atomic_read(&card
->force_alloc_skb
) == 1) &&
2833 PRINT_WARN("Switch to sg\n");
2834 atomic_add_unless(&card
->force_alloc_skb
, -1, 0);
2838 * according to old code it should be avoided to requeue all
2839 * 128 buffers in order to benefit from PCI avoidance.
2840 * this function keeps at least one buffer (the buffer at
2841 * 'index') un-requeued -> this buffer is the first buffer that
2842 * will be requeued the next time
2844 if (card
->options
.performance_stats
) {
2845 card
->perf_stats
.inbound_do_qdio_cnt
++;
2846 card
->perf_stats
.inbound_do_qdio_start_time
=
2849 rc
= do_QDIO(CARD_DDEV(card
),
2850 QDIO_FLAG_SYNC_INPUT
| QDIO_FLAG_UNDER_INTERRUPT
,
2851 0, queue
->next_buf_to_init
, count
, NULL
);
2852 if (card
->options
.performance_stats
)
2853 card
->perf_stats
.inbound_do_qdio_time
+=
2855 card
->perf_stats
.inbound_do_qdio_start_time
;
2857 PRINT_WARN("qeth_queue_input_buffer's do_QDIO "
2858 "return %i (device %s).\n",
2859 rc
, CARD_DDEV_ID(card
));
2860 QETH_DBF_TEXT(trace
,2,"qinberr");
2861 QETH_DBF_TEXT_(trace
,2,"%s",CARD_BUS_ID(card
));
2863 queue
->next_buf_to_init
= (queue
->next_buf_to_init
+ count
) %
2864 QDIO_MAX_BUFFERS_PER_Q
;
2869 qeth_put_buffer_pool_entry(struct qeth_card
*card
,
2870 struct qeth_buffer_pool_entry
*entry
)
2872 QETH_DBF_TEXT(trace
, 6, "ptbfplen");
2873 list_add_tail(&entry
->list
, &card
->qdio
.in_buf_pool
.entry_list
);
2877 qeth_qdio_input_handler(struct ccw_device
* ccwdev
, unsigned int status
,
2878 unsigned int qdio_err
, unsigned int siga_err
,
2879 unsigned int queue
, int first_element
, int count
,
2880 unsigned long card_ptr
)
2882 struct net_device
*net_dev
;
2883 struct qeth_card
*card
;
2884 struct qeth_qdio_buffer
*buffer
;
2888 QETH_DBF_TEXT(trace
, 6, "qdinput");
2889 card
= (struct qeth_card
*) card_ptr
;
2890 net_dev
= card
->dev
;
2891 if (card
->options
.performance_stats
) {
2892 card
->perf_stats
.inbound_cnt
++;
2893 card
->perf_stats
.inbound_start_time
= qeth_get_micros();
2895 if (status
& QDIO_STATUS_LOOK_FOR_ERROR
) {
2896 if (status
& QDIO_STATUS_ACTIVATE_CHECK_CONDITION
){
2897 QETH_DBF_TEXT(trace
, 1,"qdinchk");
2898 QETH_DBF_TEXT_(trace
,1,"%s",CARD_BUS_ID(card
));
2899 QETH_DBF_TEXT_(trace
,1,"%04X%04X",first_element
,count
);
2900 QETH_DBF_TEXT_(trace
,1,"%04X%04X", queue
, status
);
2901 qeth_schedule_recovery(card
);
2905 for (i
= first_element
; i
< (first_element
+ count
); ++i
) {
2906 index
= i
% QDIO_MAX_BUFFERS_PER_Q
;
2907 buffer
= &card
->qdio
.in_q
->bufs
[index
];
2908 if (!((status
& QDIO_STATUS_LOOK_FOR_ERROR
) &&
2909 qeth_check_qdio_errors(buffer
->buffer
,
2910 qdio_err
, siga_err
,"qinerr")))
2911 qeth_process_inbound_buffer(card
, buffer
, index
);
2912 /* clear buffer and give back to hardware */
2913 qeth_put_buffer_pool_entry(card
, buffer
->pool_entry
);
2914 qeth_queue_input_buffer(card
, index
);
2916 if (card
->options
.performance_stats
)
2917 card
->perf_stats
.inbound_time
+= qeth_get_micros() -
2918 card
->perf_stats
.inbound_start_time
;
2922 qeth_handle_send_error(struct qeth_card
*card
,
2923 struct qeth_qdio_out_buffer
*buffer
,
2924 unsigned int qdio_err
, unsigned int siga_err
)
2926 int sbalf15
= buffer
->buffer
->element
[15].flags
& 0xff;
2927 int cc
= siga_err
& 3;
2929 QETH_DBF_TEXT(trace
, 6, "hdsnderr");
2930 qeth_check_qdio_errors(buffer
->buffer
, qdio_err
, siga_err
, "qouterr");
2934 QETH_DBF_TEXT(trace
, 1,"lnkfail");
2935 QETH_DBF_TEXT_(trace
,1,"%s",CARD_BUS_ID(card
));
2936 QETH_DBF_TEXT_(trace
,1,"%04x %02x",
2937 (u16
)qdio_err
, (u8
)sbalf15
);
2938 return QETH_SEND_ERROR_LINK_FAILURE
;
2940 return QETH_SEND_ERROR_NONE
;
2942 if (siga_err
& QDIO_SIGA_ERROR_B_BIT_SET
) {
2943 QETH_DBF_TEXT(trace
, 1, "SIGAcc2B");
2944 QETH_DBF_TEXT_(trace
,1,"%s",CARD_BUS_ID(card
));
2945 return QETH_SEND_ERROR_KICK_IT
;
2947 if ((sbalf15
>= 15) && (sbalf15
<= 31))
2948 return QETH_SEND_ERROR_RETRY
;
2949 return QETH_SEND_ERROR_LINK_FAILURE
;
2950 /* look at qdio_error and sbalf 15 */
2952 QETH_DBF_TEXT(trace
, 1, "SIGAcc1");
2953 QETH_DBF_TEXT_(trace
,1,"%s",CARD_BUS_ID(card
));
2954 return QETH_SEND_ERROR_LINK_FAILURE
;
2957 QETH_DBF_TEXT(trace
, 1, "SIGAcc3");
2958 QETH_DBF_TEXT_(trace
,1,"%s",CARD_BUS_ID(card
));
2959 return QETH_SEND_ERROR_KICK_IT
;
2964 qeth_flush_buffers(struct qeth_qdio_out_q
*queue
, int under_int
,
2965 int index
, int count
)
2967 struct qeth_qdio_out_buffer
*buf
;
2970 unsigned int qdio_flags
;
2972 QETH_DBF_TEXT(trace
, 6, "flushbuf");
2974 for (i
= index
; i
< index
+ count
; ++i
) {
2975 buf
= &queue
->bufs
[i
% QDIO_MAX_BUFFERS_PER_Q
];
2976 buf
->buffer
->element
[buf
->next_element_to_fill
- 1].flags
|=
2977 SBAL_FLAGS_LAST_ENTRY
;
2979 if (queue
->card
->info
.type
== QETH_CARD_TYPE_IQD
)
2982 if (!queue
->do_pack
){
2983 if ((atomic_read(&queue
->used_buffers
) >=
2984 (QETH_HIGH_WATERMARK_PACK
-
2985 QETH_WATERMARK_PACK_FUZZ
)) &&
2986 !atomic_read(&queue
->set_pci_flags_count
)){
2987 /* it's likely that we'll go to packing
2989 atomic_inc(&queue
->set_pci_flags_count
);
2990 buf
->buffer
->element
[0].flags
|= 0x40;
2993 if (!atomic_read(&queue
->set_pci_flags_count
)){
2995 * there's no outstanding PCI any more, so we
2996 * have to request a PCI to be sure that the PCI
2997 * will wake at some time in the future then we
2998 * can flush packed buffers that might still be
2999 * hanging around, which can happen if no
3000 * further send was requested by the stack
3002 atomic_inc(&queue
->set_pci_flags_count
);
3003 buf
->buffer
->element
[0].flags
|= 0x40;
3008 queue
->card
->dev
->trans_start
= jiffies
;
3009 if (queue
->card
->options
.performance_stats
) {
3010 queue
->card
->perf_stats
.outbound_do_qdio_cnt
++;
3011 queue
->card
->perf_stats
.outbound_do_qdio_start_time
=
3014 qdio_flags
= QDIO_FLAG_SYNC_OUTPUT
;
3016 qdio_flags
|= QDIO_FLAG_UNDER_INTERRUPT
;
3017 if (atomic_read(&queue
->set_pci_flags_count
))
3018 qdio_flags
|= QDIO_FLAG_PCI_OUT
;
3019 rc
= do_QDIO(CARD_DDEV(queue
->card
), qdio_flags
,
3020 queue
->queue_no
, index
, count
, NULL
);
3021 if (queue
->card
->options
.performance_stats
)
3022 queue
->card
->perf_stats
.outbound_do_qdio_time
+=
3024 queue
->card
->perf_stats
.outbound_do_qdio_start_time
;
3026 QETH_DBF_TEXT(trace
, 2, "flushbuf");
3027 QETH_DBF_TEXT_(trace
, 2, " err%d", rc
);
3028 QETH_DBF_TEXT_(trace
, 2, "%s", CARD_DDEV_ID(queue
->card
));
3029 queue
->card
->stats
.tx_errors
+= count
;
3030 /* this must not happen under normal circumstances. if it
3031 * happens something is really wrong -> recover */
3032 qeth_schedule_recovery(queue
->card
);
3035 atomic_add(count
, &queue
->used_buffers
);
3036 if (queue
->card
->options
.performance_stats
)
3037 queue
->card
->perf_stats
.bufs_sent
+= count
;
3041 * Switched to packing state if the number of used buffers on a queue
3042 * reaches a certain limit.
3045 qeth_switch_to_packing_if_needed(struct qeth_qdio_out_q
*queue
)
3047 if (!queue
->do_pack
) {
3048 if (atomic_read(&queue
->used_buffers
)
3049 >= QETH_HIGH_WATERMARK_PACK
){
3050 /* switch non-PACKING -> PACKING */
3051 QETH_DBF_TEXT(trace
, 6, "np->pack");
3052 if (queue
->card
->options
.performance_stats
)
3053 queue
->card
->perf_stats
.sc_dp_p
++;
3060 * Switches from packing to non-packing mode. If there is a packing
3061 * buffer on the queue this buffer will be prepared to be flushed.
3062 * In that case 1 is returned to inform the caller. If no buffer
3063 * has to be flushed, zero is returned.
3066 qeth_switch_to_nonpacking_if_needed(struct qeth_qdio_out_q
*queue
)
3068 struct qeth_qdio_out_buffer
*buffer
;
3069 int flush_count
= 0;
3071 if (queue
->do_pack
) {
3072 if (atomic_read(&queue
->used_buffers
)
3073 <= QETH_LOW_WATERMARK_PACK
) {
3074 /* switch PACKING -> non-PACKING */
3075 QETH_DBF_TEXT(trace
, 6, "pack->np");
3076 if (queue
->card
->options
.performance_stats
)
3077 queue
->card
->perf_stats
.sc_p_dp
++;
3079 /* flush packing buffers */
3080 buffer
= &queue
->bufs
[queue
->next_buf_to_fill
];
3081 if ((atomic_read(&buffer
->state
) ==
3082 QETH_QDIO_BUF_EMPTY
) &&
3083 (buffer
->next_element_to_fill
> 0)) {
3084 atomic_set(&buffer
->state
,QETH_QDIO_BUF_PRIMED
);
3086 queue
->next_buf_to_fill
=
3087 (queue
->next_buf_to_fill
+ 1) %
3088 QDIO_MAX_BUFFERS_PER_Q
;
3096 * Called to flush a packing buffer if no more pci flags are on the queue.
3097 * Checks if there is a packing buffer and prepares it to be flushed.
3098 * In that case returns 1, otherwise zero.
3101 qeth_flush_buffers_on_no_pci(struct qeth_qdio_out_q
*queue
)
3103 struct qeth_qdio_out_buffer
*buffer
;
3105 buffer
= &queue
->bufs
[queue
->next_buf_to_fill
];
3106 if((atomic_read(&buffer
->state
) == QETH_QDIO_BUF_EMPTY
) &&
3107 (buffer
->next_element_to_fill
> 0)){
3108 /* it's a packing buffer */
3109 atomic_set(&buffer
->state
, QETH_QDIO_BUF_PRIMED
);
3110 queue
->next_buf_to_fill
=
3111 (queue
->next_buf_to_fill
+ 1) % QDIO_MAX_BUFFERS_PER_Q
;
3118 qeth_check_outbound_queue(struct qeth_qdio_out_q
*queue
)
3122 int q_was_packing
= 0;
3125 * check if weed have to switch to non-packing mode or if
3126 * we have to get a pci flag out on the queue
3128 if ((atomic_read(&queue
->used_buffers
) <= QETH_LOW_WATERMARK_PACK
) ||
3129 !atomic_read(&queue
->set_pci_flags_count
)){
3130 if (atomic_xchg(&queue
->state
, QETH_OUT_Q_LOCKED_FLUSH
) ==
3131 QETH_OUT_Q_UNLOCKED
) {
3133 * If we get in here, there was no action in
3134 * do_send_packet. So, we check if there is a
3135 * packing buffer to be flushed here.
3137 netif_stop_queue(queue
->card
->dev
);
3138 index
= queue
->next_buf_to_fill
;
3139 q_was_packing
= queue
->do_pack
;
3140 flush_cnt
+= qeth_switch_to_nonpacking_if_needed(queue
);
3142 !atomic_read(&queue
->set_pci_flags_count
))
3144 qeth_flush_buffers_on_no_pci(queue
);
3145 if (queue
->card
->options
.performance_stats
&&
3147 queue
->card
->perf_stats
.bufs_sent_pack
+=
3150 qeth_flush_buffers(queue
, 1, index
, flush_cnt
);
3151 atomic_set(&queue
->state
, QETH_OUT_Q_UNLOCKED
);
3157 qeth_qdio_output_handler(struct ccw_device
* ccwdev
, unsigned int status
,
3158 unsigned int qdio_error
, unsigned int siga_error
,
3159 unsigned int __queue
, int first_element
, int count
,
3160 unsigned long card_ptr
)
3162 struct qeth_card
*card
= (struct qeth_card
*) card_ptr
;
3163 struct qeth_qdio_out_q
*queue
= card
->qdio
.out_qs
[__queue
];
3164 struct qeth_qdio_out_buffer
*buffer
;
3167 QETH_DBF_TEXT(trace
, 6, "qdouhdl");
3168 if (status
& QDIO_STATUS_LOOK_FOR_ERROR
) {
3169 if (status
& QDIO_STATUS_ACTIVATE_CHECK_CONDITION
){
3170 QETH_DBF_TEXT(trace
, 2, "achkcond");
3171 QETH_DBF_TEXT_(trace
, 2, "%s", CARD_BUS_ID(card
));
3172 QETH_DBF_TEXT_(trace
, 2, "%08x", status
);
3173 netif_stop_queue(card
->dev
);
3174 qeth_schedule_recovery(card
);
3178 if (card
->options
.performance_stats
) {
3179 card
->perf_stats
.outbound_handler_cnt
++;
3180 card
->perf_stats
.outbound_handler_start_time
=
3183 for(i
= first_element
; i
< (first_element
+ count
); ++i
){
3184 buffer
= &queue
->bufs
[i
% QDIO_MAX_BUFFERS_PER_Q
];
3185 /*we only handle the KICK_IT error by doing a recovery */
3186 if (qeth_handle_send_error(card
, buffer
,
3187 qdio_error
, siga_error
)
3188 == QETH_SEND_ERROR_KICK_IT
){
3189 netif_stop_queue(card
->dev
);
3190 qeth_schedule_recovery(card
);
3193 qeth_clear_output_buffer(queue
, buffer
);
3195 atomic_sub(count
, &queue
->used_buffers
);
3196 /* check if we need to do something on this outbound queue */
3197 if (card
->info
.type
!= QETH_CARD_TYPE_IQD
)
3198 qeth_check_outbound_queue(queue
);
3200 netif_wake_queue(queue
->card
->dev
);
3201 if (card
->options
.performance_stats
)
3202 card
->perf_stats
.outbound_handler_time
+= qeth_get_micros() -
3203 card
->perf_stats
.outbound_handler_start_time
;
3207 qeth_create_qib_param_field(struct qeth_card
*card
, char *param_field
)
3210 param_field
[0] = _ascebc
['P'];
3211 param_field
[1] = _ascebc
['C'];
3212 param_field
[2] = _ascebc
['I'];
3213 param_field
[3] = _ascebc
['T'];
3214 *((unsigned int *) (¶m_field
[4])) = QETH_PCI_THRESHOLD_A(card
);
3215 *((unsigned int *) (¶m_field
[8])) = QETH_PCI_THRESHOLD_B(card
);
3216 *((unsigned int *) (¶m_field
[12])) = QETH_PCI_TIMER_VALUE(card
);
3220 qeth_create_qib_param_field_blkt(struct qeth_card
*card
, char *param_field
)
3222 param_field
[16] = _ascebc
['B'];
3223 param_field
[17] = _ascebc
['L'];
3224 param_field
[18] = _ascebc
['K'];
3225 param_field
[19] = _ascebc
['T'];
3226 *((unsigned int *) (¶m_field
[20])) = card
->info
.blkt
.time_total
;
3227 *((unsigned int *) (¶m_field
[24])) = card
->info
.blkt
.inter_packet
;
3228 *((unsigned int *) (¶m_field
[28])) = card
->info
.blkt
.inter_packet_jumbo
;
3232 qeth_initialize_working_pool_list(struct qeth_card
*card
)
3234 struct qeth_buffer_pool_entry
*entry
;
3236 QETH_DBF_TEXT(trace
,5,"inwrklst");
3238 list_for_each_entry(entry
,
3239 &card
->qdio
.init_pool
.entry_list
, init_list
) {
3240 qeth_put_buffer_pool_entry(card
,entry
);
3245 qeth_clear_working_pool_list(struct qeth_card
*card
)
3247 struct qeth_buffer_pool_entry
*pool_entry
, *tmp
;
3249 QETH_DBF_TEXT(trace
,5,"clwrklst");
3250 list_for_each_entry_safe(pool_entry
, tmp
,
3251 &card
->qdio
.in_buf_pool
.entry_list
, list
){
3252 list_del(&pool_entry
->list
);
3257 qeth_free_buffer_pool(struct qeth_card
*card
)
3259 struct qeth_buffer_pool_entry
*pool_entry
, *tmp
;
3261 QETH_DBF_TEXT(trace
,5,"freepool");
3262 list_for_each_entry_safe(pool_entry
, tmp
,
3263 &card
->qdio
.init_pool
.entry_list
, init_list
){
3264 for (i
= 0; i
< QETH_MAX_BUFFER_ELEMENTS(card
); ++i
)
3265 free_page((unsigned long)pool_entry
->elements
[i
]);
3266 list_del(&pool_entry
->init_list
);
3272 qeth_alloc_buffer_pool(struct qeth_card
*card
)
3274 struct qeth_buffer_pool_entry
*pool_entry
;
3278 QETH_DBF_TEXT(trace
,5,"alocpool");
3279 for (i
= 0; i
< card
->qdio
.init_pool
.buf_count
; ++i
){
3280 pool_entry
= kmalloc(sizeof(*pool_entry
), GFP_KERNEL
);
3282 qeth_free_buffer_pool(card
);
3285 for(j
= 0; j
< QETH_MAX_BUFFER_ELEMENTS(card
); ++j
){
3286 ptr
= (void *) __get_free_page(GFP_KERNEL
|GFP_DMA
);
3289 free_page((unsigned long)
3290 pool_entry
->elements
[--j
]);
3292 qeth_free_buffer_pool(card
);
3295 pool_entry
->elements
[j
] = ptr
;
3297 list_add(&pool_entry
->init_list
,
3298 &card
->qdio
.init_pool
.entry_list
);
3304 qeth_realloc_buffer_pool(struct qeth_card
*card
, int bufcnt
)
3306 QETH_DBF_TEXT(trace
, 2, "realcbp");
3308 if ((card
->state
!= CARD_STATE_DOWN
) &&
3309 (card
->state
!= CARD_STATE_RECOVER
))
3312 /* TODO: steel/add buffers from/to a running card's buffer pool (?) */
3313 qeth_clear_working_pool_list(card
);
3314 qeth_free_buffer_pool(card
);
3315 card
->qdio
.in_buf_pool
.buf_count
= bufcnt
;
3316 card
->qdio
.init_pool
.buf_count
= bufcnt
;
3317 return qeth_alloc_buffer_pool(card
);
3321 qeth_alloc_qdio_buffers(struct qeth_card
*card
)
3325 QETH_DBF_TEXT(setup
, 2, "allcqdbf");
3327 if (atomic_cmpxchg(&card
->qdio
.state
, QETH_QDIO_UNINITIALIZED
,
3328 QETH_QDIO_ALLOCATED
) != QETH_QDIO_UNINITIALIZED
)
3331 card
->qdio
.in_q
= kmalloc(sizeof(struct qeth_qdio_q
),
3332 GFP_KERNEL
|GFP_DMA
);
3333 if (!card
->qdio
.in_q
)
3335 QETH_DBF_TEXT(setup
, 2, "inq");
3336 QETH_DBF_HEX(setup
, 2, &card
->qdio
.in_q
, sizeof(void *));
3337 memset(card
->qdio
.in_q
, 0, sizeof(struct qeth_qdio_q
));
3338 /* give inbound qeth_qdio_buffers their qdio_buffers */
3339 for (i
= 0; i
< QDIO_MAX_BUFFERS_PER_Q
; ++i
)
3340 card
->qdio
.in_q
->bufs
[i
].buffer
=
3341 &card
->qdio
.in_q
->qdio_bufs
[i
];
3342 /* inbound buffer pool */
3343 if (qeth_alloc_buffer_pool(card
))
3347 kmalloc(card
->qdio
.no_out_queues
*
3348 sizeof(struct qeth_qdio_out_q
*), GFP_KERNEL
);
3349 if (!card
->qdio
.out_qs
)
3351 for (i
= 0; i
< card
->qdio
.no_out_queues
; ++i
) {
3352 card
->qdio
.out_qs
[i
] = kmalloc(sizeof(struct qeth_qdio_out_q
),
3353 GFP_KERNEL
|GFP_DMA
);
3354 if (!card
->qdio
.out_qs
[i
])
3356 QETH_DBF_TEXT_(setup
, 2, "outq %i", i
);
3357 QETH_DBF_HEX(setup
, 2, &card
->qdio
.out_qs
[i
], sizeof(void *));
3358 memset(card
->qdio
.out_qs
[i
], 0, sizeof(struct qeth_qdio_out_q
));
3359 card
->qdio
.out_qs
[i
]->queue_no
= i
;
3360 /* give outbound qeth_qdio_buffers their qdio_buffers */
3361 for (j
= 0; j
< QDIO_MAX_BUFFERS_PER_Q
; ++j
){
3362 card
->qdio
.out_qs
[i
]->bufs
[j
].buffer
=
3363 &card
->qdio
.out_qs
[i
]->qdio_bufs
[j
];
3364 skb_queue_head_init(&card
->qdio
.out_qs
[i
]->bufs
[j
].
3367 &card
->qdio
.out_qs
[i
]->bufs
[j
].skb_list
.lock
,
3368 &qdio_out_skb_queue_key
);
3369 INIT_LIST_HEAD(&card
->qdio
.out_qs
[i
]->bufs
[j
].ctx_list
);
3376 kfree(card
->qdio
.out_qs
[--i
]);
3377 kfree(card
->qdio
.out_qs
);
3378 card
->qdio
.out_qs
= NULL
;
3380 qeth_free_buffer_pool(card
);
3382 kfree(card
->qdio
.in_q
);
3383 card
->qdio
.in_q
= NULL
;
3385 atomic_set(&card
->qdio
.state
, QETH_QDIO_UNINITIALIZED
);
3390 qeth_free_qdio_buffers(struct qeth_card
*card
)
3394 QETH_DBF_TEXT(trace
, 2, "freeqdbf");
3395 if (atomic_xchg(&card
->qdio
.state
, QETH_QDIO_UNINITIALIZED
) ==
3396 QETH_QDIO_UNINITIALIZED
)
3398 kfree(card
->qdio
.in_q
);
3399 card
->qdio
.in_q
= NULL
;
3400 /* inbound buffer pool */
3401 qeth_free_buffer_pool(card
);
3402 /* free outbound qdio_qs */
3403 if (card
->qdio
.out_qs
) {
3404 for (i
= 0; i
< card
->qdio
.no_out_queues
; ++i
) {
3405 for (j
= 0; j
< QDIO_MAX_BUFFERS_PER_Q
; ++j
)
3406 qeth_clear_output_buffer(card
->qdio
.out_qs
[i
],
3407 &card
->qdio
.out_qs
[i
]->bufs
[j
]);
3408 kfree(card
->qdio
.out_qs
[i
]);
3410 kfree(card
->qdio
.out_qs
);
3411 card
->qdio
.out_qs
= NULL
;
3416 qeth_clear_qdio_buffers(struct qeth_card
*card
)
3420 QETH_DBF_TEXT(trace
, 2, "clearqdbf");
3421 /* clear outbound buffers to free skbs */
3422 for (i
= 0; i
< card
->qdio
.no_out_queues
; ++i
)
3423 if (card
->qdio
.out_qs
&& card
->qdio
.out_qs
[i
]) {
3424 for (j
= 0; j
< QDIO_MAX_BUFFERS_PER_Q
; ++j
)
3425 qeth_clear_output_buffer(card
->qdio
.out_qs
[i
],
3426 &card
->qdio
.out_qs
[i
]->bufs
[j
]);
3431 qeth_init_qdio_info(struct qeth_card
*card
)
3433 QETH_DBF_TEXT(setup
, 4, "intqdinf");
3434 atomic_set(&card
->qdio
.state
, QETH_QDIO_UNINITIALIZED
);
3436 card
->qdio
.in_buf_size
= QETH_IN_BUF_SIZE_DEFAULT
;
3437 card
->qdio
.init_pool
.buf_count
= QETH_IN_BUF_COUNT_DEFAULT
;
3438 card
->qdio
.in_buf_pool
.buf_count
= card
->qdio
.init_pool
.buf_count
;
3439 INIT_LIST_HEAD(&card
->qdio
.in_buf_pool
.entry_list
);
3440 INIT_LIST_HEAD(&card
->qdio
.init_pool
.entry_list
);
3444 qeth_init_qdio_queues(struct qeth_card
*card
)
3449 QETH_DBF_TEXT(setup
, 2, "initqdqs");
3452 memset(card
->qdio
.in_q
->qdio_bufs
, 0,
3453 QDIO_MAX_BUFFERS_PER_Q
* sizeof(struct qdio_buffer
));
3454 qeth_initialize_working_pool_list(card
);
3455 /*give only as many buffers to hardware as we have buffer pool entries*/
3456 for (i
= 0; i
< card
->qdio
.in_buf_pool
.buf_count
- 1; ++i
)
3457 qeth_init_input_buffer(card
, &card
->qdio
.in_q
->bufs
[i
]);
3458 card
->qdio
.in_q
->next_buf_to_init
= card
->qdio
.in_buf_pool
.buf_count
- 1;
3459 rc
= do_QDIO(CARD_DDEV(card
), QDIO_FLAG_SYNC_INPUT
, 0, 0,
3460 card
->qdio
.in_buf_pool
.buf_count
- 1, NULL
);
3462 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
3465 rc
= qdio_synchronize(CARD_DDEV(card
), QDIO_FLAG_SYNC_INPUT
, 0);
3467 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
3470 /* outbound queue */
3471 for (i
= 0; i
< card
->qdio
.no_out_queues
; ++i
){
3472 memset(card
->qdio
.out_qs
[i
]->qdio_bufs
, 0,
3473 QDIO_MAX_BUFFERS_PER_Q
* sizeof(struct qdio_buffer
));
3474 for (j
= 0; j
< QDIO_MAX_BUFFERS_PER_Q
; ++j
){
3475 qeth_clear_output_buffer(card
->qdio
.out_qs
[i
],
3476 &card
->qdio
.out_qs
[i
]->bufs
[j
]);
3478 card
->qdio
.out_qs
[i
]->card
= card
;
3479 card
->qdio
.out_qs
[i
]->next_buf_to_fill
= 0;
3480 card
->qdio
.out_qs
[i
]->do_pack
= 0;
3481 atomic_set(&card
->qdio
.out_qs
[i
]->used_buffers
,0);
3482 atomic_set(&card
->qdio
.out_qs
[i
]->set_pci_flags_count
, 0);
3483 atomic_set(&card
->qdio
.out_qs
[i
]->state
,
3484 QETH_OUT_Q_UNLOCKED
);
3490 qeth_qdio_establish(struct qeth_card
*card
)
3492 struct qdio_initialize init_data
;
3493 char *qib_param_field
;
3494 struct qdio_buffer
**in_sbal_ptrs
;
3495 struct qdio_buffer
**out_sbal_ptrs
;
3499 QETH_DBF_TEXT(setup
, 2, "qdioest");
3501 qib_param_field
= kzalloc(QDIO_MAX_BUFFERS_PER_Q
* sizeof(char),
3503 if (!qib_param_field
)
3506 qeth_create_qib_param_field(card
, qib_param_field
);
3507 qeth_create_qib_param_field_blkt(card
, qib_param_field
);
3509 in_sbal_ptrs
= kmalloc(QDIO_MAX_BUFFERS_PER_Q
* sizeof(void *),
3511 if (!in_sbal_ptrs
) {
3512 kfree(qib_param_field
);
3515 for(i
= 0; i
< QDIO_MAX_BUFFERS_PER_Q
; ++i
)
3516 in_sbal_ptrs
[i
] = (struct qdio_buffer
*)
3517 virt_to_phys(card
->qdio
.in_q
->bufs
[i
].buffer
);
3520 kmalloc(card
->qdio
.no_out_queues
* QDIO_MAX_BUFFERS_PER_Q
*
3521 sizeof(void *), GFP_KERNEL
);
3522 if (!out_sbal_ptrs
) {
3523 kfree(in_sbal_ptrs
);
3524 kfree(qib_param_field
);
3527 for(i
= 0, k
= 0; i
< card
->qdio
.no_out_queues
; ++i
)
3528 for(j
= 0; j
< QDIO_MAX_BUFFERS_PER_Q
; ++j
, ++k
){
3529 out_sbal_ptrs
[k
] = (struct qdio_buffer
*)
3530 virt_to_phys(card
->qdio
.out_qs
[i
]->
3534 memset(&init_data
, 0, sizeof(struct qdio_initialize
));
3535 init_data
.cdev
= CARD_DDEV(card
);
3536 init_data
.q_format
= qeth_get_qdio_q_format(card
);
3537 init_data
.qib_param_field_format
= 0;
3538 init_data
.qib_param_field
= qib_param_field
;
3539 init_data
.min_input_threshold
= QETH_MIN_INPUT_THRESHOLD
;
3540 init_data
.max_input_threshold
= QETH_MAX_INPUT_THRESHOLD
;
3541 init_data
.min_output_threshold
= QETH_MIN_OUTPUT_THRESHOLD
;
3542 init_data
.max_output_threshold
= QETH_MAX_OUTPUT_THRESHOLD
;
3543 init_data
.no_input_qs
= 1;
3544 init_data
.no_output_qs
= card
->qdio
.no_out_queues
;
3545 init_data
.input_handler
= (qdio_handler_t
*)
3546 qeth_qdio_input_handler
;
3547 init_data
.output_handler
= (qdio_handler_t
*)
3548 qeth_qdio_output_handler
;
3549 init_data
.int_parm
= (unsigned long) card
;
3550 init_data
.flags
= QDIO_INBOUND_0COPY_SBALS
|
3551 QDIO_OUTBOUND_0COPY_SBALS
|
3552 QDIO_USE_OUTBOUND_PCIS
;
3553 init_data
.input_sbal_addr_array
= (void **) in_sbal_ptrs
;
3554 init_data
.output_sbal_addr_array
= (void **) out_sbal_ptrs
;
3556 if (atomic_cmpxchg(&card
->qdio
.state
, QETH_QDIO_ALLOCATED
,
3557 QETH_QDIO_ESTABLISHED
) == QETH_QDIO_ALLOCATED
)
3558 if ((rc
= qdio_initialize(&init_data
)))
3559 atomic_set(&card
->qdio
.state
, QETH_QDIO_ALLOCATED
);
3561 kfree(out_sbal_ptrs
);
3562 kfree(in_sbal_ptrs
);
3563 kfree(qib_param_field
);
3568 qeth_qdio_activate(struct qeth_card
*card
)
3570 QETH_DBF_TEXT(setup
,3,"qdioact");
3571 return qdio_activate(CARD_DDEV(card
), 0);
3575 qeth_clear_channel(struct qeth_channel
*channel
)
3577 unsigned long flags
;
3578 struct qeth_card
*card
;
3581 QETH_DBF_TEXT(trace
,3,"clearch");
3582 card
= CARD_FROM_CDEV(channel
->ccwdev
);
3583 spin_lock_irqsave(get_ccwdev_lock(channel
->ccwdev
), flags
);
3584 rc
= ccw_device_clear(channel
->ccwdev
, QETH_CLEAR_CHANNEL_PARM
);
3585 spin_unlock_irqrestore(get_ccwdev_lock(channel
->ccwdev
), flags
);
3589 rc
= wait_event_interruptible_timeout(card
->wait_q
,
3590 channel
->state
==CH_STATE_STOPPED
, QETH_TIMEOUT
);
3591 if (rc
== -ERESTARTSYS
)
3593 if (channel
->state
!= CH_STATE_STOPPED
)
3595 channel
->state
= CH_STATE_DOWN
;
3600 qeth_halt_channel(struct qeth_channel
*channel
)
3602 unsigned long flags
;
3603 struct qeth_card
*card
;
3606 QETH_DBF_TEXT(trace
,3,"haltch");
3607 card
= CARD_FROM_CDEV(channel
->ccwdev
);
3608 spin_lock_irqsave(get_ccwdev_lock(channel
->ccwdev
), flags
);
3609 rc
= ccw_device_halt(channel
->ccwdev
, QETH_HALT_CHANNEL_PARM
);
3610 spin_unlock_irqrestore(get_ccwdev_lock(channel
->ccwdev
), flags
);
3614 rc
= wait_event_interruptible_timeout(card
->wait_q
,
3615 channel
->state
==CH_STATE_HALTED
, QETH_TIMEOUT
);
3616 if (rc
== -ERESTARTSYS
)
3618 if (channel
->state
!= CH_STATE_HALTED
)
3624 qeth_halt_channels(struct qeth_card
*card
)
3626 int rc1
= 0, rc2
=0, rc3
= 0;
3628 QETH_DBF_TEXT(trace
,3,"haltchs");
3629 rc1
= qeth_halt_channel(&card
->read
);
3630 rc2
= qeth_halt_channel(&card
->write
);
3631 rc3
= qeth_halt_channel(&card
->data
);
3639 qeth_clear_channels(struct qeth_card
*card
)
3641 int rc1
= 0, rc2
=0, rc3
= 0;
3643 QETH_DBF_TEXT(trace
,3,"clearchs");
3644 rc1
= qeth_clear_channel(&card
->read
);
3645 rc2
= qeth_clear_channel(&card
->write
);
3646 rc3
= qeth_clear_channel(&card
->data
);
3655 qeth_clear_halt_card(struct qeth_card
*card
, int halt
)
3659 QETH_DBF_TEXT(trace
,3,"clhacrd");
3660 QETH_DBF_HEX(trace
, 3, &card
, sizeof(void *));
3663 rc
= qeth_halt_channels(card
);
3666 return qeth_clear_channels(card
);
3670 qeth_qdio_clear_card(struct qeth_card
*card
, int use_halt
)
3674 QETH_DBF_TEXT(trace
,3,"qdioclr");
3675 switch (atomic_cmpxchg(&card
->qdio
.state
, QETH_QDIO_ESTABLISHED
,
3676 QETH_QDIO_CLEANING
)) {
3677 case QETH_QDIO_ESTABLISHED
:
3678 if ((rc
= qdio_cleanup(CARD_DDEV(card
),
3679 (card
->info
.type
== QETH_CARD_TYPE_IQD
) ?
3680 QDIO_FLAG_CLEANUP_USING_HALT
:
3681 QDIO_FLAG_CLEANUP_USING_CLEAR
)))
3682 QETH_DBF_TEXT_(trace
, 3, "1err%d", rc
);
3683 atomic_set(&card
->qdio
.state
, QETH_QDIO_ALLOCATED
);
3685 case QETH_QDIO_CLEANING
:
3690 if ((rc
= qeth_clear_halt_card(card
, use_halt
)))
3691 QETH_DBF_TEXT_(trace
, 3, "2err%d", rc
);
3692 card
->state
= CARD_STATE_DOWN
;
3697 qeth_dm_act(struct qeth_card
*card
)
3700 struct qeth_cmd_buffer
*iob
;
3702 QETH_DBF_TEXT(setup
,2,"dmact");
3704 iob
= qeth_wait_for_buffer(&card
->write
);
3705 memcpy(iob
->data
, DM_ACT
, DM_ACT_SIZE
);
3707 memcpy(QETH_DM_ACT_DEST_ADDR(iob
->data
),
3708 &card
->token
.cm_connection_r
, QETH_MPC_TOKEN_LENGTH
);
3709 memcpy(QETH_DM_ACT_CONNECTION_TOKEN(iob
->data
),
3710 &card
->token
.ulp_connection_r
, QETH_MPC_TOKEN_LENGTH
);
3711 rc
= qeth_send_control_data(card
, DM_ACT_SIZE
, iob
, NULL
, NULL
);
3716 qeth_mpc_initialize(struct qeth_card
*card
)
3720 QETH_DBF_TEXT(setup
,2,"mpcinit");
3722 if ((rc
= qeth_issue_next_read(card
))){
3723 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
3726 if ((rc
= qeth_cm_enable(card
))){
3727 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
3730 if ((rc
= qeth_cm_setup(card
))){
3731 QETH_DBF_TEXT_(setup
, 2, "3err%d", rc
);
3734 if ((rc
= qeth_ulp_enable(card
))){
3735 QETH_DBF_TEXT_(setup
, 2, "4err%d", rc
);
3738 if ((rc
= qeth_ulp_setup(card
))){
3739 QETH_DBF_TEXT_(setup
, 2, "5err%d", rc
);
3742 if ((rc
= qeth_alloc_qdio_buffers(card
))){
3743 QETH_DBF_TEXT_(setup
, 2, "5err%d", rc
);
3746 if ((rc
= qeth_qdio_establish(card
))){
3747 QETH_DBF_TEXT_(setup
, 2, "6err%d", rc
);
3748 qeth_free_qdio_buffers(card
);
3751 if ((rc
= qeth_qdio_activate(card
))){
3752 QETH_DBF_TEXT_(setup
, 2, "7err%d", rc
);
3755 if ((rc
= qeth_dm_act(card
))){
3756 QETH_DBF_TEXT_(setup
, 2, "8err%d", rc
);
3762 qeth_qdio_clear_card(card
, card
->info
.type
!=QETH_CARD_TYPE_IQD
);
3766 static struct net_device
*
3767 qeth_get_netdevice(enum qeth_card_types type
, enum qeth_link_types linktype
)
3769 struct net_device
*dev
= NULL
;
3772 case QETH_CARD_TYPE_OSAE
:
3774 case QETH_LINK_TYPE_LANE_TR
:
3775 case QETH_LINK_TYPE_HSTR
:
3777 dev
= alloc_trdev(0);
3778 #endif /* CONFIG_TR */
3781 dev
= alloc_etherdev(0);
3784 case QETH_CARD_TYPE_IQD
:
3785 dev
= alloc_netdev(0, "hsi%d", ether_setup
);
3787 case QETH_CARD_TYPE_OSN
:
3788 dev
= alloc_netdev(0, "osn%d", ether_setup
);
3791 dev
= alloc_etherdev(0);
3796 /*hard_header fake function; used in case fake_ll is set */
3798 qeth_fake_header(struct sk_buff
*skb
, struct net_device
*dev
,
3799 unsigned short type
, const void *daddr
, const void *saddr
,
3802 if(dev
->type
== ARPHRD_IEEE802_TR
){
3803 struct trh_hdr
*hdr
;
3804 hdr
= (struct trh_hdr
*)skb_push(skb
, QETH_FAKE_LL_LEN_TR
);
3805 memcpy(hdr
->saddr
, dev
->dev_addr
, TR_ALEN
);
3806 memcpy(hdr
->daddr
, "FAKELL", TR_ALEN
);
3807 return QETH_FAKE_LL_LEN_TR
;
3811 hdr
= (struct ethhdr
*)skb_push(skb
, QETH_FAKE_LL_LEN_ETH
);
3812 memcpy(hdr
->h_source
, dev
->dev_addr
, ETH_ALEN
);
3813 memcpy(hdr
->h_dest
, "FAKELL", ETH_ALEN
);
3814 if (type
!= ETH_P_802_3
)
3815 hdr
->h_proto
= htons(type
);
3817 hdr
->h_proto
= htons(len
);
3818 return QETH_FAKE_LL_LEN_ETH
;
3823 static const struct header_ops qeth_fake_ops
= {
3824 .create
= qeth_fake_header
,
3825 .parse
= qeth_hard_header_parse
,
3829 qeth_send_packet(struct qeth_card
*, struct sk_buff
*);
3832 qeth_hard_start_xmit(struct sk_buff
*skb
, struct net_device
*dev
)
3835 struct qeth_card
*card
;
3837 QETH_DBF_TEXT(trace
, 6, "hrdstxmi");
3838 card
= (struct qeth_card
*)dev
->priv
;
3840 card
->stats
.tx_dropped
++;
3841 card
->stats
.tx_errors
++;
3842 /* return OK; otherwise ksoftirqd goes to 100% */
3843 return NETDEV_TX_OK
;
3845 if ((card
->state
!= CARD_STATE_UP
) || !card
->lan_online
) {
3846 card
->stats
.tx_dropped
++;
3847 card
->stats
.tx_errors
++;
3848 card
->stats
.tx_carrier_errors
++;
3849 dev_kfree_skb_any(skb
);
3850 /* return OK; otherwise ksoftirqd goes to 100% */
3851 return NETDEV_TX_OK
;
3853 if (card
->options
.performance_stats
) {
3854 card
->perf_stats
.outbound_cnt
++;
3855 card
->perf_stats
.outbound_start_time
= qeth_get_micros();
3857 netif_stop_queue(dev
);
3858 if ((rc
= qeth_send_packet(card
, skb
))) {
3860 return NETDEV_TX_BUSY
;
3862 card
->stats
.tx_errors
++;
3863 card
->stats
.tx_dropped
++;
3864 dev_kfree_skb_any(skb
);
3865 /*set to OK; otherwise ksoftirqd goes to 100% */
3869 netif_wake_queue(dev
);
3870 if (card
->options
.performance_stats
)
3871 card
->perf_stats
.outbound_time
+= qeth_get_micros() -
3872 card
->perf_stats
.outbound_start_time
;
3877 qeth_verify_vlan_dev(struct net_device
*dev
, struct qeth_card
*card
)
3880 #ifdef CONFIG_QETH_VLAN
3881 struct vlan_group
*vg
;
3884 if (!(vg
= card
->vlangrp
))
3887 for (i
= 0; i
< VLAN_GROUP_ARRAY_LEN
; i
++){
3888 if (vlan_group_get_device(vg
, i
) == dev
){
3889 rc
= QETH_VLAN_CARD
;
3893 if (rc
&& !(vlan_dev_info(dev
)->real_dev
->priv
== (void *)card
))
3901 qeth_verify_dev(struct net_device
*dev
)
3903 struct qeth_card
*card
;
3904 unsigned long flags
;
3907 read_lock_irqsave(&qeth_card_list
.rwlock
, flags
);
3908 list_for_each_entry(card
, &qeth_card_list
.list
, list
){
3909 if (card
->dev
== dev
){
3910 rc
= QETH_REAL_CARD
;
3913 rc
= qeth_verify_vlan_dev(dev
, card
);
3917 read_unlock_irqrestore(&qeth_card_list
.rwlock
, flags
);
3922 static struct qeth_card
*
3923 qeth_get_card_from_dev(struct net_device
*dev
)
3925 struct qeth_card
*card
= NULL
;
3928 rc
= qeth_verify_dev(dev
);
3929 if (rc
== QETH_REAL_CARD
)
3930 card
= (struct qeth_card
*)dev
->priv
;
3931 else if (rc
== QETH_VLAN_CARD
)
3932 card
= (struct qeth_card
*)
3933 vlan_dev_info(dev
)->real_dev
->priv
;
3935 QETH_DBF_TEXT_(trace
, 4, "%d", rc
);
3940 qeth_tx_timeout(struct net_device
*dev
)
3942 struct qeth_card
*card
;
3944 card
= (struct qeth_card
*) dev
->priv
;
3945 card
->stats
.tx_errors
++;
3946 qeth_schedule_recovery(card
);
3950 qeth_open(struct net_device
*dev
)
3952 struct qeth_card
*card
;
3954 QETH_DBF_TEXT(trace
, 4, "qethopen");
3956 card
= (struct qeth_card
*) dev
->priv
;
3958 if (card
->state
!= CARD_STATE_SOFTSETUP
)
3961 if ( (card
->info
.type
!= QETH_CARD_TYPE_OSN
) &&
3962 (card
->options
.layer2
) &&
3963 (!(card
->info
.mac_bits
& QETH_LAYER2_MAC_REGISTERED
))) {
3964 QETH_DBF_TEXT(trace
,4,"nomacadr");
3967 card
->data
.state
= CH_STATE_UP
;
3968 card
->state
= CARD_STATE_UP
;
3969 card
->dev
->flags
|= IFF_UP
;
3970 netif_start_queue(dev
);
3972 if (!card
->lan_online
&& netif_carrier_ok(dev
))
3973 netif_carrier_off(dev
);
3978 qeth_stop(struct net_device
*dev
)
3980 struct qeth_card
*card
;
3982 QETH_DBF_TEXT(trace
, 4, "qethstop");
3984 card
= (struct qeth_card
*) dev
->priv
;
3986 netif_tx_disable(dev
);
3987 card
->dev
->flags
&= ~IFF_UP
;
3988 if (card
->state
== CARD_STATE_UP
)
3989 card
->state
= CARD_STATE_SOFTSETUP
;
3994 qeth_get_cast_type(struct qeth_card
*card
, struct sk_buff
*skb
)
3996 int cast_type
= RTN_UNSPEC
;
3998 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
4001 if (skb
->dst
&& skb
->dst
->neighbour
){
4002 cast_type
= skb
->dst
->neighbour
->type
;
4003 if ((cast_type
== RTN_BROADCAST
) ||
4004 (cast_type
== RTN_MULTICAST
) ||
4005 (cast_type
== RTN_ANYCAST
))
4010 /* try something else */
4011 if (skb
->protocol
== ETH_P_IPV6
)
4012 return (skb_network_header(skb
)[24] == 0xff) ?
4014 else if (skb
->protocol
== ETH_P_IP
)
4015 return ((skb_network_header(skb
)[16] & 0xf0) == 0xe0) ?
4018 if (!memcmp(skb
->data
, skb
->dev
->broadcast
, 6))
4019 return RTN_BROADCAST
;
4023 hdr_mac
= *((u16
*)skb
->data
);
4025 switch (card
->info
.link_type
) {
4026 case QETH_LINK_TYPE_HSTR
:
4027 case QETH_LINK_TYPE_LANE_TR
:
4028 if ((hdr_mac
== QETH_TR_MAC_NC
) ||
4029 (hdr_mac
== QETH_TR_MAC_C
))
4030 return RTN_MULTICAST
;
4032 /* eth or so multicast? */
4034 if ((hdr_mac
== QETH_ETH_MAC_V4
) ||
4035 (hdr_mac
== QETH_ETH_MAC_V6
))
4036 return RTN_MULTICAST
;
4043 qeth_get_priority_queue(struct qeth_card
*card
, struct sk_buff
*skb
,
4044 int ipv
, int cast_type
)
4046 if (!ipv
&& (card
->info
.type
== QETH_CARD_TYPE_OSAE
))
4047 return card
->qdio
.default_out_queue
;
4048 switch (card
->qdio
.no_out_queues
) {
4050 if (cast_type
&& card
->info
.is_multicast_different
)
4051 return card
->info
.is_multicast_different
&
4052 (card
->qdio
.no_out_queues
- 1);
4053 if (card
->qdio
.do_prio_queueing
&& (ipv
== 4)) {
4054 const u8 tos
= ip_hdr(skb
)->tos
;
4056 if (card
->qdio
.do_prio_queueing
==QETH_PRIO_Q_ING_TOS
){
4057 if (tos
& IP_TOS_NOTIMPORTANT
)
4059 if (tos
& IP_TOS_HIGHRELIABILITY
)
4061 if (tos
& IP_TOS_HIGHTHROUGHPUT
)
4063 if (tos
& IP_TOS_LOWDELAY
)
4066 if (card
->qdio
.do_prio_queueing
==QETH_PRIO_Q_ING_PREC
)
4067 return 3 - (tos
>> 6);
4068 } else if (card
->qdio
.do_prio_queueing
&& (ipv
== 6)) {
4071 return card
->qdio
.default_out_queue
;
4072 case 1: /* fallthrough for single-out-queue 1920-device */
4074 return card
->qdio
.default_out_queue
;
4079 qeth_get_ip_version(struct sk_buff
*skb
)
4081 switch (skb
->protocol
) {
4091 static struct qeth_hdr
*
4092 __qeth_prepare_skb(struct qeth_card
*card
, struct sk_buff
*skb
, int ipv
)
4094 #ifdef CONFIG_QETH_VLAN
4096 if (card
->vlangrp
&& vlan_tx_tag_present(skb
) &&
4097 ((ipv
== 6) || card
->options
.layer2
) ) {
4099 * Move the mac addresses (6 bytes src, 6 bytes dest)
4100 * to the beginning of the new header. We are using three
4101 * memcpys instead of one memmove to save cycles.
4103 skb_push(skb
, VLAN_HLEN
);
4104 skb_copy_to_linear_data(skb
, skb
->data
+ 4, 4);
4105 skb_copy_to_linear_data_offset(skb
, 4, skb
->data
+ 8, 4);
4106 skb_copy_to_linear_data_offset(skb
, 8, skb
->data
+ 12, 4);
4107 tag
= (u16
*)(skb
->data
+ 12);
4109 * first two bytes = ETH_P_8021Q (0x8100)
4110 * second two bytes = VLANID
4112 *tag
= __constant_htons(ETH_P_8021Q
);
4113 *(tag
+ 1) = htons(vlan_tx_tag_get(skb
));
4116 return ((struct qeth_hdr
*)
4117 qeth_push_skb(card
, skb
, sizeof(struct qeth_hdr
)));
4121 __qeth_free_new_skb(struct sk_buff
*orig_skb
, struct sk_buff
*new_skb
)
4123 if (orig_skb
!= new_skb
)
4124 dev_kfree_skb_any(new_skb
);
4127 static struct sk_buff
*
4128 qeth_prepare_skb(struct qeth_card
*card
, struct sk_buff
*skb
,
4129 struct qeth_hdr
**hdr
, int ipv
)
4131 struct sk_buff
*new_skb
, *new_skb2
;
4133 QETH_DBF_TEXT(trace
, 6, "prepskb");
4135 new_skb
= qeth_pskb_unshare(skb
, GFP_ATOMIC
);
4138 new_skb2
= qeth_realloc_headroom(card
, new_skb
,
4139 sizeof(struct qeth_hdr
));
4141 __qeth_free_new_skb(skb
, new_skb
);
4145 __qeth_free_new_skb(new_skb2
, new_skb
);
4147 *hdr
= __qeth_prepare_skb(card
, new_skb
, ipv
);
4149 __qeth_free_new_skb(skb
, new_skb
);
4156 qeth_get_qeth_hdr_flags4(int cast_type
)
4158 if (cast_type
== RTN_MULTICAST
)
4159 return QETH_CAST_MULTICAST
;
4160 if (cast_type
== RTN_BROADCAST
)
4161 return QETH_CAST_BROADCAST
;
4162 return QETH_CAST_UNICAST
;
4166 qeth_get_qeth_hdr_flags6(int cast_type
)
4168 u8 ct
= QETH_HDR_PASSTHRU
| QETH_HDR_IPV6
;
4169 if (cast_type
== RTN_MULTICAST
)
4170 return ct
| QETH_CAST_MULTICAST
;
4171 if (cast_type
== RTN_ANYCAST
)
4172 return ct
| QETH_CAST_ANYCAST
;
4173 if (cast_type
== RTN_BROADCAST
)
4174 return ct
| QETH_CAST_BROADCAST
;
4175 return ct
| QETH_CAST_UNICAST
;
4179 qeth_layer2_get_packet_type(struct qeth_card
*card
, struct qeth_hdr
*hdr
,
4180 struct sk_buff
*skb
)
4184 if (!memcmp(skb
->data
+QETH_HEADER_SIZE
,
4185 skb
->dev
->broadcast
,6)) { /* broadcast? */
4186 *(__u32
*)hdr
->hdr
.l2
.flags
|=
4187 QETH_LAYER2_FLAG_BROADCAST
<< 8;
4190 hdr_mac
=*((__u16
*)skb
->data
);
4192 switch (card
->info
.link_type
) {
4193 case QETH_LINK_TYPE_HSTR
:
4194 case QETH_LINK_TYPE_LANE_TR
:
4195 if ((hdr_mac
== QETH_TR_MAC_NC
) ||
4196 (hdr_mac
== QETH_TR_MAC_C
) )
4197 *(__u32
*)hdr
->hdr
.l2
.flags
|=
4198 QETH_LAYER2_FLAG_MULTICAST
<< 8;
4200 *(__u32
*)hdr
->hdr
.l2
.flags
|=
4201 QETH_LAYER2_FLAG_UNICAST
<< 8;
4203 /* eth or so multicast? */
4205 if ( (hdr_mac
==QETH_ETH_MAC_V4
) ||
4206 (hdr_mac
==QETH_ETH_MAC_V6
) )
4207 *(__u32
*)hdr
->hdr
.l2
.flags
|=
4208 QETH_LAYER2_FLAG_MULTICAST
<< 8;
4210 *(__u32
*)hdr
->hdr
.l2
.flags
|=
4211 QETH_LAYER2_FLAG_UNICAST
<< 8;
4216 qeth_layer2_fill_header(struct qeth_card
*card
, struct qeth_hdr
*hdr
,
4217 struct sk_buff
*skb
, int cast_type
)
4219 memset(hdr
, 0, sizeof(struct qeth_hdr
));
4220 hdr
->hdr
.l2
.id
= QETH_HEADER_TYPE_LAYER2
;
4222 /* set byte 0 to "0x02" and byte 3 to casting flags */
4223 if (cast_type
==RTN_MULTICAST
)
4224 *(__u32
*)hdr
->hdr
.l2
.flags
|= QETH_LAYER2_FLAG_MULTICAST
<< 8;
4225 else if (cast_type
==RTN_BROADCAST
)
4226 *(__u32
*)hdr
->hdr
.l2
.flags
|= QETH_LAYER2_FLAG_BROADCAST
<< 8;
4228 qeth_layer2_get_packet_type(card
, hdr
, skb
);
4230 hdr
->hdr
.l2
.pkt_length
= skb
->len
-QETH_HEADER_SIZE
;
4231 #ifdef CONFIG_QETH_VLAN
4232 /* VSWITCH relies on the VLAN
4233 * information to be present in
4234 * the QDIO header */
4235 if ((card
->vlangrp
!= NULL
) &&
4236 vlan_tx_tag_present(skb
)) {
4237 *(__u32
*)hdr
->hdr
.l2
.flags
|= QETH_LAYER2_FLAG_VLAN
<< 8;
4238 hdr
->hdr
.l2
.vlan_id
= vlan_tx_tag_get(skb
);
4244 qeth_fill_header(struct qeth_card
*card
, struct qeth_hdr
*hdr
,
4245 struct sk_buff
*skb
, int ipv
, int cast_type
)
4247 QETH_DBF_TEXT(trace
, 6, "fillhdr");
4249 memset(hdr
, 0, sizeof(struct qeth_hdr
));
4250 if (card
->options
.layer2
) {
4251 qeth_layer2_fill_header(card
, hdr
, skb
, cast_type
);
4254 hdr
->hdr
.l3
.id
= QETH_HEADER_TYPE_LAYER3
;
4255 hdr
->hdr
.l3
.ext_flags
= 0;
4256 #ifdef CONFIG_QETH_VLAN
4258 * before we're going to overwrite this location with next hop ip.
4259 * v6 uses passthrough, v4 sets the tag in the QDIO header.
4261 if (card
->vlangrp
&& vlan_tx_tag_present(skb
)) {
4262 hdr
->hdr
.l3
.ext_flags
= (ipv
== 4) ?
4263 QETH_HDR_EXT_VLAN_FRAME
:
4264 QETH_HDR_EXT_INCLUDE_VLAN_TAG
;
4265 hdr
->hdr
.l3
.vlan_id
= vlan_tx_tag_get(skb
);
4267 #endif /* CONFIG_QETH_VLAN */
4268 hdr
->hdr
.l3
.length
= skb
->len
- sizeof(struct qeth_hdr
);
4269 if (ipv
== 4) { /* IPv4 */
4270 hdr
->hdr
.l3
.flags
= qeth_get_qeth_hdr_flags4(cast_type
);
4271 memset(hdr
->hdr
.l3
.dest_addr
, 0, 12);
4272 if ((skb
->dst
) && (skb
->dst
->neighbour
)) {
4273 *((u32
*) (&hdr
->hdr
.l3
.dest_addr
[12])) =
4274 *((u32
*) skb
->dst
->neighbour
->primary_key
);
4276 /* fill in destination address used in ip header */
4277 *((u32
*)(&hdr
->hdr
.l3
.dest_addr
[12])) =
4280 } else if (ipv
== 6) { /* IPv6 or passthru */
4281 hdr
->hdr
.l3
.flags
= qeth_get_qeth_hdr_flags6(cast_type
);
4282 if ((skb
->dst
) && (skb
->dst
->neighbour
)) {
4283 memcpy(hdr
->hdr
.l3
.dest_addr
,
4284 skb
->dst
->neighbour
->primary_key
, 16);
4286 /* fill in destination address used in ip header */
4287 memcpy(hdr
->hdr
.l3
.dest_addr
,
4288 &ipv6_hdr(skb
)->daddr
, 16);
4290 } else { /* passthrough */
4291 if((skb
->dev
->type
== ARPHRD_IEEE802_TR
) &&
4292 !memcmp(skb
->data
+ sizeof(struct qeth_hdr
) +
4293 sizeof(__u16
), skb
->dev
->broadcast
, 6)) {
4294 hdr
->hdr
.l3
.flags
= QETH_CAST_BROADCAST
|
4296 } else if (!memcmp(skb
->data
+ sizeof(struct qeth_hdr
),
4297 skb
->dev
->broadcast
, 6)) { /* broadcast? */
4298 hdr
->hdr
.l3
.flags
= QETH_CAST_BROADCAST
|
4301 hdr
->hdr
.l3
.flags
= (cast_type
== RTN_MULTICAST
) ?
4302 QETH_CAST_MULTICAST
| QETH_HDR_PASSTHRU
:
4303 QETH_CAST_UNICAST
| QETH_HDR_PASSTHRU
;
4309 __qeth_fill_buffer(struct sk_buff
*skb
, struct qdio_buffer
*buffer
,
4310 int is_tso
, int *next_element_to_fill
)
4312 int length
= skb
->len
;
4318 element
= *next_element_to_fill
;
4320 first_lap
= (is_tso
== 0 ? 1 : 0);
4322 while (length
> 0) {
4323 /* length_here is the remaining amount of data in this page */
4324 length_here
= PAGE_SIZE
- ((unsigned long) data
% PAGE_SIZE
);
4325 if (length
< length_here
)
4326 length_here
= length
;
4328 buffer
->element
[element
].addr
= data
;
4329 buffer
->element
[element
].length
= length_here
;
4330 length
-= length_here
;
4333 buffer
->element
[element
].flags
= 0;
4335 buffer
->element
[element
].flags
=
4336 SBAL_FLAGS_LAST_FRAG
;
4339 buffer
->element
[element
].flags
=
4340 SBAL_FLAGS_FIRST_FRAG
;
4342 buffer
->element
[element
].flags
=
4343 SBAL_FLAGS_MIDDLE_FRAG
;
4345 data
+= length_here
;
4349 *next_element_to_fill
= element
;
4353 qeth_fill_buffer(struct qeth_qdio_out_q
*queue
,
4354 struct qeth_qdio_out_buffer
*buf
,
4355 struct sk_buff
*skb
)
4357 struct qdio_buffer
*buffer
;
4358 struct qeth_hdr_tso
*hdr
;
4359 int flush_cnt
= 0, hdr_len
, large_send
= 0;
4361 QETH_DBF_TEXT(trace
, 6, "qdfillbf");
4363 buffer
= buf
->buffer
;
4364 atomic_inc(&skb
->users
);
4365 skb_queue_tail(&buf
->skb_list
, skb
);
4367 hdr
= (struct qeth_hdr_tso
*) skb
->data
;
4368 /*check first on TSO ....*/
4369 if (hdr
->hdr
.hdr
.l3
.id
== QETH_HEADER_TYPE_TSO
) {
4370 int element
= buf
->next_element_to_fill
;
4372 hdr_len
= sizeof(struct qeth_hdr_tso
) + hdr
->ext
.dg_hdr_len
;
4373 /*fill first buffer entry only with header information */
4374 buffer
->element
[element
].addr
= skb
->data
;
4375 buffer
->element
[element
].length
= hdr_len
;
4376 buffer
->element
[element
].flags
= SBAL_FLAGS_FIRST_FRAG
;
4377 buf
->next_element_to_fill
++;
4378 skb
->data
+= hdr_len
;
4379 skb
->len
-= hdr_len
;
4382 if (skb_shinfo(skb
)->nr_frags
== 0)
4383 __qeth_fill_buffer(skb
, buffer
, large_send
,
4384 (int *)&buf
->next_element_to_fill
);
4386 __qeth_fill_buffer_frag(skb
, buffer
, large_send
,
4387 (int *)&buf
->next_element_to_fill
);
4389 if (!queue
->do_pack
) {
4390 QETH_DBF_TEXT(trace
, 6, "fillbfnp");
4391 /* set state to PRIMED -> will be flushed */
4392 atomic_set(&buf
->state
, QETH_QDIO_BUF_PRIMED
);
4395 QETH_DBF_TEXT(trace
, 6, "fillbfpa");
4396 if (queue
->card
->options
.performance_stats
)
4397 queue
->card
->perf_stats
.skbs_sent_pack
++;
4398 if (buf
->next_element_to_fill
>=
4399 QETH_MAX_BUFFER_ELEMENTS(queue
->card
)) {
4401 * packed buffer if full -> set state PRIMED
4402 * -> will be flushed
4404 atomic_set(&buf
->state
, QETH_QDIO_BUF_PRIMED
);
4412 qeth_do_send_packet_fast(struct qeth_card
*card
, struct qeth_qdio_out_q
*queue
,
4413 struct sk_buff
*skb
, struct qeth_hdr
*hdr
,
4414 int elements_needed
,
4415 struct qeth_eddp_context
*ctx
)
4417 struct qeth_qdio_out_buffer
*buffer
;
4418 int buffers_needed
= 0;
4422 QETH_DBF_TEXT(trace
, 6, "dosndpfa");
4424 /* spin until we get the queue ... */
4425 while (atomic_cmpxchg(&queue
->state
, QETH_OUT_Q_UNLOCKED
,
4426 QETH_OUT_Q_LOCKED
) != QETH_OUT_Q_UNLOCKED
);
4427 /* ... now we've got the queue */
4428 index
= queue
->next_buf_to_fill
;
4429 buffer
= &queue
->bufs
[queue
->next_buf_to_fill
];
4431 * check if buffer is empty to make sure that we do not 'overtake'
4432 * ourselves and try to fill a buffer that is already primed
4434 if (atomic_read(&buffer
->state
) != QETH_QDIO_BUF_EMPTY
)
4437 queue
->next_buf_to_fill
= (queue
->next_buf_to_fill
+ 1) %
4438 QDIO_MAX_BUFFERS_PER_Q
;
4440 buffers_needed
= qeth_eddp_check_buffers_for_context(queue
,ctx
);
4441 if (buffers_needed
< 0)
4443 queue
->next_buf_to_fill
=
4444 (queue
->next_buf_to_fill
+ buffers_needed
) %
4445 QDIO_MAX_BUFFERS_PER_Q
;
4447 atomic_set(&queue
->state
, QETH_OUT_Q_UNLOCKED
);
4449 qeth_fill_buffer(queue
, buffer
, skb
);
4450 qeth_flush_buffers(queue
, 0, index
, 1);
4452 flush_cnt
= qeth_eddp_fill_buffer(queue
, ctx
, index
);
4453 WARN_ON(buffers_needed
!= flush_cnt
);
4454 qeth_flush_buffers(queue
, 0, index
, flush_cnt
);
4458 atomic_set(&queue
->state
, QETH_OUT_Q_UNLOCKED
);
4463 qeth_do_send_packet(struct qeth_card
*card
, struct qeth_qdio_out_q
*queue
,
4464 struct sk_buff
*skb
, struct qeth_hdr
*hdr
,
4465 int elements_needed
, struct qeth_eddp_context
*ctx
)
4467 struct qeth_qdio_out_buffer
*buffer
;
4469 int flush_count
= 0;
4474 QETH_DBF_TEXT(trace
, 6, "dosndpkt");
4476 /* spin until we get the queue ... */
4477 while (atomic_cmpxchg(&queue
->state
, QETH_OUT_Q_UNLOCKED
,
4478 QETH_OUT_Q_LOCKED
) != QETH_OUT_Q_UNLOCKED
);
4479 start_index
= queue
->next_buf_to_fill
;
4480 buffer
= &queue
->bufs
[queue
->next_buf_to_fill
];
4482 * check if buffer is empty to make sure that we do not 'overtake'
4483 * ourselves and try to fill a buffer that is already primed
4485 if (atomic_read(&buffer
->state
) != QETH_QDIO_BUF_EMPTY
) {
4486 atomic_set(&queue
->state
, QETH_OUT_Q_UNLOCKED
);
4489 /* check if we need to switch packing state of this queue */
4490 qeth_switch_to_packing_if_needed(queue
);
4491 if (queue
->do_pack
){
4494 /* does packet fit in current buffer? */
4495 if((QETH_MAX_BUFFER_ELEMENTS(card
) -
4496 buffer
->next_element_to_fill
) < elements_needed
){
4497 /* ... no -> set state PRIMED */
4498 atomic_set(&buffer
->state
,QETH_QDIO_BUF_PRIMED
);
4500 queue
->next_buf_to_fill
=
4501 (queue
->next_buf_to_fill
+ 1) %
4502 QDIO_MAX_BUFFERS_PER_Q
;
4503 buffer
= &queue
->bufs
[queue
->next_buf_to_fill
];
4504 /* we did a step forward, so check buffer state
4506 if (atomic_read(&buffer
->state
) !=
4507 QETH_QDIO_BUF_EMPTY
){
4508 qeth_flush_buffers(queue
, 0, start_index
, flush_count
);
4509 atomic_set(&queue
->state
, QETH_OUT_Q_UNLOCKED
);
4514 /* check if we have enough elements (including following
4515 * free buffers) to handle eddp context */
4516 if (qeth_eddp_check_buffers_for_context(queue
,ctx
) < 0){
4517 if (net_ratelimit())
4518 PRINT_WARN("eddp tx_dropped 1\n");
4525 tmp
= qeth_fill_buffer(queue
, buffer
, skb
);
4527 tmp
= qeth_eddp_fill_buffer(queue
,ctx
,queue
->next_buf_to_fill
);
4529 printk("eddp tx_dropped 2\n");
4534 queue
->next_buf_to_fill
= (queue
->next_buf_to_fill
+ tmp
) %
4535 QDIO_MAX_BUFFERS_PER_Q
;
4539 qeth_flush_buffers(queue
, 0, start_index
, flush_count
);
4540 else if (!atomic_read(&queue
->set_pci_flags_count
))
4541 atomic_xchg(&queue
->state
, QETH_OUT_Q_LOCKED_FLUSH
);
4543 * queue->state will go from LOCKED -> UNLOCKED or from
4544 * LOCKED_FLUSH -> LOCKED if output_handler wanted to 'notify' us
4545 * (switch packing state or flush buffer to get another pci flag out).
4546 * In that case we will enter this loop
4548 while (atomic_dec_return(&queue
->state
)){
4550 start_index
= queue
->next_buf_to_fill
;
4551 /* check if we can go back to non-packing state */
4552 flush_count
+= qeth_switch_to_nonpacking_if_needed(queue
);
4554 * check if we need to flush a packing buffer to get a pci
4555 * flag out on the queue
4557 if (!flush_count
&& !atomic_read(&queue
->set_pci_flags_count
))
4558 flush_count
+= qeth_flush_buffers_on_no_pci(queue
);
4560 qeth_flush_buffers(queue
, 0, start_index
, flush_count
);
4562 /* at this point the queue is UNLOCKED again */
4563 if (queue
->card
->options
.performance_stats
&& do_pack
)
4564 queue
->card
->perf_stats
.bufs_sent_pack
+= flush_count
;
4570 qeth_get_elements_no(struct qeth_card
*card
, void *hdr
,
4571 struct sk_buff
*skb
, int elems
)
4573 int elements_needed
= 0;
4575 if (skb_shinfo(skb
)->nr_frags
> 0)
4576 elements_needed
= (skb_shinfo(skb
)->nr_frags
+ 1);
4577 if (elements_needed
== 0)
4578 elements_needed
= 1 + (((((unsigned long) hdr
) % PAGE_SIZE
)
4579 + skb
->len
) >> PAGE_SHIFT
);
4580 if ((elements_needed
+ elems
) > QETH_MAX_BUFFER_ELEMENTS(card
)){
4581 PRINT_ERR("Invalid size of IP packet "
4582 "(Number=%d / Length=%d). Discarded.\n",
4583 (elements_needed
+elems
), skb
->len
);
4586 return elements_needed
;
4589 static void qeth_tx_csum(struct sk_buff
*skb
)
4593 if (skb
->protocol
== htons(ETH_P_IP
)) {
4594 tlen
= ntohs(ip_hdr(skb
)->tot_len
) - (ip_hdr(skb
)->ihl
<< 2);
4595 switch (ip_hdr(skb
)->protocol
) {
4597 tcp_hdr(skb
)->check
= 0;
4598 tcp_hdr(skb
)->check
= csum_tcpudp_magic(
4599 ip_hdr(skb
)->saddr
, ip_hdr(skb
)->daddr
,
4600 tlen
, ip_hdr(skb
)->protocol
,
4601 skb_checksum(skb
, skb_transport_offset(skb
),
4605 udp_hdr(skb
)->check
= 0;
4606 udp_hdr(skb
)->check
= csum_tcpudp_magic(
4607 ip_hdr(skb
)->saddr
, ip_hdr(skb
)->daddr
,
4608 tlen
, ip_hdr(skb
)->protocol
,
4609 skb_checksum(skb
, skb_transport_offset(skb
),
4613 } else if (skb
->protocol
== htons(ETH_P_IPV6
)) {
4614 switch (ipv6_hdr(skb
)->nexthdr
) {
4616 tcp_hdr(skb
)->check
= 0;
4617 tcp_hdr(skb
)->check
= csum_ipv6_magic(
4618 &ipv6_hdr(skb
)->saddr
, &ipv6_hdr(skb
)->daddr
,
4619 ipv6_hdr(skb
)->payload_len
,
4620 ipv6_hdr(skb
)->nexthdr
,
4621 skb_checksum(skb
, skb_transport_offset(skb
),
4622 ipv6_hdr(skb
)->payload_len
, 0));
4625 udp_hdr(skb
)->check
= 0;
4626 udp_hdr(skb
)->check
= csum_ipv6_magic(
4627 &ipv6_hdr(skb
)->saddr
, &ipv6_hdr(skb
)->daddr
,
4628 ipv6_hdr(skb
)->payload_len
,
4629 ipv6_hdr(skb
)->nexthdr
,
4630 skb_checksum(skb
, skb_transport_offset(skb
),
4631 ipv6_hdr(skb
)->payload_len
, 0));
4638 qeth_send_packet(struct qeth_card
*card
, struct sk_buff
*skb
)
4642 struct qeth_qdio_out_q
*queue
;
4643 struct qeth_hdr
*hdr
= NULL
;
4644 int elements_needed
= 0;
4645 enum qeth_large_send_types large_send
= QETH_LARGE_SEND_NO
;
4646 struct qeth_eddp_context
*ctx
= NULL
;
4647 int tx_bytes
= skb
->len
;
4648 unsigned short nr_frags
= skb_shinfo(skb
)->nr_frags
;
4649 unsigned short tso_size
= skb_shinfo(skb
)->gso_size
;
4650 struct sk_buff
*new_skb
, *new_skb2
;
4653 QETH_DBF_TEXT(trace
, 6, "sendpkt");
4656 if ((card
->info
.type
== QETH_CARD_TYPE_OSN
) &&
4657 (skb
->protocol
== htons(ETH_P_IPV6
)))
4659 cast_type
= qeth_get_cast_type(card
, skb
);
4660 if ((cast_type
== RTN_BROADCAST
) &&
4661 (card
->info
.broadcast_capable
== 0))
4663 queue
= card
->qdio
.out_qs
4664 [qeth_get_priority_queue(card
, skb
, ipv
, cast_type
)];
4665 if (!card
->options
.layer2
) {
4666 ipv
= qeth_get_ip_version(skb
);
4667 if ((card
->dev
->header_ops
== &qeth_fake_ops
) && ipv
) {
4668 new_skb
= qeth_pskb_unshare(skb
, GFP_ATOMIC
);
4671 if(card
->dev
->type
== ARPHRD_IEEE802_TR
){
4672 skb_pull(new_skb
, QETH_FAKE_LL_LEN_TR
);
4674 skb_pull(new_skb
, QETH_FAKE_LL_LEN_ETH
);
4678 if (skb_is_gso(skb
))
4679 large_send
= card
->options
.large_send
;
4680 /* check on OSN device*/
4681 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
4682 hdr
= (struct qeth_hdr
*)new_skb
->data
;
4683 /*are we able to do TSO ? */
4684 if ((large_send
== QETH_LARGE_SEND_TSO
) &&
4685 (cast_type
== RTN_UNSPEC
)) {
4686 rc
= qeth_tso_prepare_packet(card
, new_skb
, ipv
, cast_type
);
4688 __qeth_free_new_skb(skb
, new_skb
);
4692 } else if (card
->info
.type
!= QETH_CARD_TYPE_OSN
) {
4693 new_skb2
= qeth_prepare_skb(card
, new_skb
, &hdr
, ipv
);
4695 __qeth_free_new_skb(skb
, new_skb
);
4699 __qeth_free_new_skb(new_skb2
, new_skb
);
4701 qeth_fill_header(card
, hdr
, new_skb
, ipv
, cast_type
);
4703 if (large_send
== QETH_LARGE_SEND_EDDP
) {
4704 ctx
= qeth_eddp_create_context(card
, new_skb
, hdr
,
4705 skb
->sk
->sk_protocol
);
4707 __qeth_free_new_skb(skb
, new_skb
);
4708 PRINT_WARN("could not create eddp context\n");
4712 int elems
= qeth_get_elements_no(card
,(void*) hdr
, new_skb
,
4715 __qeth_free_new_skb(skb
, new_skb
);
4718 elements_needed
+= elems
;
4721 if ((large_send
== QETH_LARGE_SEND_NO
) &&
4722 (skb
->ip_summed
== CHECKSUM_PARTIAL
))
4723 qeth_tx_csum(new_skb
);
4725 if (card
->info
.type
!= QETH_CARD_TYPE_IQD
)
4726 rc
= qeth_do_send_packet(card
, queue
, new_skb
, hdr
,
4727 elements_needed
, ctx
);
4729 if ((!card
->options
.layer2
) &&
4731 __qeth_free_new_skb(skb
, new_skb
);
4734 rc
= qeth_do_send_packet_fast(card
, queue
, new_skb
, hdr
,
4735 elements_needed
, ctx
);
4738 card
->stats
.tx_packets
++;
4739 card
->stats
.tx_bytes
+= tx_bytes
;
4741 dev_kfree_skb_any(skb
);
4742 if (card
->options
.performance_stats
) {
4744 !(large_send
== QETH_LARGE_SEND_NO
)) {
4745 card
->perf_stats
.large_send_bytes
+= tx_bytes
;
4746 card
->perf_stats
.large_send_cnt
++;
4749 card
->perf_stats
.sg_skbs_sent
++;
4750 /* nr_frags + skb->data */
4751 card
->perf_stats
.sg_frags_sent
+=
4756 card
->stats
.tx_dropped
++;
4757 __qeth_free_new_skb(skb
, new_skb
);
4760 /* drop creator's reference */
4761 qeth_eddp_put_context(ctx
);
4762 /* free skb; it's not referenced by a buffer */
4764 dev_kfree_skb_any(new_skb
);
4770 qeth_mdio_read(struct net_device
*dev
, int phy_id
, int regnum
)
4772 struct qeth_card
*card
= (struct qeth_card
*) dev
->priv
;
4776 case MII_BMCR
: /* Basic mode control register */
4778 if ((card
->info
.link_type
!= QETH_LINK_TYPE_GBIT_ETH
)&&
4779 (card
->info
.link_type
!= QETH_LINK_TYPE_OSN
) &&
4780 (card
->info
.link_type
!= QETH_LINK_TYPE_10GBIT_ETH
))
4781 rc
|= BMCR_SPEED100
;
4783 case MII_BMSR
: /* Basic mode status register */
4784 rc
= BMSR_ERCAP
| BMSR_ANEGCOMPLETE
| BMSR_LSTATUS
|
4785 BMSR_10HALF
| BMSR_10FULL
| BMSR_100HALF
| BMSR_100FULL
|
4788 case MII_PHYSID1
: /* PHYS ID 1 */
4789 rc
= (dev
->dev_addr
[0] << 16) | (dev
->dev_addr
[1] << 8) |
4791 rc
= (rc
>> 5) & 0xFFFF;
4793 case MII_PHYSID2
: /* PHYS ID 2 */
4794 rc
= (dev
->dev_addr
[2] << 10) & 0xFFFF;
4796 case MII_ADVERTISE
: /* Advertisement control reg */
4799 case MII_LPA
: /* Link partner ability reg */
4800 rc
= LPA_10HALF
| LPA_10FULL
| LPA_100HALF
| LPA_100FULL
|
4801 LPA_100BASE4
| LPA_LPACK
;
4803 case MII_EXPANSION
: /* Expansion register */
4805 case MII_DCOUNTER
: /* disconnect counter */
4807 case MII_FCSCOUNTER
: /* false carrier counter */
4809 case MII_NWAYTEST
: /* N-way auto-neg test register */
4811 case MII_RERRCOUNTER
: /* rx error counter */
4812 rc
= card
->stats
.rx_errors
;
4814 case MII_SREVISION
: /* silicon revision */
4816 case MII_RESV1
: /* reserved 1 */
4818 case MII_LBRERROR
: /* loopback, rx, bypass error */
4820 case MII_PHYADDR
: /* physical address */
4822 case MII_RESV2
: /* reserved 2 */
4824 case MII_TPISTATUS
: /* TPI status for 10mbps */
4826 case MII_NCONFIG
: /* network interface config */
4836 qeth_arp_get_error_cause(int *rc
)
4839 case QETH_IPA_ARP_RC_FAILED
:
4841 return "operation failed";
4842 case QETH_IPA_ARP_RC_NOTSUPP
:
4844 return "operation not supported";
4845 case QETH_IPA_ARP_RC_OUT_OF_RANGE
:
4847 return "argument out of range";
4848 case QETH_IPA_ARP_RC_Q_NOTSUPP
:
4850 return "query operation not supported";
4851 case QETH_IPA_ARP_RC_Q_NO_DATA
:
4853 return "no query data available";
4855 return "unknown error";
4860 qeth_send_simple_setassparms(struct qeth_card
*, enum qeth_ipa_funcs
,
4864 qeth_arp_set_no_entries(struct qeth_card
*card
, int no_entries
)
4869 QETH_DBF_TEXT(trace
,3,"arpstnoe");
4872 * currently GuestLAN only supports the ARP assist function
4873 * IPA_CMD_ASS_ARP_QUERY_INFO, but not IPA_CMD_ASS_ARP_SET_NO_ENTRIES;
4874 * thus we say EOPNOTSUPP for this ARP function
4876 if (card
->info
.guestlan
)
4878 if (!qeth_is_supported(card
,IPA_ARP_PROCESSING
)) {
4879 PRINT_WARN("ARP processing not supported "
4880 "on %s!\n", QETH_CARD_IFNAME(card
));
4883 rc
= qeth_send_simple_setassparms(card
, IPA_ARP_PROCESSING
,
4884 IPA_CMD_ASS_ARP_SET_NO_ENTRIES
,
4888 PRINT_WARN("Could not set number of ARP entries on %s: "
4890 QETH_CARD_IFNAME(card
), qeth_arp_get_error_cause(&rc
),
4897 qeth_copy_arp_entries_stripped(struct qeth_arp_query_info
*qinfo
,
4898 struct qeth_arp_query_data
*qdata
,
4899 int entry_size
, int uentry_size
)
4905 entry_ptr
= (char *)&qdata
->data
;
4906 uentry_ptr
= (char *)(qinfo
->udata
+ qinfo
->udata_offset
);
4907 for (i
= 0; i
< qdata
->no_entries
; ++i
){
4908 /* strip off 32 bytes "media specific information" */
4909 memcpy(uentry_ptr
, (entry_ptr
+ 32), entry_size
- 32);
4910 entry_ptr
+= entry_size
;
4911 uentry_ptr
+= uentry_size
;
4916 qeth_arp_query_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
4919 struct qeth_ipa_cmd
*cmd
;
4920 struct qeth_arp_query_data
*qdata
;
4921 struct qeth_arp_query_info
*qinfo
;
4926 QETH_DBF_TEXT(trace
,4,"arpquecb");
4928 qinfo
= (struct qeth_arp_query_info
*) reply
->param
;
4929 cmd
= (struct qeth_ipa_cmd
*) data
;
4930 if (cmd
->hdr
.return_code
) {
4931 QETH_DBF_TEXT_(trace
,4,"qaer1%i", cmd
->hdr
.return_code
);
4934 if (cmd
->data
.setassparms
.hdr
.return_code
) {
4935 cmd
->hdr
.return_code
= cmd
->data
.setassparms
.hdr
.return_code
;
4936 QETH_DBF_TEXT_(trace
,4,"qaer2%i", cmd
->hdr
.return_code
);
4939 qdata
= &cmd
->data
.setassparms
.data
.query_arp
;
4940 switch(qdata
->reply_bits
){
4942 uentry_size
= entry_size
= sizeof(struct qeth_arp_qi_entry5
);
4943 if (qinfo
->mask_bits
& QETH_QARP_STRIP_ENTRIES
)
4944 uentry_size
= sizeof(struct qeth_arp_qi_entry5_short
);
4947 /* fall through to default */
4949 /* tr is the same as eth -> entry7 */
4950 uentry_size
= entry_size
= sizeof(struct qeth_arp_qi_entry7
);
4951 if (qinfo
->mask_bits
& QETH_QARP_STRIP_ENTRIES
)
4952 uentry_size
= sizeof(struct qeth_arp_qi_entry7_short
);
4955 /* check if there is enough room in userspace */
4956 if ((qinfo
->udata_len
- qinfo
->udata_offset
) <
4957 qdata
->no_entries
* uentry_size
){
4958 QETH_DBF_TEXT_(trace
, 4, "qaer3%i", -ENOMEM
);
4959 cmd
->hdr
.return_code
= -ENOMEM
;
4960 PRINT_WARN("query ARP user space buffer is too small for "
4961 "the returned number of ARP entries. "
4962 "Aborting query!\n");
4965 QETH_DBF_TEXT_(trace
, 4, "anore%i",
4966 cmd
->data
.setassparms
.hdr
.number_of_replies
);
4967 QETH_DBF_TEXT_(trace
, 4, "aseqn%i", cmd
->data
.setassparms
.hdr
.seq_no
);
4968 QETH_DBF_TEXT_(trace
, 4, "anoen%i", qdata
->no_entries
);
4970 if (qinfo
->mask_bits
& QETH_QARP_STRIP_ENTRIES
) {
4971 /* strip off "media specific information" */
4972 qeth_copy_arp_entries_stripped(qinfo
, qdata
, entry_size
,
4975 /*copy entries to user buffer*/
4976 memcpy(qinfo
->udata
+ qinfo
->udata_offset
,
4977 (char *)&qdata
->data
, qdata
->no_entries
*uentry_size
);
4979 qinfo
->no_entries
+= qdata
->no_entries
;
4980 qinfo
->udata_offset
+= (qdata
->no_entries
*uentry_size
);
4981 /* check if all replies received ... */
4982 if (cmd
->data
.setassparms
.hdr
.seq_no
<
4983 cmd
->data
.setassparms
.hdr
.number_of_replies
)
4985 memcpy(qinfo
->udata
, &qinfo
->no_entries
, 4);
4986 /* keep STRIP_ENTRIES flag so the user program can distinguish
4987 * stripped entries from normal ones */
4988 if (qinfo
->mask_bits
& QETH_QARP_STRIP_ENTRIES
)
4989 qdata
->reply_bits
|= QETH_QARP_STRIP_ENTRIES
;
4990 memcpy(qinfo
->udata
+ QETH_QARP_MASK_OFFSET
,&qdata
->reply_bits
,2);
4994 memcpy(qinfo
->udata
, &i
, 4);
4999 qeth_send_ipa_arp_cmd(struct qeth_card
*card
, struct qeth_cmd_buffer
*iob
,
5000 int len
, int (*reply_cb
)(struct qeth_card
*,
5001 struct qeth_reply
*,
5005 QETH_DBF_TEXT(trace
,4,"sendarp");
5007 memcpy(iob
->data
, IPA_PDU_HEADER
, IPA_PDU_HEADER_SIZE
);
5008 memcpy(QETH_IPA_CMD_DEST_ADDR(iob
->data
),
5009 &card
->token
.ulp_connection_r
, QETH_MPC_TOKEN_LENGTH
);
5010 return qeth_send_control_data(card
, IPA_PDU_HEADER_SIZE
+ len
, iob
,
5011 reply_cb
, reply_param
);
5015 qeth_send_ipa_snmp_cmd(struct qeth_card
*card
, struct qeth_cmd_buffer
*iob
,
5016 int len
, int (*reply_cb
)(struct qeth_card
*,
5017 struct qeth_reply
*,
5023 QETH_DBF_TEXT(trace
,4,"sendsnmp");
5025 memcpy(iob
->data
, IPA_PDU_HEADER
, IPA_PDU_HEADER_SIZE
);
5026 memcpy(QETH_IPA_CMD_DEST_ADDR(iob
->data
),
5027 &card
->token
.ulp_connection_r
, QETH_MPC_TOKEN_LENGTH
);
5028 /* adjust PDU length fields in IPA_PDU_HEADER */
5029 s1
= (u32
) IPA_PDU_HEADER_SIZE
+ len
;
5031 memcpy(QETH_IPA_PDU_LEN_TOTAL(iob
->data
), &s1
, 2);
5032 memcpy(QETH_IPA_PDU_LEN_PDU1(iob
->data
), &s2
, 2);
5033 memcpy(QETH_IPA_PDU_LEN_PDU2(iob
->data
), &s2
, 2);
5034 memcpy(QETH_IPA_PDU_LEN_PDU3(iob
->data
), &s2
, 2);
5035 return qeth_send_control_data(card
, IPA_PDU_HEADER_SIZE
+ len
, iob
,
5036 reply_cb
, reply_param
);
5039 static struct qeth_cmd_buffer
*
5040 qeth_get_setassparms_cmd(struct qeth_card
*, enum qeth_ipa_funcs
,
5041 __u16
, __u16
, enum qeth_prot_versions
);
5043 qeth_arp_query(struct qeth_card
*card
, char __user
*udata
)
5045 struct qeth_cmd_buffer
*iob
;
5046 struct qeth_arp_query_info qinfo
= {0, };
5050 QETH_DBF_TEXT(trace
,3,"arpquery");
5052 if (!qeth_is_supported(card
,/*IPA_QUERY_ARP_ADDR_INFO*/
5053 IPA_ARP_PROCESSING
)) {
5054 PRINT_WARN("ARP processing not supported "
5055 "on %s!\n", QETH_CARD_IFNAME(card
));
5058 /* get size of userspace buffer and mask_bits -> 6 bytes */
5059 if (copy_from_user(&qinfo
, udata
, 6))
5061 if (!(qinfo
.udata
= kzalloc(qinfo
.udata_len
, GFP_KERNEL
)))
5063 qinfo
.udata_offset
= QETH_QARP_ENTRIES_OFFSET
;
5064 iob
= qeth_get_setassparms_cmd(card
, IPA_ARP_PROCESSING
,
5065 IPA_CMD_ASS_ARP_QUERY_INFO
,
5066 sizeof(int),QETH_PROT_IPV4
);
5068 rc
= qeth_send_ipa_arp_cmd(card
, iob
,
5069 QETH_SETASS_BASE_LEN
+QETH_ARP_CMD_LEN
,
5070 qeth_arp_query_cb
, (void *)&qinfo
);
5073 PRINT_WARN("Error while querying ARP cache on %s: %s "
5075 QETH_CARD_IFNAME(card
), qeth_arp_get_error_cause(&rc
),
5077 if (copy_to_user(udata
, qinfo
.udata
, 4))
5080 if (copy_to_user(udata
, qinfo
.udata
, qinfo
.udata_len
))
5088 * SNMP command callback
5091 qeth_snmp_command_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
5092 unsigned long sdata
)
5094 struct qeth_ipa_cmd
*cmd
;
5095 struct qeth_arp_query_info
*qinfo
;
5096 struct qeth_snmp_cmd
*snmp
;
5097 unsigned char *data
;
5100 QETH_DBF_TEXT(trace
,3,"snpcmdcb");
5102 cmd
= (struct qeth_ipa_cmd
*) sdata
;
5103 data
= (unsigned char *)((char *)cmd
- reply
->offset
);
5104 qinfo
= (struct qeth_arp_query_info
*) reply
->param
;
5105 snmp
= &cmd
->data
.setadapterparms
.data
.snmp
;
5107 if (cmd
->hdr
.return_code
) {
5108 QETH_DBF_TEXT_(trace
,4,"scer1%i", cmd
->hdr
.return_code
);
5111 if (cmd
->data
.setadapterparms
.hdr
.return_code
) {
5112 cmd
->hdr
.return_code
= cmd
->data
.setadapterparms
.hdr
.return_code
;
5113 QETH_DBF_TEXT_(trace
,4,"scer2%i", cmd
->hdr
.return_code
);
5116 data_len
= *((__u16
*)QETH_IPA_PDU_LEN_PDU1(data
));
5117 if (cmd
->data
.setadapterparms
.hdr
.seq_no
== 1)
5118 data_len
-= (__u16
)((char *)&snmp
->data
- (char *)cmd
);
5120 data_len
-= (__u16
)((char*)&snmp
->request
- (char *)cmd
);
5122 /* check if there is enough room in userspace */
5123 if ((qinfo
->udata_len
- qinfo
->udata_offset
) < data_len
) {
5124 QETH_DBF_TEXT_(trace
, 4, "scer3%i", -ENOMEM
);
5125 cmd
->hdr
.return_code
= -ENOMEM
;
5128 QETH_DBF_TEXT_(trace
, 4, "snore%i",
5129 cmd
->data
.setadapterparms
.hdr
.used_total
);
5130 QETH_DBF_TEXT_(trace
, 4, "sseqn%i", cmd
->data
.setadapterparms
.hdr
.seq_no
);
5131 /*copy entries to user buffer*/
5132 if (cmd
->data
.setadapterparms
.hdr
.seq_no
== 1) {
5133 memcpy(qinfo
->udata
+ qinfo
->udata_offset
,
5135 data_len
+ offsetof(struct qeth_snmp_cmd
,data
));
5136 qinfo
->udata_offset
+= offsetof(struct qeth_snmp_cmd
, data
);
5138 memcpy(qinfo
->udata
+ qinfo
->udata_offset
,
5139 (char *)&snmp
->request
, data_len
);
5141 qinfo
->udata_offset
+= data_len
;
5142 /* check if all replies received ... */
5143 QETH_DBF_TEXT_(trace
, 4, "srtot%i",
5144 cmd
->data
.setadapterparms
.hdr
.used_total
);
5145 QETH_DBF_TEXT_(trace
, 4, "srseq%i",
5146 cmd
->data
.setadapterparms
.hdr
.seq_no
);
5147 if (cmd
->data
.setadapterparms
.hdr
.seq_no
<
5148 cmd
->data
.setadapterparms
.hdr
.used_total
)
5153 static struct qeth_cmd_buffer
*
5154 qeth_get_ipacmd_buffer(struct qeth_card
*, enum qeth_ipa_cmds
,
5155 enum qeth_prot_versions
);
5157 static struct qeth_cmd_buffer
*
5158 qeth_get_adapter_cmd(struct qeth_card
*card
, __u32 command
, __u32 cmdlen
)
5160 struct qeth_cmd_buffer
*iob
;
5161 struct qeth_ipa_cmd
*cmd
;
5163 iob
= qeth_get_ipacmd_buffer(card
,IPA_CMD_SETADAPTERPARMS
,
5165 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
5166 cmd
->data
.setadapterparms
.hdr
.cmdlength
= cmdlen
;
5167 cmd
->data
.setadapterparms
.hdr
.command_code
= command
;
5168 cmd
->data
.setadapterparms
.hdr
.used_total
= 1;
5169 cmd
->data
.setadapterparms
.hdr
.seq_no
= 1;
5175 * function to send SNMP commands to OSA-E card
5178 qeth_snmp_command(struct qeth_card
*card
, char __user
*udata
)
5180 struct qeth_cmd_buffer
*iob
;
5181 struct qeth_ipa_cmd
*cmd
;
5182 struct qeth_snmp_ureq
*ureq
;
5184 struct qeth_arp_query_info qinfo
= {0, };
5187 QETH_DBF_TEXT(trace
,3,"snmpcmd");
5189 if (card
->info
.guestlan
)
5192 if ((!qeth_adp_supported(card
,IPA_SETADP_SET_SNMP_CONTROL
)) &&
5193 (!card
->options
.layer2
) ) {
5194 PRINT_WARN("SNMP Query MIBS not supported "
5195 "on %s!\n", QETH_CARD_IFNAME(card
));
5198 /* skip 4 bytes (data_len struct member) to get req_len */
5199 if (copy_from_user(&req_len
, udata
+ sizeof(int), sizeof(int)))
5201 ureq
= kmalloc(req_len
+sizeof(struct qeth_snmp_ureq_hdr
), GFP_KERNEL
);
5203 QETH_DBF_TEXT(trace
, 2, "snmpnome");
5206 if (copy_from_user(ureq
, udata
,
5207 req_len
+sizeof(struct qeth_snmp_ureq_hdr
))){
5211 qinfo
.udata_len
= ureq
->hdr
.data_len
;
5212 if (!(qinfo
.udata
= kzalloc(qinfo
.udata_len
, GFP_KERNEL
))){
5216 qinfo
.udata_offset
= sizeof(struct qeth_snmp_ureq_hdr
);
5218 iob
= qeth_get_adapter_cmd(card
, IPA_SETADP_SET_SNMP_CONTROL
,
5219 QETH_SNMP_SETADP_CMDLENGTH
+ req_len
);
5220 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
5221 memcpy(&cmd
->data
.setadapterparms
.data
.snmp
, &ureq
->cmd
, req_len
);
5222 rc
= qeth_send_ipa_snmp_cmd(card
, iob
, QETH_SETADP_BASE_LEN
+ req_len
,
5223 qeth_snmp_command_cb
, (void *)&qinfo
);
5225 PRINT_WARN("SNMP command failed on %s: (0x%x)\n",
5226 QETH_CARD_IFNAME(card
), rc
);
5228 if (copy_to_user(udata
, qinfo
.udata
, qinfo
.udata_len
))
5238 qeth_default_setassparms_cb(struct qeth_card
*, struct qeth_reply
*,
5242 qeth_default_setadapterparms_cb(struct qeth_card
*card
,
5243 struct qeth_reply
*reply
,
5244 unsigned long data
);
5246 qeth_send_setassparms(struct qeth_card
*, struct qeth_cmd_buffer
*,
5249 (struct qeth_card
*, struct qeth_reply
*, unsigned long),
5253 qeth_arp_add_entry(struct qeth_card
*card
, struct qeth_arp_cache_entry
*entry
)
5255 struct qeth_cmd_buffer
*iob
;
5260 QETH_DBF_TEXT(trace
,3,"arpadent");
5263 * currently GuestLAN only supports the ARP assist function
5264 * IPA_CMD_ASS_ARP_QUERY_INFO, but not IPA_CMD_ASS_ARP_ADD_ENTRY;
5265 * thus we say EOPNOTSUPP for this ARP function
5267 if (card
->info
.guestlan
)
5269 if (!qeth_is_supported(card
,IPA_ARP_PROCESSING
)) {
5270 PRINT_WARN("ARP processing not supported "
5271 "on %s!\n", QETH_CARD_IFNAME(card
));
5275 iob
= qeth_get_setassparms_cmd(card
, IPA_ARP_PROCESSING
,
5276 IPA_CMD_ASS_ARP_ADD_ENTRY
,
5277 sizeof(struct qeth_arp_cache_entry
),
5279 rc
= qeth_send_setassparms(card
, iob
,
5280 sizeof(struct qeth_arp_cache_entry
),
5281 (unsigned long) entry
,
5282 qeth_default_setassparms_cb
, NULL
);
5285 qeth_ipaddr4_to_string((u8
*)entry
->ipaddr
, buf
);
5286 PRINT_WARN("Could not add ARP entry for address %s on %s: "
5288 buf
, QETH_CARD_IFNAME(card
),
5289 qeth_arp_get_error_cause(&rc
), tmp
, tmp
);
5295 qeth_arp_remove_entry(struct qeth_card
*card
, struct qeth_arp_cache_entry
*entry
)
5297 struct qeth_cmd_buffer
*iob
;
5298 char buf
[16] = {0, };
5302 QETH_DBF_TEXT(trace
,3,"arprment");
5305 * currently GuestLAN only supports the ARP assist function
5306 * IPA_CMD_ASS_ARP_QUERY_INFO, but not IPA_CMD_ASS_ARP_REMOVE_ENTRY;
5307 * thus we say EOPNOTSUPP for this ARP function
5309 if (card
->info
.guestlan
)
5311 if (!qeth_is_supported(card
,IPA_ARP_PROCESSING
)) {
5312 PRINT_WARN("ARP processing not supported "
5313 "on %s!\n", QETH_CARD_IFNAME(card
));
5316 memcpy(buf
, entry
, 12);
5317 iob
= qeth_get_setassparms_cmd(card
, IPA_ARP_PROCESSING
,
5318 IPA_CMD_ASS_ARP_REMOVE_ENTRY
,
5321 rc
= qeth_send_setassparms(card
, iob
,
5322 12, (unsigned long)buf
,
5323 qeth_default_setassparms_cb
, NULL
);
5327 qeth_ipaddr4_to_string((u8
*)entry
->ipaddr
, buf
);
5328 PRINT_WARN("Could not delete ARP entry for address %s on %s: "
5330 buf
, QETH_CARD_IFNAME(card
),
5331 qeth_arp_get_error_cause(&rc
), tmp
, tmp
);
5337 qeth_arp_flush_cache(struct qeth_card
*card
)
5342 QETH_DBF_TEXT(trace
,3,"arpflush");
5345 * currently GuestLAN only supports the ARP assist function
5346 * IPA_CMD_ASS_ARP_QUERY_INFO, but not IPA_CMD_ASS_ARP_FLUSH_CACHE;
5347 * thus we say EOPNOTSUPP for this ARP function
5349 if (card
->info
.guestlan
|| (card
->info
.type
== QETH_CARD_TYPE_IQD
))
5351 if (!qeth_is_supported(card
,IPA_ARP_PROCESSING
)) {
5352 PRINT_WARN("ARP processing not supported "
5353 "on %s!\n", QETH_CARD_IFNAME(card
));
5356 rc
= qeth_send_simple_setassparms(card
, IPA_ARP_PROCESSING
,
5357 IPA_CMD_ASS_ARP_FLUSH_CACHE
, 0);
5360 PRINT_WARN("Could not flush ARP cache on %s: %s (0x%x/%d)\n",
5361 QETH_CARD_IFNAME(card
), qeth_arp_get_error_cause(&rc
),
5368 qeth_do_ioctl(struct net_device
*dev
, struct ifreq
*rq
, int cmd
)
5370 struct qeth_card
*card
= (struct qeth_card
*)dev
->priv
;
5371 struct qeth_arp_cache_entry arp_entry
;
5372 struct mii_ioctl_data
*mii_data
;
5378 if ((card
->state
!= CARD_STATE_UP
) &&
5379 (card
->state
!= CARD_STATE_SOFTSETUP
))
5382 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
5386 case SIOC_QETH_ARP_SET_NO_ENTRIES
:
5387 if ( !capable(CAP_NET_ADMIN
) ||
5388 (card
->options
.layer2
) ) {
5392 rc
= qeth_arp_set_no_entries(card
, rq
->ifr_ifru
.ifru_ivalue
);
5394 case SIOC_QETH_ARP_QUERY_INFO
:
5395 if ( !capable(CAP_NET_ADMIN
) ||
5396 (card
->options
.layer2
) ) {
5400 rc
= qeth_arp_query(card
, rq
->ifr_ifru
.ifru_data
);
5402 case SIOC_QETH_ARP_ADD_ENTRY
:
5403 if ( !capable(CAP_NET_ADMIN
) ||
5404 (card
->options
.layer2
) ) {
5408 if (copy_from_user(&arp_entry
, rq
->ifr_ifru
.ifru_data
,
5409 sizeof(struct qeth_arp_cache_entry
)))
5412 rc
= qeth_arp_add_entry(card
, &arp_entry
);
5414 case SIOC_QETH_ARP_REMOVE_ENTRY
:
5415 if ( !capable(CAP_NET_ADMIN
) ||
5416 (card
->options
.layer2
) ) {
5420 if (copy_from_user(&arp_entry
, rq
->ifr_ifru
.ifru_data
,
5421 sizeof(struct qeth_arp_cache_entry
)))
5424 rc
= qeth_arp_remove_entry(card
, &arp_entry
);
5426 case SIOC_QETH_ARP_FLUSH_CACHE
:
5427 if ( !capable(CAP_NET_ADMIN
) ||
5428 (card
->options
.layer2
) ) {
5432 rc
= qeth_arp_flush_cache(card
);
5434 case SIOC_QETH_ADP_SET_SNMP_CONTROL
:
5435 rc
= qeth_snmp_command(card
, rq
->ifr_ifru
.ifru_data
);
5437 case SIOC_QETH_GET_CARD_TYPE
:
5438 if ((card
->info
.type
== QETH_CARD_TYPE_OSAE
) &&
5439 !card
->info
.guestlan
)
5444 mii_data
= if_mii(rq
);
5445 mii_data
->phy_id
= 0;
5448 mii_data
= if_mii(rq
);
5449 if (mii_data
->phy_id
!= 0)
5452 mii_data
->val_out
= qeth_mdio_read(dev
,mii_data
->phy_id
,
5459 QETH_DBF_TEXT_(trace
, 2, "ioce%d", rc
);
5463 static struct net_device_stats
*
5464 qeth_get_stats(struct net_device
*dev
)
5466 struct qeth_card
*card
;
5468 card
= (struct qeth_card
*) (dev
->priv
);
5470 QETH_DBF_TEXT(trace
,5,"getstat");
5472 return &card
->stats
;
5476 qeth_change_mtu(struct net_device
*dev
, int new_mtu
)
5478 struct qeth_card
*card
;
5481 card
= (struct qeth_card
*) (dev
->priv
);
5483 QETH_DBF_TEXT(trace
,4,"chgmtu");
5484 sprintf(dbf_text
, "%8x", new_mtu
);
5485 QETH_DBF_TEXT(trace
,4,dbf_text
);
5489 if (new_mtu
> 65535)
5491 if ((!qeth_is_supported(card
,IPA_IP_FRAGMENTATION
)) &&
5492 (!qeth_mtu_is_valid(card
, new_mtu
)))
5498 #ifdef CONFIG_QETH_VLAN
5500 qeth_vlan_rx_register(struct net_device
*dev
, struct vlan_group
*grp
)
5502 struct qeth_card
*card
;
5503 unsigned long flags
;
5505 QETH_DBF_TEXT(trace
,4,"vlanreg");
5507 card
= (struct qeth_card
*) dev
->priv
;
5508 spin_lock_irqsave(&card
->vlanlock
, flags
);
5509 card
->vlangrp
= grp
;
5510 spin_unlock_irqrestore(&card
->vlanlock
, flags
);
5514 qeth_free_vlan_buffer(struct qeth_card
*card
, struct qeth_qdio_out_buffer
*buf
,
5518 struct sk_buff
*skb
;
5519 struct sk_buff_head tmp_list
;
5521 skb_queue_head_init(&tmp_list
);
5522 lockdep_set_class(&tmp_list
.lock
, &qdio_out_skb_queue_key
);
5523 for(i
= 0; i
< QETH_MAX_BUFFER_ELEMENTS(card
); ++i
){
5524 while ((skb
= skb_dequeue(&buf
->skb_list
))){
5525 if (vlan_tx_tag_present(skb
) &&
5526 (vlan_tx_tag_get(skb
) == vid
)) {
5527 atomic_dec(&skb
->users
);
5530 skb_queue_tail(&tmp_list
, skb
);
5533 while ((skb
= skb_dequeue(&tmp_list
)))
5534 skb_queue_tail(&buf
->skb_list
, skb
);
5538 qeth_free_vlan_skbs(struct qeth_card
*card
, unsigned short vid
)
5542 QETH_DBF_TEXT(trace
, 4, "frvlskbs");
5543 for (i
= 0; i
< card
->qdio
.no_out_queues
; ++i
){
5544 for (j
= 0; j
< QDIO_MAX_BUFFERS_PER_Q
; ++j
)
5545 qeth_free_vlan_buffer(card
, &card
->qdio
.
5546 out_qs
[i
]->bufs
[j
], vid
);
5551 qeth_free_vlan_addresses4(struct qeth_card
*card
, unsigned short vid
)
5553 struct in_device
*in_dev
;
5554 struct in_ifaddr
*ifa
;
5555 struct qeth_ipaddr
*addr
;
5557 QETH_DBF_TEXT(trace
, 4, "frvaddr4");
5560 in_dev
= __in_dev_get_rcu(vlan_group_get_device(card
->vlangrp
, vid
));
5563 for (ifa
= in_dev
->ifa_list
; ifa
; ifa
= ifa
->ifa_next
) {
5564 addr
= qeth_get_addr_buffer(QETH_PROT_IPV4
);
5566 addr
->u
.a4
.addr
= ifa
->ifa_address
;
5567 addr
->u
.a4
.mask
= ifa
->ifa_mask
;
5568 addr
->type
= QETH_IP_TYPE_NORMAL
;
5569 if (!qeth_delete_ip(card
, addr
))
5578 qeth_free_vlan_addresses6(struct qeth_card
*card
, unsigned short vid
)
5580 #ifdef CONFIG_QETH_IPV6
5581 struct inet6_dev
*in6_dev
;
5582 struct inet6_ifaddr
*ifa
;
5583 struct qeth_ipaddr
*addr
;
5585 QETH_DBF_TEXT(trace
, 4, "frvaddr6");
5587 in6_dev
= in6_dev_get(vlan_group_get_device(card
->vlangrp
, vid
));
5590 for (ifa
= in6_dev
->addr_list
; ifa
; ifa
= ifa
->lst_next
){
5591 addr
= qeth_get_addr_buffer(QETH_PROT_IPV6
);
5593 memcpy(&addr
->u
.a6
.addr
, &ifa
->addr
,
5594 sizeof(struct in6_addr
));
5595 addr
->u
.a6
.pfxlen
= ifa
->prefix_len
;
5596 addr
->type
= QETH_IP_TYPE_NORMAL
;
5597 if (!qeth_delete_ip(card
, addr
))
5601 in6_dev_put(in6_dev
);
5602 #endif /* CONFIG_QETH_IPV6 */
5606 qeth_free_vlan_addresses(struct qeth_card
*card
, unsigned short vid
)
5608 if (card
->options
.layer2
|| !card
->vlangrp
)
5610 qeth_free_vlan_addresses4(card
, vid
);
5611 qeth_free_vlan_addresses6(card
, vid
);
5615 qeth_layer2_send_setdelvlan_cb(struct qeth_card
*card
,
5616 struct qeth_reply
*reply
,
5619 struct qeth_ipa_cmd
*cmd
;
5621 QETH_DBF_TEXT(trace
, 2, "L2sdvcb");
5622 cmd
= (struct qeth_ipa_cmd
*) data
;
5623 if (cmd
->hdr
.return_code
) {
5624 PRINT_ERR("Error in processing VLAN %i on %s: 0x%x. "
5625 "Continuing\n",cmd
->data
.setdelvlan
.vlan_id
,
5626 QETH_CARD_IFNAME(card
), cmd
->hdr
.return_code
);
5627 QETH_DBF_TEXT_(trace
, 2, "L2VL%4x", cmd
->hdr
.command
);
5628 QETH_DBF_TEXT_(trace
, 2, "L2%s", CARD_BUS_ID(card
));
5629 QETH_DBF_TEXT_(trace
, 2, "err%d", cmd
->hdr
.return_code
);
5635 qeth_layer2_send_setdelvlan(struct qeth_card
*card
, __u16 i
,
5636 enum qeth_ipa_cmds ipacmd
)
5638 struct qeth_ipa_cmd
*cmd
;
5639 struct qeth_cmd_buffer
*iob
;
5641 QETH_DBF_TEXT_(trace
, 4, "L2sdv%x",ipacmd
);
5642 iob
= qeth_get_ipacmd_buffer(card
, ipacmd
, QETH_PROT_IPV4
);
5643 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
5644 cmd
->data
.setdelvlan
.vlan_id
= i
;
5645 return qeth_send_ipa_cmd(card
, iob
,
5646 qeth_layer2_send_setdelvlan_cb
, NULL
);
5650 qeth_layer2_process_vlans(struct qeth_card
*card
, int clear
)
5654 QETH_DBF_TEXT(trace
, 3, "L2prcvln");
5658 for (i
= 0; i
< VLAN_GROUP_ARRAY_LEN
; i
++) {
5659 if (vlan_group_get_device(card
->vlangrp
, i
) == NULL
)
5662 qeth_layer2_send_setdelvlan(card
, i
, IPA_CMD_DELVLAN
);
5664 qeth_layer2_send_setdelvlan(card
, i
, IPA_CMD_SETVLAN
);
5668 /*add_vid is layer 2 used only ....*/
5670 qeth_vlan_rx_add_vid(struct net_device
*dev
, unsigned short vid
)
5672 struct qeth_card
*card
;
5674 QETH_DBF_TEXT_(trace
, 4, "aid:%d", vid
);
5676 card
= (struct qeth_card
*) dev
->priv
;
5677 if (!card
->options
.layer2
)
5679 qeth_layer2_send_setdelvlan(card
, vid
, IPA_CMD_SETVLAN
);
5682 /*... kill_vid used for both modes*/
5684 qeth_vlan_rx_kill_vid(struct net_device
*dev
, unsigned short vid
)
5686 struct qeth_card
*card
;
5687 unsigned long flags
;
5689 QETH_DBF_TEXT_(trace
, 4, "kid:%d", vid
);
5691 card
= (struct qeth_card
*) dev
->priv
;
5692 /* free all skbs for the vlan device */
5693 qeth_free_vlan_skbs(card
, vid
);
5694 spin_lock_irqsave(&card
->vlanlock
, flags
);
5695 /* unregister IP addresses of vlan device */
5696 qeth_free_vlan_addresses(card
, vid
);
5697 vlan_group_set_device(card
->vlangrp
, vid
, NULL
);
5698 spin_unlock_irqrestore(&card
->vlanlock
, flags
);
5699 if (card
->options
.layer2
)
5700 qeth_layer2_send_setdelvlan(card
, vid
, IPA_CMD_DELVLAN
);
5701 qeth_set_multicast_list(card
->dev
);
5705 * Examine hardware response to SET_PROMISC_MODE
5708 qeth_setadp_promisc_mode_cb(struct qeth_card
*card
,
5709 struct qeth_reply
*reply
,
5712 struct qeth_ipa_cmd
*cmd
;
5713 struct qeth_ipacmd_setadpparms
*setparms
;
5715 QETH_DBF_TEXT(trace
,4,"prmadpcb");
5717 cmd
= (struct qeth_ipa_cmd
*) data
;
5718 setparms
= &(cmd
->data
.setadapterparms
);
5720 qeth_default_setadapterparms_cb(card
, reply
, (unsigned long)cmd
);
5721 if (cmd
->hdr
.return_code
) {
5722 QETH_DBF_TEXT_(trace
,4,"prmrc%2.2x",cmd
->hdr
.return_code
);
5723 setparms
->data
.mode
= SET_PROMISC_MODE_OFF
;
5725 card
->info
.promisc_mode
= setparms
->data
.mode
;
5729 * Set promiscuous mode (on or off) (SET_PROMISC_MODE command)
5732 qeth_setadp_promisc_mode(struct qeth_card
*card
)
5734 enum qeth_ipa_promisc_modes mode
;
5735 struct net_device
*dev
= card
->dev
;
5736 struct qeth_cmd_buffer
*iob
;
5737 struct qeth_ipa_cmd
*cmd
;
5739 QETH_DBF_TEXT(trace
, 4, "setprom");
5741 if (((dev
->flags
& IFF_PROMISC
) &&
5742 (card
->info
.promisc_mode
== SET_PROMISC_MODE_ON
)) ||
5743 (!(dev
->flags
& IFF_PROMISC
) &&
5744 (card
->info
.promisc_mode
== SET_PROMISC_MODE_OFF
)))
5746 mode
= SET_PROMISC_MODE_OFF
;
5747 if (dev
->flags
& IFF_PROMISC
)
5748 mode
= SET_PROMISC_MODE_ON
;
5749 QETH_DBF_TEXT_(trace
, 4, "mode:%x", mode
);
5751 iob
= qeth_get_adapter_cmd(card
, IPA_SETADP_SET_PROMISC_MODE
,
5752 sizeof(struct qeth_ipacmd_setadpparms
));
5753 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+ IPA_PDU_HEADER_SIZE
);
5754 cmd
->data
.setadapterparms
.data
.mode
= mode
;
5755 qeth_send_ipa_cmd(card
, iob
, qeth_setadp_promisc_mode_cb
, NULL
);
5759 * set multicast address on card
5762 qeth_set_multicast_list(struct net_device
*dev
)
5764 struct qeth_card
*card
= (struct qeth_card
*) dev
->priv
;
5766 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
5769 QETH_DBF_TEXT(trace
, 3, "setmulti");
5770 qeth_delete_mc_addresses(card
);
5771 if (card
->options
.layer2
) {
5772 qeth_layer2_add_multicast(card
);
5775 qeth_add_multicast_ipv4(card
);
5776 #ifdef CONFIG_QETH_IPV6
5777 qeth_add_multicast_ipv6(card
);
5780 qeth_set_ip_addr_list(card
);
5781 if (!qeth_adp_supported(card
, IPA_SETADP_SET_PROMISC_MODE
))
5783 qeth_setadp_promisc_mode(card
);
5787 qeth_neigh_setup(struct net_device
*dev
, struct neigh_parms
*np
)
5793 qeth_get_mac_for_ipm(__u32 ipm
, char *mac
, struct net_device
*dev
)
5795 if (dev
->type
== ARPHRD_IEEE802_TR
)
5796 ip_tr_mc_map(ipm
, mac
);
5798 ip_eth_mc_map(ipm
, mac
);
5801 static struct qeth_ipaddr
*
5802 qeth_get_addr_buffer(enum qeth_prot_versions prot
)
5804 struct qeth_ipaddr
*addr
;
5806 addr
= kzalloc(sizeof(struct qeth_ipaddr
), GFP_ATOMIC
);
5808 PRINT_WARN("Not enough memory to add address\n");
5811 addr
->type
= QETH_IP_TYPE_NORMAL
;
5817 qeth_osn_assist(struct net_device
*dev
,
5821 struct qeth_cmd_buffer
*iob
;
5822 struct qeth_card
*card
;
5825 QETH_DBF_TEXT(trace
, 2, "osnsdmc");
5828 card
= (struct qeth_card
*)dev
->priv
;
5831 if ((card
->state
!= CARD_STATE_UP
) &&
5832 (card
->state
!= CARD_STATE_SOFTSETUP
))
5834 iob
= qeth_wait_for_buffer(&card
->write
);
5835 memcpy(iob
->data
+IPA_PDU_HEADER_SIZE
, data
, data_len
);
5836 rc
= qeth_osn_send_ipa_cmd(card
, iob
, data_len
);
5840 static struct net_device
*
5841 qeth_netdev_by_devno(unsigned char *read_dev_no
)
5843 struct qeth_card
*card
;
5844 struct net_device
*ndev
;
5845 unsigned char *readno
;
5846 __u16 temp_dev_no
, card_dev_no
;
5848 unsigned long flags
;
5851 memcpy(&temp_dev_no
, read_dev_no
, 2);
5852 read_lock_irqsave(&qeth_card_list
.rwlock
, flags
);
5853 list_for_each_entry(card
, &qeth_card_list
.list
, list
) {
5854 readno
= CARD_RDEV_ID(card
);
5855 readno
+= (strlen(readno
) - 4);
5856 card_dev_no
= simple_strtoul(readno
, &endp
, 16);
5857 if (card_dev_no
== temp_dev_no
) {
5862 read_unlock_irqrestore(&qeth_card_list
.rwlock
, flags
);
5867 qeth_osn_register(unsigned char *read_dev_no
,
5868 struct net_device
**dev
,
5869 int (*assist_cb
)(struct net_device
*, void *),
5870 int (*data_cb
)(struct sk_buff
*))
5872 struct qeth_card
* card
;
5874 QETH_DBF_TEXT(trace
, 2, "osnreg");
5875 *dev
= qeth_netdev_by_devno(read_dev_no
);
5878 card
= (struct qeth_card
*)(*dev
)->priv
;
5881 if ((assist_cb
== NULL
) || (data_cb
== NULL
))
5883 card
->osn_info
.assist_cb
= assist_cb
;
5884 card
->osn_info
.data_cb
= data_cb
;
5889 qeth_osn_deregister(struct net_device
* dev
)
5891 struct qeth_card
*card
;
5893 QETH_DBF_TEXT(trace
, 2, "osndereg");
5896 card
= (struct qeth_card
*)dev
->priv
;
5899 card
->osn_info
.assist_cb
= NULL
;
5900 card
->osn_info
.data_cb
= NULL
;
5905 qeth_delete_mc_addresses(struct qeth_card
*card
)
5907 struct qeth_ipaddr
*iptodo
;
5908 unsigned long flags
;
5910 QETH_DBF_TEXT(trace
,4,"delmc");
5911 iptodo
= qeth_get_addr_buffer(QETH_PROT_IPV4
);
5913 QETH_DBF_TEXT(trace
, 2, "dmcnomem");
5916 iptodo
->type
= QETH_IP_TYPE_DEL_ALL_MC
;
5917 spin_lock_irqsave(&card
->ip_lock
, flags
);
5918 if (!__qeth_insert_ip_todo(card
, iptodo
, 0))
5920 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
5924 qeth_add_mc(struct qeth_card
*card
, struct in_device
*in4_dev
)
5926 struct qeth_ipaddr
*ipm
;
5927 struct ip_mc_list
*im4
;
5928 char buf
[MAX_ADDR_LEN
];
5930 QETH_DBF_TEXT(trace
,4,"addmc");
5931 for (im4
= in4_dev
->mc_list
; im4
; im4
= im4
->next
) {
5932 qeth_get_mac_for_ipm(im4
->multiaddr
, buf
, in4_dev
->dev
);
5933 ipm
= qeth_get_addr_buffer(QETH_PROT_IPV4
);
5936 ipm
->u
.a4
.addr
= im4
->multiaddr
;
5937 memcpy(ipm
->mac
,buf
,OSA_ADDR_LEN
);
5938 ipm
->is_multicast
= 1;
5939 if (!qeth_add_ip(card
,ipm
))
5945 qeth_add_vlan_mc(struct qeth_card
*card
)
5947 #ifdef CONFIG_QETH_VLAN
5948 struct in_device
*in_dev
;
5949 struct vlan_group
*vg
;
5952 QETH_DBF_TEXT(trace
,4,"addmcvl");
5953 if ( ((card
->options
.layer2
== 0) &&
5954 (!qeth_is_supported(card
,IPA_FULL_VLAN
))) ||
5955 (card
->vlangrp
== NULL
) )
5959 for (i
= 0; i
< VLAN_GROUP_ARRAY_LEN
; i
++) {
5960 struct net_device
*netdev
= vlan_group_get_device(vg
, i
);
5961 if (netdev
== NULL
||
5962 !(netdev
->flags
& IFF_UP
))
5964 in_dev
= in_dev_get(netdev
);
5967 read_lock(&in_dev
->mc_list_lock
);
5968 qeth_add_mc(card
,in_dev
);
5969 read_unlock(&in_dev
->mc_list_lock
);
5976 qeth_add_multicast_ipv4(struct qeth_card
*card
)
5978 struct in_device
*in4_dev
;
5980 QETH_DBF_TEXT(trace
,4,"chkmcv4");
5981 in4_dev
= in_dev_get(card
->dev
);
5982 if (in4_dev
== NULL
)
5984 read_lock(&in4_dev
->mc_list_lock
);
5985 qeth_add_mc(card
, in4_dev
);
5986 qeth_add_vlan_mc(card
);
5987 read_unlock(&in4_dev
->mc_list_lock
);
5988 in_dev_put(in4_dev
);
5992 qeth_layer2_add_multicast(struct qeth_card
*card
)
5994 struct qeth_ipaddr
*ipm
;
5995 struct dev_mc_list
*dm
;
5997 QETH_DBF_TEXT(trace
,4,"L2addmc");
5998 for (dm
= card
->dev
->mc_list
; dm
; dm
= dm
->next
) {
5999 ipm
= qeth_get_addr_buffer(QETH_PROT_IPV4
);
6002 memcpy(ipm
->mac
,dm
->dmi_addr
,MAX_ADDR_LEN
);
6003 ipm
->is_multicast
= 1;
6004 if (!qeth_add_ip(card
, ipm
))
6009 #ifdef CONFIG_QETH_IPV6
6011 qeth_add_mc6(struct qeth_card
*card
, struct inet6_dev
*in6_dev
)
6013 struct qeth_ipaddr
*ipm
;
6014 struct ifmcaddr6
*im6
;
6015 char buf
[MAX_ADDR_LEN
];
6017 QETH_DBF_TEXT(trace
,4,"addmc6");
6018 for (im6
= in6_dev
->mc_list
; im6
!= NULL
; im6
= im6
->next
) {
6019 ndisc_mc_map(&im6
->mca_addr
, buf
, in6_dev
->dev
, 0);
6020 ipm
= qeth_get_addr_buffer(QETH_PROT_IPV6
);
6023 ipm
->is_multicast
= 1;
6024 memcpy(ipm
->mac
,buf
,OSA_ADDR_LEN
);
6025 memcpy(&ipm
->u
.a6
.addr
,&im6
->mca_addr
.s6_addr
,
6026 sizeof(struct in6_addr
));
6027 if (!qeth_add_ip(card
,ipm
))
6033 qeth_add_vlan_mc6(struct qeth_card
*card
)
6035 #ifdef CONFIG_QETH_VLAN
6036 struct inet6_dev
*in_dev
;
6037 struct vlan_group
*vg
;
6040 QETH_DBF_TEXT(trace
,4,"admc6vl");
6041 if ( ((card
->options
.layer2
== 0) &&
6042 (!qeth_is_supported(card
,IPA_FULL_VLAN
))) ||
6043 (card
->vlangrp
== NULL
))
6047 for (i
= 0; i
< VLAN_GROUP_ARRAY_LEN
; i
++) {
6048 struct net_device
*netdev
= vlan_group_get_device(vg
, i
);
6049 if (netdev
== NULL
||
6050 !(netdev
->flags
& IFF_UP
))
6052 in_dev
= in6_dev_get(netdev
);
6055 read_lock_bh(&in_dev
->lock
);
6056 qeth_add_mc6(card
,in_dev
);
6057 read_unlock_bh(&in_dev
->lock
);
6058 in6_dev_put(in_dev
);
6060 #endif /* CONFIG_QETH_VLAN */
6064 qeth_add_multicast_ipv6(struct qeth_card
*card
)
6066 struct inet6_dev
*in6_dev
;
6068 QETH_DBF_TEXT(trace
,4,"chkmcv6");
6069 if (!qeth_is_supported(card
, IPA_IPV6
))
6071 in6_dev
= in6_dev_get(card
->dev
);
6072 if (in6_dev
== NULL
)
6074 read_lock_bh(&in6_dev
->lock
);
6075 qeth_add_mc6(card
, in6_dev
);
6076 qeth_add_vlan_mc6(card
);
6077 read_unlock_bh(&in6_dev
->lock
);
6078 in6_dev_put(in6_dev
);
6080 #endif /* CONFIG_QETH_IPV6 */
6083 qeth_layer2_send_setdelmac(struct qeth_card
*card
, __u8
*mac
,
6084 enum qeth_ipa_cmds ipacmd
,
6085 int (*reply_cb
) (struct qeth_card
*,
6089 struct qeth_ipa_cmd
*cmd
;
6090 struct qeth_cmd_buffer
*iob
;
6092 QETH_DBF_TEXT(trace
, 2, "L2sdmac");
6093 iob
= qeth_get_ipacmd_buffer(card
, ipacmd
, QETH_PROT_IPV4
);
6094 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
6095 cmd
->data
.setdelmac
.mac_length
= OSA_ADDR_LEN
;
6096 memcpy(&cmd
->data
.setdelmac
.mac
, mac
, OSA_ADDR_LEN
);
6097 return qeth_send_ipa_cmd(card
, iob
, reply_cb
, NULL
);
6101 qeth_layer2_send_setgroupmac_cb(struct qeth_card
*card
,
6102 struct qeth_reply
*reply
,
6105 struct qeth_ipa_cmd
*cmd
;
6108 QETH_DBF_TEXT(trace
, 2, "L2Sgmacb");
6109 cmd
= (struct qeth_ipa_cmd
*) data
;
6110 mac
= &cmd
->data
.setdelmac
.mac
[0];
6111 /* MAC already registered, needed in couple/uncouple case */
6112 if (cmd
->hdr
.return_code
== 0x2005) {
6113 PRINT_WARN("Group MAC %02x:%02x:%02x:%02x:%02x:%02x " \
6114 "already existing on %s \n",
6115 mac
[0], mac
[1], mac
[2], mac
[3], mac
[4], mac
[5],
6116 QETH_CARD_IFNAME(card
));
6117 cmd
->hdr
.return_code
= 0;
6119 if (cmd
->hdr
.return_code
)
6120 PRINT_ERR("Could not set group MAC " \
6121 "%02x:%02x:%02x:%02x:%02x:%02x on %s: %x\n",
6122 mac
[0], mac
[1], mac
[2], mac
[3], mac
[4], mac
[5],
6123 QETH_CARD_IFNAME(card
),cmd
->hdr
.return_code
);
6128 qeth_layer2_send_setgroupmac(struct qeth_card
*card
, __u8
*mac
)
6130 QETH_DBF_TEXT(trace
, 2, "L2Sgmac");
6131 return qeth_layer2_send_setdelmac(card
, mac
, IPA_CMD_SETGMAC
,
6132 qeth_layer2_send_setgroupmac_cb
);
6136 qeth_layer2_send_delgroupmac_cb(struct qeth_card
*card
,
6137 struct qeth_reply
*reply
,
6140 struct qeth_ipa_cmd
*cmd
;
6143 QETH_DBF_TEXT(trace
, 2, "L2Dgmacb");
6144 cmd
= (struct qeth_ipa_cmd
*) data
;
6145 mac
= &cmd
->data
.setdelmac
.mac
[0];
6146 if (cmd
->hdr
.return_code
)
6147 PRINT_ERR("Could not delete group MAC " \
6148 "%02x:%02x:%02x:%02x:%02x:%02x on %s: %x\n",
6149 mac
[0], mac
[1], mac
[2], mac
[3], mac
[4], mac
[5],
6150 QETH_CARD_IFNAME(card
), cmd
->hdr
.return_code
);
6155 qeth_layer2_send_delgroupmac(struct qeth_card
*card
, __u8
*mac
)
6157 QETH_DBF_TEXT(trace
, 2, "L2Dgmac");
6158 return qeth_layer2_send_setdelmac(card
, mac
, IPA_CMD_DELGMAC
,
6159 qeth_layer2_send_delgroupmac_cb
);
6163 qeth_layer2_send_setmac_cb(struct qeth_card
*card
,
6164 struct qeth_reply
*reply
,
6167 struct qeth_ipa_cmd
*cmd
;
6169 QETH_DBF_TEXT(trace
, 2, "L2Smaccb");
6170 cmd
= (struct qeth_ipa_cmd
*) data
;
6171 if (cmd
->hdr
.return_code
) {
6172 QETH_DBF_TEXT_(trace
, 2, "L2er%x", cmd
->hdr
.return_code
);
6173 card
->info
.mac_bits
&= ~QETH_LAYER2_MAC_REGISTERED
;
6174 cmd
->hdr
.return_code
= -EIO
;
6176 card
->info
.mac_bits
|= QETH_LAYER2_MAC_REGISTERED
;
6177 memcpy(card
->dev
->dev_addr
,cmd
->data
.setdelmac
.mac
,
6179 PRINT_INFO("MAC address %2.2x:%2.2x:%2.2x:%2.2x:%2.2x:%2.2x "
6180 "successfully registered on device %s\n",
6181 card
->dev
->dev_addr
[0], card
->dev
->dev_addr
[1],
6182 card
->dev
->dev_addr
[2], card
->dev
->dev_addr
[3],
6183 card
->dev
->dev_addr
[4], card
->dev
->dev_addr
[5],
6190 qeth_layer2_send_setmac(struct qeth_card
*card
, __u8
*mac
)
6192 QETH_DBF_TEXT(trace
, 2, "L2Setmac");
6193 return qeth_layer2_send_setdelmac(card
, mac
, IPA_CMD_SETVMAC
,
6194 qeth_layer2_send_setmac_cb
);
6198 qeth_layer2_send_delmac_cb(struct qeth_card
*card
,
6199 struct qeth_reply
*reply
,
6202 struct qeth_ipa_cmd
*cmd
;
6204 QETH_DBF_TEXT(trace
, 2, "L2Dmaccb");
6205 cmd
= (struct qeth_ipa_cmd
*) data
;
6206 if (cmd
->hdr
.return_code
) {
6207 QETH_DBF_TEXT_(trace
, 2, "err%d", cmd
->hdr
.return_code
);
6208 cmd
->hdr
.return_code
= -EIO
;
6211 card
->info
.mac_bits
&= ~QETH_LAYER2_MAC_REGISTERED
;
6216 qeth_layer2_send_delmac(struct qeth_card
*card
, __u8
*mac
)
6218 QETH_DBF_TEXT(trace
, 2, "L2Delmac");
6219 if (!(card
->info
.mac_bits
& QETH_LAYER2_MAC_REGISTERED
))
6221 return qeth_layer2_send_setdelmac(card
, mac
, IPA_CMD_DELVMAC
,
6222 qeth_layer2_send_delmac_cb
);
6226 qeth_layer2_set_mac_address(struct net_device
*dev
, void *p
)
6228 struct sockaddr
*addr
= p
;
6229 struct qeth_card
*card
;
6232 QETH_DBF_TEXT(trace
, 3, "setmac");
6234 if (qeth_verify_dev(dev
) != QETH_REAL_CARD
) {
6235 QETH_DBF_TEXT(trace
, 3, "setmcINV");
6238 card
= (struct qeth_card
*) dev
->priv
;
6240 if (!card
->options
.layer2
) {
6241 PRINT_WARN("Setting MAC address on %s is not supported "
6242 "in Layer 3 mode.\n", dev
->name
);
6243 QETH_DBF_TEXT(trace
, 3, "setmcLY3");
6246 if (card
->info
.type
== QETH_CARD_TYPE_OSN
) {
6247 PRINT_WARN("Setting MAC address on %s is not supported.\n",
6249 QETH_DBF_TEXT(trace
, 3, "setmcOSN");
6252 QETH_DBF_TEXT_(trace
, 3, "%s", CARD_BUS_ID(card
));
6253 QETH_DBF_HEX(trace
, 3, addr
->sa_data
, OSA_ADDR_LEN
);
6254 rc
= qeth_layer2_send_delmac(card
, &card
->dev
->dev_addr
[0]);
6256 rc
= qeth_layer2_send_setmac(card
, addr
->sa_data
);
6261 qeth_fill_ipacmd_header(struct qeth_card
*card
, struct qeth_ipa_cmd
*cmd
,
6262 __u8 command
, enum qeth_prot_versions prot
)
6264 memset(cmd
, 0, sizeof (struct qeth_ipa_cmd
));
6265 cmd
->hdr
.command
= command
;
6266 cmd
->hdr
.initiator
= IPA_CMD_INITIATOR_HOST
;
6267 cmd
->hdr
.seqno
= card
->seqno
.ipa
;
6268 cmd
->hdr
.adapter_type
= qeth_get_ipa_adp_type(card
->info
.link_type
);
6269 cmd
->hdr
.rel_adapter_no
= (__u8
) card
->info
.portno
;
6270 if (card
->options
.layer2
)
6271 cmd
->hdr
.prim_version_no
= 2;
6273 cmd
->hdr
.prim_version_no
= 1;
6274 cmd
->hdr
.param_count
= 1;
6275 cmd
->hdr
.prot_version
= prot
;
6276 cmd
->hdr
.ipa_supported
= 0;
6277 cmd
->hdr
.ipa_enabled
= 0;
6280 static struct qeth_cmd_buffer
*
6281 qeth_get_ipacmd_buffer(struct qeth_card
*card
, enum qeth_ipa_cmds ipacmd
,
6282 enum qeth_prot_versions prot
)
6284 struct qeth_cmd_buffer
*iob
;
6285 struct qeth_ipa_cmd
*cmd
;
6287 iob
= qeth_wait_for_buffer(&card
->write
);
6288 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
6289 qeth_fill_ipacmd_header(card
, cmd
, ipacmd
, prot
);
6295 qeth_send_setdelmc(struct qeth_card
*card
, struct qeth_ipaddr
*addr
, int ipacmd
)
6298 struct qeth_cmd_buffer
*iob
;
6299 struct qeth_ipa_cmd
*cmd
;
6301 QETH_DBF_TEXT(trace
,4,"setdelmc");
6303 iob
= qeth_get_ipacmd_buffer(card
, ipacmd
, addr
->proto
);
6304 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
6305 memcpy(&cmd
->data
.setdelipm
.mac
,addr
->mac
, OSA_ADDR_LEN
);
6306 if (addr
->proto
== QETH_PROT_IPV6
)
6307 memcpy(cmd
->data
.setdelipm
.ip6
, &addr
->u
.a6
.addr
,
6308 sizeof(struct in6_addr
));
6310 memcpy(&cmd
->data
.setdelipm
.ip4
, &addr
->u
.a4
.addr
,4);
6312 rc
= qeth_send_ipa_cmd(card
, iob
, NULL
, NULL
);
6317 qeth_fill_netmask(u8
*netmask
, unsigned int len
)
6320 for (i
=0;i
<16;i
++) {
6325 netmask
[i
] = (u8
)(0xFF00>>j
);
6332 qeth_send_setdelip(struct qeth_card
*card
, struct qeth_ipaddr
*addr
,
6333 int ipacmd
, unsigned int flags
)
6336 struct qeth_cmd_buffer
*iob
;
6337 struct qeth_ipa_cmd
*cmd
;
6340 QETH_DBF_TEXT(trace
,4,"setdelip");
6341 QETH_DBF_TEXT_(trace
,4,"flags%02X", flags
);
6343 iob
= qeth_get_ipacmd_buffer(card
, ipacmd
, addr
->proto
);
6344 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
6345 if (addr
->proto
== QETH_PROT_IPV6
) {
6346 memcpy(cmd
->data
.setdelip6
.ip_addr
, &addr
->u
.a6
.addr
,
6347 sizeof(struct in6_addr
));
6348 qeth_fill_netmask(netmask
,addr
->u
.a6
.pfxlen
);
6349 memcpy(cmd
->data
.setdelip6
.mask
, netmask
,
6350 sizeof(struct in6_addr
));
6351 cmd
->data
.setdelip6
.flags
= flags
;
6353 memcpy(cmd
->data
.setdelip4
.ip_addr
, &addr
->u
.a4
.addr
, 4);
6354 memcpy(cmd
->data
.setdelip4
.mask
, &addr
->u
.a4
.mask
, 4);
6355 cmd
->data
.setdelip4
.flags
= flags
;
6358 rc
= qeth_send_ipa_cmd(card
, iob
, NULL
, NULL
);
6364 qeth_layer2_register_addr_entry(struct qeth_card
*card
,
6365 struct qeth_ipaddr
*addr
)
6367 if (!addr
->is_multicast
)
6369 QETH_DBF_TEXT(trace
, 2, "setgmac");
6370 QETH_DBF_HEX(trace
,3,&addr
->mac
[0],OSA_ADDR_LEN
);
6371 return qeth_layer2_send_setgroupmac(card
, &addr
->mac
[0]);
6375 qeth_layer2_deregister_addr_entry(struct qeth_card
*card
,
6376 struct qeth_ipaddr
*addr
)
6378 if (!addr
->is_multicast
)
6380 QETH_DBF_TEXT(trace
, 2, "delgmac");
6381 QETH_DBF_HEX(trace
,3,&addr
->mac
[0],OSA_ADDR_LEN
);
6382 return qeth_layer2_send_delgroupmac(card
, &addr
->mac
[0]);
6386 qeth_layer3_register_addr_entry(struct qeth_card
*card
,
6387 struct qeth_ipaddr
*addr
)
6393 if (addr
->proto
== QETH_PROT_IPV4
) {
6394 QETH_DBF_TEXT(trace
, 2,"setaddr4");
6395 QETH_DBF_HEX(trace
, 3, &addr
->u
.a4
.addr
, sizeof(int));
6396 } else if (addr
->proto
== QETH_PROT_IPV6
) {
6397 QETH_DBF_TEXT(trace
, 2, "setaddr6");
6398 QETH_DBF_HEX(trace
,3,&addr
->u
.a6
.addr
,8);
6399 QETH_DBF_HEX(trace
,3,((char *)&addr
->u
.a6
.addr
)+8,8);
6401 QETH_DBF_TEXT(trace
, 2, "setaddr?");
6402 QETH_DBF_HEX(trace
, 3, addr
, sizeof(struct qeth_ipaddr
));
6405 if (addr
->is_multicast
)
6406 rc
= qeth_send_setdelmc(card
, addr
, IPA_CMD_SETIPM
);
6408 rc
= qeth_send_setdelip(card
, addr
, IPA_CMD_SETIP
,
6411 QETH_DBF_TEXT(trace
, 2, "failed");
6412 } while ((--cnt
> 0) && rc
);
6414 QETH_DBF_TEXT(trace
, 2, "FAILED");
6415 qeth_ipaddr_to_string(addr
->proto
, (u8
*)&addr
->u
, buf
);
6416 PRINT_WARN("Could not register IP address %s (rc=0x%x/%d)\n",
6423 qeth_layer3_deregister_addr_entry(struct qeth_card
*card
,
6424 struct qeth_ipaddr
*addr
)
6429 if (addr
->proto
== QETH_PROT_IPV4
) {
6430 QETH_DBF_TEXT(trace
, 2,"deladdr4");
6431 QETH_DBF_HEX(trace
, 3, &addr
->u
.a4
.addr
, sizeof(int));
6432 } else if (addr
->proto
== QETH_PROT_IPV6
) {
6433 QETH_DBF_TEXT(trace
, 2, "deladdr6");
6434 QETH_DBF_HEX(trace
,3,&addr
->u
.a6
.addr
,8);
6435 QETH_DBF_HEX(trace
,3,((char *)&addr
->u
.a6
.addr
)+8,8);
6437 QETH_DBF_TEXT(trace
, 2, "deladdr?");
6438 QETH_DBF_HEX(trace
, 3, addr
, sizeof(struct qeth_ipaddr
));
6440 if (addr
->is_multicast
)
6441 rc
= qeth_send_setdelmc(card
, addr
, IPA_CMD_DELIPM
);
6443 rc
= qeth_send_setdelip(card
, addr
, IPA_CMD_DELIP
,
6446 QETH_DBF_TEXT(trace
, 2, "failed");
6447 /* TODO: re-activate this warning as soon as we have a
6449 qeth_ipaddr_to_string(addr->proto, (u8 *)&addr->u, buf);
6450 PRINT_WARN("Could not deregister IP address %s (rc=%x)\n",
6458 qeth_register_addr_entry(struct qeth_card
*card
, struct qeth_ipaddr
*addr
)
6460 if (card
->options
.layer2
)
6461 return qeth_layer2_register_addr_entry(card
, addr
);
6463 return qeth_layer3_register_addr_entry(card
, addr
);
6467 qeth_deregister_addr_entry(struct qeth_card
*card
, struct qeth_ipaddr
*addr
)
6469 if (card
->options
.layer2
)
6470 return qeth_layer2_deregister_addr_entry(card
, addr
);
6472 return qeth_layer3_deregister_addr_entry(card
, addr
);
6476 qeth_ethtool_get_tx_csum(struct net_device
*dev
)
6478 return (dev
->features
& NETIF_F_HW_CSUM
) != 0;
6482 qeth_ethtool_set_tx_csum(struct net_device
*dev
, u32 data
)
6485 dev
->features
|= NETIF_F_HW_CSUM
;
6487 dev
->features
&= ~NETIF_F_HW_CSUM
;
6493 qeth_ethtool_get_rx_csum(struct net_device
*dev
)
6495 struct qeth_card
*card
= (struct qeth_card
*)dev
->priv
;
6497 return (card
->options
.checksum_type
== HW_CHECKSUMMING
);
6501 qeth_ethtool_set_rx_csum(struct net_device
*dev
, u32 data
)
6503 struct qeth_card
*card
= (struct qeth_card
*)dev
->priv
;
6505 if ((card
->state
!= CARD_STATE_DOWN
) &&
6506 (card
->state
!= CARD_STATE_RECOVER
))
6509 card
->options
.checksum_type
= HW_CHECKSUMMING
;
6511 card
->options
.checksum_type
= SW_CHECKSUMMING
;
6516 qeth_ethtool_get_sg(struct net_device
*dev
)
6518 struct qeth_card
*card
= (struct qeth_card
*)dev
->priv
;
6520 return ((card
->options
.large_send
!= QETH_LARGE_SEND_NO
) &&
6521 (dev
->features
& NETIF_F_SG
));
6525 qeth_ethtool_set_sg(struct net_device
*dev
, u32 data
)
6527 struct qeth_card
*card
= (struct qeth_card
*)dev
->priv
;
6530 if (card
->options
.large_send
!= QETH_LARGE_SEND_NO
)
6531 dev
->features
|= NETIF_F_SG
;
6533 dev
->features
&= ~NETIF_F_SG
;
6537 dev
->features
&= ~NETIF_F_SG
;
6542 qeth_ethtool_get_tso(struct net_device
*dev
)
6544 struct qeth_card
*card
= (struct qeth_card
*)dev
->priv
;
6546 return ((card
->options
.large_send
!= QETH_LARGE_SEND_NO
) &&
6547 (dev
->features
& NETIF_F_TSO
));
6551 qeth_ethtool_set_tso(struct net_device
*dev
, u32 data
)
6553 struct qeth_card
*card
= (struct qeth_card
*)dev
->priv
;
6556 if (card
->options
.large_send
!= QETH_LARGE_SEND_NO
)
6557 dev
->features
|= NETIF_F_TSO
;
6559 dev
->features
&= ~NETIF_F_TSO
;
6563 dev
->features
&= ~NETIF_F_TSO
;
6567 static struct ethtool_ops qeth_ethtool_ops
= {
6568 .get_tx_csum
= qeth_ethtool_get_tx_csum
,
6569 .set_tx_csum
= qeth_ethtool_set_tx_csum
,
6570 .get_rx_csum
= qeth_ethtool_get_rx_csum
,
6571 .set_rx_csum
= qeth_ethtool_set_rx_csum
,
6572 .get_sg
= qeth_ethtool_get_sg
,
6573 .set_sg
= qeth_ethtool_set_sg
,
6574 .get_tso
= qeth_ethtool_get_tso
,
6575 .set_tso
= qeth_ethtool_set_tso
,
6579 qeth_hard_header_parse(const struct sk_buff
*skb
, unsigned char *haddr
)
6581 const struct qeth_card
*card
;
6582 const struct ethhdr
*eth
;
6583 struct net_device
*dev
= skb
->dev
;
6585 if (dev
->type
!= ARPHRD_IEEE802_TR
)
6588 card
= qeth_get_card_from_dev(dev
);
6589 if (card
->options
.layer2
)
6591 #ifdef CONFIG_QETH_IPV6
6592 /* cause of the manipulated arp constructor and the ARP
6593 flag for OSAE devices we have some nasty exceptions */
6594 if (card
->info
.type
== QETH_CARD_TYPE_OSAE
) {
6595 if (!card
->options
.fake_ll
) {
6596 if ((skb
->pkt_type
==PACKET_OUTGOING
) &&
6597 (skb
->protocol
==ETH_P_IPV6
))
6602 if ((skb
->pkt_type
==PACKET_OUTGOING
) &&
6603 (skb
->protocol
==ETH_P_IP
))
6610 if (!card
->options
.fake_ll
)
6614 memcpy(haddr
, eth
->h_source
, ETH_ALEN
);
6618 static const struct header_ops qeth_null_ops
= {
6619 .parse
= qeth_hard_header_parse
,
6623 qeth_netdev_init(struct net_device
*dev
)
6625 struct qeth_card
*card
;
6627 card
= (struct qeth_card
*) dev
->priv
;
6629 QETH_DBF_TEXT(trace
,3,"initdev");
6631 dev
->tx_timeout
= &qeth_tx_timeout
;
6632 dev
->watchdog_timeo
= QETH_TX_TIMEOUT
;
6633 dev
->open
= qeth_open
;
6634 dev
->stop
= qeth_stop
;
6635 dev
->hard_start_xmit
= qeth_hard_start_xmit
;
6636 dev
->do_ioctl
= qeth_do_ioctl
;
6637 dev
->get_stats
= qeth_get_stats
;
6638 dev
->change_mtu
= qeth_change_mtu
;
6639 dev
->neigh_setup
= qeth_neigh_setup
;
6640 dev
->set_multicast_list
= qeth_set_multicast_list
;
6641 #ifdef CONFIG_QETH_VLAN
6642 dev
->vlan_rx_register
= qeth_vlan_rx_register
;
6643 dev
->vlan_rx_kill_vid
= qeth_vlan_rx_kill_vid
;
6644 dev
->vlan_rx_add_vid
= qeth_vlan_rx_add_vid
;
6646 if (qeth_get_netdev_flags(card
) & IFF_NOARP
)
6647 dev
->header_ops
= &qeth_null_ops
;
6649 #ifdef CONFIG_QETH_IPV6
6650 /*IPv6 address autoconfiguration stuff*/
6651 if (!(card
->info
.unique_id
& UNIQUE_ID_NOT_BY_CARD
))
6652 card
->dev
->dev_id
= card
->info
.unique_id
& 0xffff;
6654 if (card
->options
.fake_ll
&&
6655 (qeth_get_netdev_flags(card
) & IFF_NOARP
))
6656 dev
->header_ops
= &qeth_fake_ops
;
6658 dev
->set_mac_address
= qeth_layer2_set_mac_address
;
6659 dev
->flags
|= qeth_get_netdev_flags(card
);
6660 if ((card
->options
.fake_broadcast
) ||
6661 (card
->info
.broadcast_capable
))
6662 dev
->flags
|= IFF_BROADCAST
;
6663 dev
->hard_header_len
=
6664 qeth_get_hlen(card
->info
.link_type
) + card
->options
.add_hhlen
;
6665 dev
->addr_len
= OSA_ADDR_LEN
;
6666 dev
->mtu
= card
->info
.initial_mtu
;
6667 if (card
->info
.type
!= QETH_CARD_TYPE_OSN
)
6668 SET_ETHTOOL_OPS(dev
, &qeth_ethtool_ops
);
6673 qeth_init_func_level(struct qeth_card
*card
)
6675 if (card
->ipato
.enabled
) {
6676 if (card
->info
.type
== QETH_CARD_TYPE_IQD
)
6677 card
->info
.func_level
=
6678 QETH_IDX_FUNC_LEVEL_IQD_ENA_IPAT
;
6680 card
->info
.func_level
=
6681 QETH_IDX_FUNC_LEVEL_OSAE_ENA_IPAT
;
6683 if (card
->info
.type
== QETH_CARD_TYPE_IQD
)
6684 /*FIXME:why do we have same values for dis and ena for osae??? */
6685 card
->info
.func_level
=
6686 QETH_IDX_FUNC_LEVEL_IQD_DIS_IPAT
;
6688 card
->info
.func_level
=
6689 QETH_IDX_FUNC_LEVEL_OSAE_DIS_IPAT
;
6694 * hardsetup card, initialize MPC and QDIO stuff
6697 qeth_hardsetup_card(struct qeth_card
*card
)
6702 QETH_DBF_TEXT(setup
, 2, "hrdsetup");
6704 atomic_set(&card
->force_alloc_skb
, 0);
6707 PRINT_WARN("Retrying to do IDX activates.\n");
6708 ccw_device_set_offline(CARD_DDEV(card
));
6709 ccw_device_set_offline(CARD_WDEV(card
));
6710 ccw_device_set_offline(CARD_RDEV(card
));
6711 ccw_device_set_online(CARD_RDEV(card
));
6712 ccw_device_set_online(CARD_WDEV(card
));
6713 ccw_device_set_online(CARD_DDEV(card
));
6715 rc
= qeth_qdio_clear_card(card
,card
->info
.type
!=QETH_CARD_TYPE_IQD
);
6716 if (rc
== -ERESTARTSYS
) {
6717 QETH_DBF_TEXT(setup
, 2, "break1");
6720 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
6726 if ((rc
= qeth_get_unitaddr(card
))){
6727 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
6730 qeth_init_tokens(card
);
6731 qeth_init_func_level(card
);
6732 rc
= qeth_idx_activate_channel(&card
->read
, qeth_idx_read_cb
);
6733 if (rc
== -ERESTARTSYS
) {
6734 QETH_DBF_TEXT(setup
, 2, "break2");
6737 QETH_DBF_TEXT_(setup
, 2, "3err%d", rc
);
6743 rc
= qeth_idx_activate_channel(&card
->write
, qeth_idx_write_cb
);
6744 if (rc
== -ERESTARTSYS
) {
6745 QETH_DBF_TEXT(setup
, 2, "break3");
6748 QETH_DBF_TEXT_(setup
, 2, "4err%d", rc
);
6754 if ((rc
= qeth_mpc_initialize(card
))){
6755 QETH_DBF_TEXT_(setup
, 2, "5err%d", rc
);
6758 /*network device will be recovered*/
6760 card
->dev
->header_ops
= card
->orig_header_ops
;
6761 if (card
->options
.fake_ll
&&
6762 (qeth_get_netdev_flags(card
) & IFF_NOARP
))
6763 card
->dev
->header_ops
= &qeth_fake_ops
;
6766 /* at first set_online allocate netdev */
6767 card
->dev
= qeth_get_netdevice(card
->info
.type
,
6768 card
->info
.link_type
);
6770 qeth_qdio_clear_card(card
, card
->info
.type
!=
6771 QETH_CARD_TYPE_IQD
);
6773 QETH_DBF_TEXT_(setup
, 2, "6err%d", rc
);
6776 card
->dev
->priv
= card
;
6777 card
->orig_header_ops
= card
->dev
->header_ops
;
6778 card
->dev
->type
= qeth_get_arphdr_type(card
->info
.type
,
6779 card
->info
.link_type
);
6780 card
->dev
->init
= qeth_netdev_init
;
6783 PRINT_ERR("Initialization in hardsetup failed! rc=%d\n", rc
);
6788 qeth_default_setassparms_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
6791 struct qeth_ipa_cmd
*cmd
;
6793 QETH_DBF_TEXT(trace
,4,"defadpcb");
6795 cmd
= (struct qeth_ipa_cmd
*) data
;
6796 if (cmd
->hdr
.return_code
== 0){
6797 cmd
->hdr
.return_code
= cmd
->data
.setassparms
.hdr
.return_code
;
6798 if (cmd
->hdr
.prot_version
== QETH_PROT_IPV4
)
6799 card
->options
.ipa4
.enabled_funcs
= cmd
->hdr
.ipa_enabled
;
6800 #ifdef CONFIG_QETH_IPV6
6801 if (cmd
->hdr
.prot_version
== QETH_PROT_IPV6
)
6802 card
->options
.ipa6
.enabled_funcs
= cmd
->hdr
.ipa_enabled
;
6805 if (cmd
->data
.setassparms
.hdr
.assist_no
== IPA_INBOUND_CHECKSUM
&&
6806 cmd
->data
.setassparms
.hdr
.command_code
== IPA_CMD_ASS_START
) {
6807 card
->info
.csum_mask
= cmd
->data
.setassparms
.data
.flags_32bit
;
6808 QETH_DBF_TEXT_(trace
, 3, "csum:%d", card
->info
.csum_mask
);
6814 qeth_default_setadapterparms_cb(struct qeth_card
*card
,
6815 struct qeth_reply
*reply
,
6818 struct qeth_ipa_cmd
*cmd
;
6820 QETH_DBF_TEXT(trace
,4,"defadpcb");
6822 cmd
= (struct qeth_ipa_cmd
*) data
;
6823 if (cmd
->hdr
.return_code
== 0)
6824 cmd
->hdr
.return_code
= cmd
->data
.setadapterparms
.hdr
.return_code
;
6831 qeth_query_setadapterparms_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
6834 struct qeth_ipa_cmd
*cmd
;
6836 QETH_DBF_TEXT(trace
,3,"quyadpcb");
6838 cmd
= (struct qeth_ipa_cmd
*) data
;
6839 if (cmd
->data
.setadapterparms
.data
.query_cmds_supp
.lan_type
& 0x7f)
6840 card
->info
.link_type
=
6841 cmd
->data
.setadapterparms
.data
.query_cmds_supp
.lan_type
;
6842 card
->options
.adp
.supported_funcs
=
6843 cmd
->data
.setadapterparms
.data
.query_cmds_supp
.supported_cmds
;
6844 return qeth_default_setadapterparms_cb(card
, reply
, (unsigned long)cmd
);
6848 qeth_query_setadapterparms(struct qeth_card
*card
)
6851 struct qeth_cmd_buffer
*iob
;
6853 QETH_DBF_TEXT(trace
,3,"queryadp");
6854 iob
= qeth_get_adapter_cmd(card
, IPA_SETADP_QUERY_COMMANDS_SUPPORTED
,
6855 sizeof(struct qeth_ipacmd_setadpparms
));
6856 rc
= qeth_send_ipa_cmd(card
, iob
, qeth_query_setadapterparms_cb
, NULL
);
6861 qeth_setadpparms_change_macaddr_cb(struct qeth_card
*card
,
6862 struct qeth_reply
*reply
,
6865 struct qeth_ipa_cmd
*cmd
;
6867 QETH_DBF_TEXT(trace
,4,"chgmaccb");
6869 cmd
= (struct qeth_ipa_cmd
*) data
;
6870 if (!card
->options
.layer2
||
6871 !(card
->info
.mac_bits
& QETH_LAYER2_MAC_READ
)) {
6872 memcpy(card
->dev
->dev_addr
,
6873 &cmd
->data
.setadapterparms
.data
.change_addr
.addr
,
6875 card
->info
.mac_bits
|= QETH_LAYER2_MAC_READ
;
6877 qeth_default_setadapterparms_cb(card
, reply
, (unsigned long) cmd
);
6882 qeth_setadpparms_change_macaddr(struct qeth_card
*card
)
6885 struct qeth_cmd_buffer
*iob
;
6886 struct qeth_ipa_cmd
*cmd
;
6888 QETH_DBF_TEXT(trace
,4,"chgmac");
6890 iob
= qeth_get_adapter_cmd(card
,IPA_SETADP_ALTER_MAC_ADDRESS
,
6891 sizeof(struct qeth_ipacmd_setadpparms
));
6892 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
6893 cmd
->data
.setadapterparms
.data
.change_addr
.cmd
= CHANGE_ADDR_READ_MAC
;
6894 cmd
->data
.setadapterparms
.data
.change_addr
.addr_size
= OSA_ADDR_LEN
;
6895 memcpy(&cmd
->data
.setadapterparms
.data
.change_addr
.addr
,
6896 card
->dev
->dev_addr
, OSA_ADDR_LEN
);
6897 rc
= qeth_send_ipa_cmd(card
, iob
, qeth_setadpparms_change_macaddr_cb
,
6903 qeth_send_setadp_mode(struct qeth_card
*card
, __u32 command
, __u32 mode
)
6906 struct qeth_cmd_buffer
*iob
;
6907 struct qeth_ipa_cmd
*cmd
;
6909 QETH_DBF_TEXT(trace
,4,"adpmode");
6911 iob
= qeth_get_adapter_cmd(card
, command
,
6912 sizeof(struct qeth_ipacmd_setadpparms
));
6913 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
6914 cmd
->data
.setadapterparms
.data
.mode
= mode
;
6915 rc
= qeth_send_ipa_cmd(card
, iob
, qeth_default_setadapterparms_cb
,
6921 qeth_setadapter_hstr(struct qeth_card
*card
)
6925 QETH_DBF_TEXT(trace
,4,"adphstr");
6927 if (qeth_adp_supported(card
,IPA_SETADP_SET_BROADCAST_MODE
)) {
6928 rc
= qeth_send_setadp_mode(card
, IPA_SETADP_SET_BROADCAST_MODE
,
6929 card
->options
.broadcast_mode
);
6931 PRINT_WARN("couldn't set broadcast mode on "
6933 CARD_BUS_ID(card
), rc
);
6934 rc
= qeth_send_setadp_mode(card
, IPA_SETADP_ALTER_MAC_ADDRESS
,
6935 card
->options
.macaddr_mode
);
6937 PRINT_WARN("couldn't set macaddr mode on "
6938 "device %s: x%x\n", CARD_BUS_ID(card
), rc
);
6941 if (card
->options
.broadcast_mode
== QETH_TR_BROADCAST_LOCAL
)
6942 PRINT_WARN("set adapter parameters not available "
6943 "to set broadcast mode, using ALLRINGS "
6944 "on device %s:\n", CARD_BUS_ID(card
));
6945 if (card
->options
.macaddr_mode
== QETH_TR_MACADDR_CANONICAL
)
6946 PRINT_WARN("set adapter parameters not available "
6947 "to set macaddr mode, using NONCANONICAL "
6948 "on device %s:\n", CARD_BUS_ID(card
));
6953 qeth_setadapter_parms(struct qeth_card
*card
)
6957 QETH_DBF_TEXT(setup
, 2, "setadprm");
6959 if (!qeth_is_supported(card
, IPA_SETADAPTERPARMS
)){
6960 PRINT_WARN("set adapter parameters not supported "
6963 QETH_DBF_TEXT(setup
, 2, " notsupp");
6966 rc
= qeth_query_setadapterparms(card
);
6968 PRINT_WARN("couldn't set adapter parameters on device %s: "
6969 "x%x\n", CARD_BUS_ID(card
), rc
);
6972 if (qeth_adp_supported(card
,IPA_SETADP_ALTER_MAC_ADDRESS
)) {
6973 rc
= qeth_setadpparms_change_macaddr(card
);
6975 PRINT_WARN("couldn't get MAC address on "
6977 CARD_BUS_ID(card
), rc
);
6980 if ((card
->info
.link_type
== QETH_LINK_TYPE_HSTR
) ||
6981 (card
->info
.link_type
== QETH_LINK_TYPE_LANE_TR
))
6982 rc
= qeth_setadapter_hstr(card
);
6988 qeth_layer2_initialize(struct qeth_card
*card
)
6993 QETH_DBF_TEXT(setup
, 2, "doL2init");
6994 QETH_DBF_TEXT_(setup
, 2, "doL2%s", CARD_BUS_ID(card
));
6996 rc
= qeth_query_setadapterparms(card
);
6998 PRINT_WARN("could not query adapter parameters on device %s: "
6999 "x%x\n", CARD_BUS_ID(card
), rc
);
7002 rc
= qeth_setadpparms_change_macaddr(card
);
7004 PRINT_WARN("couldn't get MAC address on "
7006 CARD_BUS_ID(card
), rc
);
7007 QETH_DBF_TEXT_(setup
, 2,"1err%d",rc
);
7010 QETH_DBF_HEX(setup
,2, card
->dev
->dev_addr
, OSA_ADDR_LEN
);
7012 rc
= qeth_layer2_send_setmac(card
, &card
->dev
->dev_addr
[0]);
7014 QETH_DBF_TEXT_(setup
, 2,"2err%d",rc
);
7020 qeth_send_startstoplan(struct qeth_card
*card
, enum qeth_ipa_cmds ipacmd
,
7021 enum qeth_prot_versions prot
)
7024 struct qeth_cmd_buffer
*iob
;
7026 iob
= qeth_get_ipacmd_buffer(card
,ipacmd
,prot
);
7027 rc
= qeth_send_ipa_cmd(card
, iob
, NULL
, NULL
);
7033 qeth_send_startlan(struct qeth_card
*card
, enum qeth_prot_versions prot
)
7037 QETH_DBF_TEXT_(setup
, 2, "strtlan%i", prot
);
7039 rc
= qeth_send_startstoplan(card
, IPA_CMD_STARTLAN
, prot
);
7044 qeth_send_stoplan(struct qeth_card
*card
)
7049 * TODO: according to the IPA format document page 14,
7050 * TCP/IP (we!) never issue a STOPLAN
7053 QETH_DBF_TEXT(trace
, 2, "stoplan");
7055 rc
= qeth_send_startstoplan(card
, IPA_CMD_STOPLAN
, QETH_PROT_IPV4
);
7060 qeth_query_ipassists_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
7063 struct qeth_ipa_cmd
*cmd
;
7065 QETH_DBF_TEXT(setup
, 2, "qipasscb");
7067 cmd
= (struct qeth_ipa_cmd
*) data
;
7068 if (cmd
->hdr
.prot_version
== QETH_PROT_IPV4
) {
7069 card
->options
.ipa4
.supported_funcs
= cmd
->hdr
.ipa_supported
;
7070 card
->options
.ipa4
.enabled_funcs
= cmd
->hdr
.ipa_enabled
;
7071 /* Disable IPV6 support hard coded for Hipersockets */
7072 if(card
->info
.type
== QETH_CARD_TYPE_IQD
)
7073 card
->options
.ipa4
.supported_funcs
&= ~IPA_IPV6
;
7075 #ifdef CONFIG_QETH_IPV6
7076 card
->options
.ipa6
.supported_funcs
= cmd
->hdr
.ipa_supported
;
7077 card
->options
.ipa6
.enabled_funcs
= cmd
->hdr
.ipa_enabled
;
7080 QETH_DBF_TEXT(setup
, 2, "suppenbl");
7081 QETH_DBF_TEXT_(setup
, 2, "%x",cmd
->hdr
.ipa_supported
);
7082 QETH_DBF_TEXT_(setup
, 2, "%x",cmd
->hdr
.ipa_enabled
);
7087 qeth_query_ipassists(struct qeth_card
*card
, enum qeth_prot_versions prot
)
7090 struct qeth_cmd_buffer
*iob
;
7092 QETH_DBF_TEXT_(setup
, 2, "qipassi%i", prot
);
7093 if (card
->options
.layer2
) {
7094 QETH_DBF_TEXT(setup
, 2, "noprmly2");
7098 iob
= qeth_get_ipacmd_buffer(card
,IPA_CMD_QIPASSIST
,prot
);
7099 rc
= qeth_send_ipa_cmd(card
, iob
, qeth_query_ipassists_cb
, NULL
);
7103 static struct qeth_cmd_buffer
*
7104 qeth_get_setassparms_cmd(struct qeth_card
*card
, enum qeth_ipa_funcs ipa_func
,
7105 __u16 cmd_code
, __u16 len
,
7106 enum qeth_prot_versions prot
)
7108 struct qeth_cmd_buffer
*iob
;
7109 struct qeth_ipa_cmd
*cmd
;
7111 QETH_DBF_TEXT(trace
,4,"getasscm");
7112 iob
= qeth_get_ipacmd_buffer(card
,IPA_CMD_SETASSPARMS
,prot
);
7114 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
7115 cmd
->data
.setassparms
.hdr
.assist_no
= ipa_func
;
7116 cmd
->data
.setassparms
.hdr
.length
= 8 + len
;
7117 cmd
->data
.setassparms
.hdr
.command_code
= cmd_code
;
7118 cmd
->data
.setassparms
.hdr
.return_code
= 0;
7119 cmd
->data
.setassparms
.hdr
.seq_no
= 0;
7125 qeth_send_setassparms(struct qeth_card
*card
, struct qeth_cmd_buffer
*iob
,
7126 __u16 len
, long data
,
7128 (struct qeth_card
*,struct qeth_reply
*,unsigned long),
7132 struct qeth_ipa_cmd
*cmd
;
7134 QETH_DBF_TEXT(trace
,4,"sendassp");
7136 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
7137 if (len
<= sizeof(__u32
))
7138 cmd
->data
.setassparms
.data
.flags_32bit
= (__u32
) data
;
7139 else /* (len > sizeof(__u32)) */
7140 memcpy(&cmd
->data
.setassparms
.data
, (void *) data
, len
);
7142 rc
= qeth_send_ipa_cmd(card
, iob
, reply_cb
, reply_param
);
7146 #ifdef CONFIG_QETH_IPV6
7148 qeth_send_simple_setassparms_ipv6(struct qeth_card
*card
,
7149 enum qeth_ipa_funcs ipa_func
, __u16 cmd_code
)
7153 struct qeth_cmd_buffer
*iob
;
7155 QETH_DBF_TEXT(trace
,4,"simassp6");
7156 iob
= qeth_get_setassparms_cmd(card
, ipa_func
, cmd_code
,
7158 rc
= qeth_send_setassparms(card
, iob
, 0, 0,
7159 qeth_default_setassparms_cb
, NULL
);
7165 qeth_send_simple_setassparms(struct qeth_card
*card
,
7166 enum qeth_ipa_funcs ipa_func
,
7167 __u16 cmd_code
, long data
)
7171 struct qeth_cmd_buffer
*iob
;
7173 QETH_DBF_TEXT(trace
,4,"simassp4");
7175 length
= sizeof(__u32
);
7176 iob
= qeth_get_setassparms_cmd(card
, ipa_func
, cmd_code
,
7177 length
, QETH_PROT_IPV4
);
7178 rc
= qeth_send_setassparms(card
, iob
, length
, data
,
7179 qeth_default_setassparms_cb
, NULL
);
7184 qeth_start_ipa_arp_processing(struct qeth_card
*card
)
7188 QETH_DBF_TEXT(trace
,3,"ipaarp");
7190 if (!qeth_is_supported(card
,IPA_ARP_PROCESSING
)) {
7191 PRINT_WARN("ARP processing not supported "
7192 "on %s!\n", QETH_CARD_IFNAME(card
));
7195 rc
= qeth_send_simple_setassparms(card
,IPA_ARP_PROCESSING
,
7196 IPA_CMD_ASS_START
, 0);
7198 PRINT_WARN("Could not start ARP processing "
7199 "assist on %s: 0x%x\n",
7200 QETH_CARD_IFNAME(card
), rc
);
7206 qeth_start_ipa_ip_fragmentation(struct qeth_card
*card
)
7210 QETH_DBF_TEXT(trace
,3,"ipaipfrg");
7212 if (!qeth_is_supported(card
, IPA_IP_FRAGMENTATION
)) {
7213 PRINT_INFO("Hardware IP fragmentation not supported on %s\n",
7214 QETH_CARD_IFNAME(card
));
7218 rc
= qeth_send_simple_setassparms(card
, IPA_IP_FRAGMENTATION
,
7219 IPA_CMD_ASS_START
, 0);
7221 PRINT_WARN("Could not start Hardware IP fragmentation "
7222 "assist on %s: 0x%x\n",
7223 QETH_CARD_IFNAME(card
), rc
);
7225 PRINT_INFO("Hardware IP fragmentation enabled \n");
7230 qeth_start_ipa_source_mac(struct qeth_card
*card
)
7234 QETH_DBF_TEXT(trace
,3,"stsrcmac");
7236 if (!card
->options
.fake_ll
)
7239 if (!qeth_is_supported(card
, IPA_SOURCE_MAC
)) {
7240 PRINT_INFO("Inbound source address not "
7241 "supported on %s\n", QETH_CARD_IFNAME(card
));
7245 rc
= qeth_send_simple_setassparms(card
, IPA_SOURCE_MAC
,
7246 IPA_CMD_ASS_START
, 0);
7248 PRINT_WARN("Could not start inbound source "
7249 "assist on %s: 0x%x\n",
7250 QETH_CARD_IFNAME(card
), rc
);
7255 qeth_start_ipa_vlan(struct qeth_card
*card
)
7259 QETH_DBF_TEXT(trace
,3,"strtvlan");
7261 #ifdef CONFIG_QETH_VLAN
7262 if (!qeth_is_supported(card
, IPA_FULL_VLAN
)) {
7263 PRINT_WARN("VLAN not supported on %s\n", QETH_CARD_IFNAME(card
));
7267 rc
= qeth_send_simple_setassparms(card
, IPA_VLAN_PRIO
,
7268 IPA_CMD_ASS_START
,0);
7270 PRINT_WARN("Could not start vlan "
7271 "assist on %s: 0x%x\n",
7272 QETH_CARD_IFNAME(card
), rc
);
7274 PRINT_INFO("VLAN enabled \n");
7275 card
->dev
->features
|=
7276 NETIF_F_HW_VLAN_FILTER
|
7277 NETIF_F_HW_VLAN_TX
|
7280 #endif /* QETH_VLAN */
7285 qeth_start_ipa_multicast(struct qeth_card
*card
)
7289 QETH_DBF_TEXT(trace
,3,"stmcast");
7291 if (!qeth_is_supported(card
, IPA_MULTICASTING
)) {
7292 PRINT_WARN("Multicast not supported on %s\n",
7293 QETH_CARD_IFNAME(card
));
7297 rc
= qeth_send_simple_setassparms(card
, IPA_MULTICASTING
,
7298 IPA_CMD_ASS_START
,0);
7300 PRINT_WARN("Could not start multicast "
7301 "assist on %s: rc=%i\n",
7302 QETH_CARD_IFNAME(card
), rc
);
7304 PRINT_INFO("Multicast enabled\n");
7305 card
->dev
->flags
|= IFF_MULTICAST
;
7310 #ifdef CONFIG_QETH_IPV6
7312 qeth_softsetup_ipv6(struct qeth_card
*card
)
7316 QETH_DBF_TEXT(trace
,3,"softipv6");
7318 rc
= qeth_send_startlan(card
, QETH_PROT_IPV6
);
7320 PRINT_ERR("IPv6 startlan failed on %s\n",
7321 QETH_CARD_IFNAME(card
));
7324 rc
= qeth_query_ipassists(card
,QETH_PROT_IPV6
);
7326 PRINT_ERR("IPv6 query ipassist failed on %s\n",
7327 QETH_CARD_IFNAME(card
));
7330 rc
= qeth_send_simple_setassparms(card
, IPA_IPV6
,
7331 IPA_CMD_ASS_START
, 3);
7333 PRINT_WARN("IPv6 start assist (version 4) failed "
7335 QETH_CARD_IFNAME(card
), rc
);
7338 rc
= qeth_send_simple_setassparms_ipv6(card
, IPA_IPV6
,
7341 PRINT_WARN("IPV6 start assist (version 6) failed "
7343 QETH_CARD_IFNAME(card
), rc
);
7346 rc
= qeth_send_simple_setassparms_ipv6(card
, IPA_PASSTHRU
,
7349 PRINT_WARN("Could not enable passthrough "
7351 QETH_CARD_IFNAME(card
), rc
);
7354 PRINT_INFO("IPV6 enabled \n");
7361 qeth_start_ipa_ipv6(struct qeth_card
*card
)
7364 #ifdef CONFIG_QETH_IPV6
7365 QETH_DBF_TEXT(trace
,3,"strtipv6");
7367 if (!qeth_is_supported(card
, IPA_IPV6
)) {
7368 PRINT_WARN("IPv6 not supported on %s\n",
7369 QETH_CARD_IFNAME(card
));
7372 rc
= qeth_softsetup_ipv6(card
);
7378 qeth_start_ipa_broadcast(struct qeth_card
*card
)
7382 QETH_DBF_TEXT(trace
,3,"stbrdcst");
7383 card
->info
.broadcast_capable
= 0;
7384 if (!qeth_is_supported(card
, IPA_FILTERING
)) {
7385 PRINT_WARN("Broadcast not supported on %s\n",
7386 QETH_CARD_IFNAME(card
));
7390 rc
= qeth_send_simple_setassparms(card
, IPA_FILTERING
,
7391 IPA_CMD_ASS_START
, 0);
7393 PRINT_WARN("Could not enable broadcasting filtering "
7395 QETH_CARD_IFNAME(card
), rc
);
7399 rc
= qeth_send_simple_setassparms(card
, IPA_FILTERING
,
7400 IPA_CMD_ASS_CONFIGURE
, 1);
7402 PRINT_WARN("Could not set up broadcast filtering on %s: 0x%x\n",
7403 QETH_CARD_IFNAME(card
), rc
);
7406 card
->info
.broadcast_capable
= QETH_BROADCAST_WITH_ECHO
;
7407 PRINT_INFO("Broadcast enabled \n");
7408 rc
= qeth_send_simple_setassparms(card
, IPA_FILTERING
,
7409 IPA_CMD_ASS_ENABLE
, 1);
7411 PRINT_WARN("Could not set up broadcast echo filtering on "
7412 "%s: 0x%x\n", QETH_CARD_IFNAME(card
), rc
);
7415 card
->info
.broadcast_capable
= QETH_BROADCAST_WITHOUT_ECHO
;
7417 if (card
->info
.broadcast_capable
)
7418 card
->dev
->flags
|= IFF_BROADCAST
;
7420 card
->dev
->flags
&= ~IFF_BROADCAST
;
7425 qeth_send_checksum_command(struct qeth_card
*card
)
7429 rc
= qeth_send_simple_setassparms(card
, IPA_INBOUND_CHECKSUM
,
7430 IPA_CMD_ASS_START
, 0);
7432 PRINT_WARN("Starting Inbound HW Checksumming failed on %s: "
7433 "0x%x,\ncontinuing using Inbound SW Checksumming\n",
7434 QETH_CARD_IFNAME(card
), rc
);
7437 rc
= qeth_send_simple_setassparms(card
, IPA_INBOUND_CHECKSUM
,
7439 card
->info
.csum_mask
);
7441 PRINT_WARN("Enabling Inbound HW Checksumming failed on %s: "
7442 "0x%x,\ncontinuing using Inbound SW Checksumming\n",
7443 QETH_CARD_IFNAME(card
), rc
);
7450 qeth_start_ipa_checksum(struct qeth_card
*card
)
7454 QETH_DBF_TEXT(trace
,3,"strtcsum");
7456 if (card
->options
.checksum_type
== NO_CHECKSUMMING
) {
7457 PRINT_WARN("Using no checksumming on %s.\n",
7458 QETH_CARD_IFNAME(card
));
7461 if (card
->options
.checksum_type
== SW_CHECKSUMMING
) {
7462 PRINT_WARN("Using SW checksumming on %s.\n",
7463 QETH_CARD_IFNAME(card
));
7466 if (!qeth_is_supported(card
, IPA_INBOUND_CHECKSUM
)) {
7467 PRINT_WARN("Inbound HW Checksumming not "
7468 "supported on %s,\ncontinuing "
7469 "using Inbound SW Checksumming\n",
7470 QETH_CARD_IFNAME(card
));
7471 card
->options
.checksum_type
= SW_CHECKSUMMING
;
7474 rc
= qeth_send_checksum_command(card
);
7476 PRINT_INFO("HW Checksumming (inbound) enabled \n");
7482 qeth_start_ipa_tso(struct qeth_card
*card
)
7486 QETH_DBF_TEXT(trace
,3,"sttso");
7488 if (!qeth_is_supported(card
, IPA_OUTBOUND_TSO
)) {
7489 PRINT_WARN("Outbound TSO not supported on %s\n",
7490 QETH_CARD_IFNAME(card
));
7493 rc
= qeth_send_simple_setassparms(card
, IPA_OUTBOUND_TSO
,
7494 IPA_CMD_ASS_START
,0);
7496 PRINT_WARN("Could not start outbound TSO "
7497 "assist on %s: rc=%i\n",
7498 QETH_CARD_IFNAME(card
), rc
);
7500 PRINT_INFO("Outbound TSO enabled\n");
7502 if (rc
&& (card
->options
.large_send
== QETH_LARGE_SEND_TSO
)){
7503 card
->options
.large_send
= QETH_LARGE_SEND_NO
;
7504 card
->dev
->features
&= ~(NETIF_F_TSO
| NETIF_F_SG
|
7511 qeth_start_ipassists(struct qeth_card
*card
)
7513 QETH_DBF_TEXT(trace
,3,"strtipas");
7514 qeth_start_ipa_arp_processing(card
); /* go on*/
7515 qeth_start_ipa_ip_fragmentation(card
); /* go on*/
7516 qeth_start_ipa_source_mac(card
); /* go on*/
7517 qeth_start_ipa_vlan(card
); /* go on*/
7518 qeth_start_ipa_multicast(card
); /* go on*/
7519 qeth_start_ipa_ipv6(card
); /* go on*/
7520 qeth_start_ipa_broadcast(card
); /* go on*/
7521 qeth_start_ipa_checksum(card
); /* go on*/
7522 qeth_start_ipa_tso(card
); /* go on*/
7527 qeth_send_setrouting(struct qeth_card
*card
, enum qeth_routing_types type
,
7528 enum qeth_prot_versions prot
)
7531 struct qeth_ipa_cmd
*cmd
;
7532 struct qeth_cmd_buffer
*iob
;
7534 QETH_DBF_TEXT(trace
,4,"setroutg");
7535 iob
= qeth_get_ipacmd_buffer(card
, IPA_CMD_SETRTG
, prot
);
7536 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
7537 cmd
->data
.setrtg
.type
= (type
);
7538 rc
= qeth_send_ipa_cmd(card
, iob
, NULL
, NULL
);
7545 qeth_correct_routing_type(struct qeth_card
*card
, enum qeth_routing_types
*type
,
7546 enum qeth_prot_versions prot
)
7548 if (card
->info
.type
== QETH_CARD_TYPE_IQD
) {
7551 case PRIMARY_CONNECTOR
:
7552 case SECONDARY_CONNECTOR
:
7553 case MULTICAST_ROUTER
:
7561 case PRIMARY_ROUTER
:
7562 case SECONDARY_ROUTER
:
7564 case MULTICAST_ROUTER
:
7565 if (qeth_is_ipafunc_supported(card
, prot
,
7573 PRINT_WARN("Routing type '%s' not supported for interface %s.\n"
7574 "Router status set to 'no router'.\n",
7575 ((*type
== PRIMARY_ROUTER
)? "primary router" :
7576 (*type
== SECONDARY_ROUTER
)? "secondary router" :
7577 (*type
== PRIMARY_CONNECTOR
)? "primary connector" :
7578 (*type
== SECONDARY_CONNECTOR
)? "secondary connector" :
7579 (*type
== MULTICAST_ROUTER
)? "multicast router" :
7586 qeth_setrouting_v4(struct qeth_card
*card
)
7590 QETH_DBF_TEXT(trace
,3,"setrtg4");
7592 qeth_correct_routing_type(card
, &card
->options
.route4
.type
,
7595 rc
= qeth_send_setrouting(card
, card
->options
.route4
.type
,
7598 card
->options
.route4
.type
= NO_ROUTER
;
7599 PRINT_WARN("Error (0x%04x) while setting routing type on %s. "
7600 "Type set to 'no router'.\n",
7601 rc
, QETH_CARD_IFNAME(card
));
7607 qeth_setrouting_v6(struct qeth_card
*card
)
7611 QETH_DBF_TEXT(trace
,3,"setrtg6");
7612 #ifdef CONFIG_QETH_IPV6
7614 if (!qeth_is_supported(card
, IPA_IPV6
))
7616 qeth_correct_routing_type(card
, &card
->options
.route6
.type
,
7619 rc
= qeth_send_setrouting(card
, card
->options
.route6
.type
,
7622 card
->options
.route6
.type
= NO_ROUTER
;
7623 PRINT_WARN("Error (0x%04x) while setting routing type on %s. "
7624 "Type set to 'no router'.\n",
7625 rc
, QETH_CARD_IFNAME(card
));
7632 qeth_set_large_send(struct qeth_card
*card
, enum qeth_large_send_types type
)
7636 if (card
->dev
== NULL
) {
7637 card
->options
.large_send
= type
;
7640 if (card
->state
== CARD_STATE_UP
)
7641 netif_tx_disable(card
->dev
);
7642 card
->options
.large_send
= type
;
7643 switch (card
->options
.large_send
) {
7644 case QETH_LARGE_SEND_EDDP
:
7645 card
->dev
->features
|= NETIF_F_TSO
| NETIF_F_SG
|
7648 case QETH_LARGE_SEND_TSO
:
7649 if (qeth_is_supported(card
, IPA_OUTBOUND_TSO
)){
7650 card
->dev
->features
|= NETIF_F_TSO
| NETIF_F_SG
|
7653 PRINT_WARN("TSO not supported on %s. "
7654 "large_send set to 'no'.\n",
7656 card
->dev
->features
&= ~(NETIF_F_TSO
| NETIF_F_SG
|
7658 card
->options
.large_send
= QETH_LARGE_SEND_NO
;
7662 default: /* includes QETH_LARGE_SEND_NO */
7663 card
->dev
->features
&= ~(NETIF_F_TSO
| NETIF_F_SG
|
7667 if (card
->state
== CARD_STATE_UP
)
7668 netif_wake_queue(card
->dev
);
7673 * softsetup card: init IPA stuff
7676 qeth_softsetup_card(struct qeth_card
*card
)
7680 QETH_DBF_TEXT(setup
, 2, "softsetp");
7682 if ((rc
= qeth_send_startlan(card
, QETH_PROT_IPV4
))){
7683 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
7685 PRINT_WARN("LAN on card %s if offline! "
7686 "Waiting for STARTLAN from card.\n",
7688 card
->lan_online
= 0;
7692 card
->lan_online
= 1;
7693 if (card
->info
.type
==QETH_CARD_TYPE_OSN
)
7695 qeth_set_large_send(card
, card
->options
.large_send
);
7696 if (card
->options
.layer2
) {
7697 card
->dev
->features
|=
7698 NETIF_F_HW_VLAN_FILTER
|
7699 NETIF_F_HW_VLAN_TX
|
7701 card
->dev
->flags
|=IFF_MULTICAST
|IFF_BROADCAST
;
7702 card
->info
.broadcast_capable
=1;
7703 if ((rc
= qeth_layer2_initialize(card
))) {
7704 QETH_DBF_TEXT_(setup
, 2, "L2err%d", rc
);
7707 #ifdef CONFIG_QETH_VLAN
7708 qeth_layer2_process_vlans(card
, 0);
7712 if ((rc
= qeth_setadapter_parms(card
)))
7713 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
7714 if ((rc
= qeth_start_ipassists(card
)))
7715 QETH_DBF_TEXT_(setup
, 2, "3err%d", rc
);
7716 if ((rc
= qeth_setrouting_v4(card
)))
7717 QETH_DBF_TEXT_(setup
, 2, "4err%d", rc
);
7718 if ((rc
= qeth_setrouting_v6(card
)))
7719 QETH_DBF_TEXT_(setup
, 2, "5err%d", rc
);
7721 netif_tx_disable(card
->dev
);
7725 #ifdef CONFIG_QETH_IPV6
7727 qeth_get_unique_id_cb(struct qeth_card
*card
, struct qeth_reply
*reply
,
7730 struct qeth_ipa_cmd
*cmd
;
7732 cmd
= (struct qeth_ipa_cmd
*) data
;
7733 if (cmd
->hdr
.return_code
== 0)
7734 card
->info
.unique_id
= *((__u16
*)
7735 &cmd
->data
.create_destroy_addr
.unique_id
[6]);
7737 card
->info
.unique_id
= UNIQUE_ID_IF_CREATE_ADDR_FAILED
|
7738 UNIQUE_ID_NOT_BY_CARD
;
7739 PRINT_WARN("couldn't get a unique id from the card on device "
7740 "%s (result=x%x), using default id. ipv6 "
7741 "autoconfig on other lpars may lead to duplicate "
7742 "ip addresses. please use manually "
7743 "configured ones.\n",
7744 CARD_BUS_ID(card
), cmd
->hdr
.return_code
);
7751 qeth_put_unique_id(struct qeth_card
*card
)
7755 #ifdef CONFIG_QETH_IPV6
7756 struct qeth_cmd_buffer
*iob
;
7757 struct qeth_ipa_cmd
*cmd
;
7759 QETH_DBF_TEXT(trace
,2,"puniqeid");
7761 if ((card
->info
.unique_id
& UNIQUE_ID_NOT_BY_CARD
) ==
7762 UNIQUE_ID_NOT_BY_CARD
)
7764 iob
= qeth_get_ipacmd_buffer(card
, IPA_CMD_DESTROY_ADDR
,
7766 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
7767 *((__u16
*) &cmd
->data
.create_destroy_addr
.unique_id
[6]) =
7768 card
->info
.unique_id
;
7769 memcpy(&cmd
->data
.create_destroy_addr
.unique_id
[0],
7770 card
->dev
->dev_addr
, OSA_ADDR_LEN
);
7771 rc
= qeth_send_ipa_cmd(card
, iob
, NULL
, NULL
);
7773 card
->info
.unique_id
= UNIQUE_ID_IF_CREATE_ADDR_FAILED
|
7774 UNIQUE_ID_NOT_BY_CARD
;
7783 qeth_clear_ip_list(struct qeth_card
*card
, int clean
, int recover
)
7785 struct qeth_ipaddr
*addr
, *tmp
;
7786 unsigned long flags
;
7788 QETH_DBF_TEXT(trace
,4,"clearip");
7789 spin_lock_irqsave(&card
->ip_lock
, flags
);
7790 /* clear todo list */
7791 list_for_each_entry_safe(addr
, tmp
, card
->ip_tbd_list
, entry
){
7792 list_del(&addr
->entry
);
7796 while (!list_empty(&card
->ip_list
)) {
7797 addr
= list_entry(card
->ip_list
.next
,
7798 struct qeth_ipaddr
, entry
);
7799 list_del_init(&addr
->entry
);
7801 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
7802 qeth_deregister_addr_entry(card
, addr
);
7803 spin_lock_irqsave(&card
->ip_lock
, flags
);
7805 if (!recover
|| addr
->is_multicast
) {
7809 list_add_tail(&addr
->entry
, card
->ip_tbd_list
);
7811 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
7815 qeth_set_allowed_threads(struct qeth_card
*card
, unsigned long threads
,
7816 int clear_start_mask
)
7818 unsigned long flags
;
7820 spin_lock_irqsave(&card
->thread_mask_lock
, flags
);
7821 card
->thread_allowed_mask
= threads
;
7822 if (clear_start_mask
)
7823 card
->thread_start_mask
&= threads
;
7824 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
7825 wake_up(&card
->wait_q
);
7829 qeth_threads_running(struct qeth_card
*card
, unsigned long threads
)
7831 unsigned long flags
;
7834 spin_lock_irqsave(&card
->thread_mask_lock
, flags
);
7835 rc
= (card
->thread_running_mask
& threads
);
7836 spin_unlock_irqrestore(&card
->thread_mask_lock
, flags
);
7841 qeth_wait_for_threads(struct qeth_card
*card
, unsigned long threads
)
7843 return wait_event_interruptible(card
->wait_q
,
7844 qeth_threads_running(card
, threads
) == 0);
7848 qeth_stop_card(struct qeth_card
*card
, int recovery_mode
)
7852 QETH_DBF_TEXT(setup
,2,"stopcard");
7853 QETH_DBF_HEX(setup
, 2, &card
, sizeof(void *));
7855 qeth_set_allowed_threads(card
, 0, 1);
7856 if (qeth_wait_for_threads(card
, ~QETH_RECOVER_THREAD
))
7857 return -ERESTARTSYS
;
7858 if (card
->read
.state
== CH_STATE_UP
&&
7859 card
->write
.state
== CH_STATE_UP
&&
7860 (card
->state
== CARD_STATE_UP
)) {
7861 if (recovery_mode
&&
7862 card
->info
.type
!= QETH_CARD_TYPE_OSN
) {
7863 qeth_stop(card
->dev
);
7866 dev_close(card
->dev
);
7869 if (!card
->use_hard_stop
) {
7870 __u8
*mac
= &card
->dev
->dev_addr
[0];
7871 rc
= qeth_layer2_send_delmac(card
, mac
);
7872 QETH_DBF_TEXT_(setup
, 2, "Lerr%d", rc
);
7873 if ((rc
= qeth_send_stoplan(card
)))
7874 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
7876 card
->state
= CARD_STATE_SOFTSETUP
;
7878 if (card
->state
== CARD_STATE_SOFTSETUP
) {
7879 #ifdef CONFIG_QETH_VLAN
7880 if (card
->options
.layer2
)
7881 qeth_layer2_process_vlans(card
, 1);
7883 qeth_clear_ip_list(card
, !card
->use_hard_stop
, 1);
7884 qeth_clear_ipacmd_list(card
);
7885 card
->state
= CARD_STATE_HARDSETUP
;
7887 if (card
->state
== CARD_STATE_HARDSETUP
) {
7888 if ((!card
->use_hard_stop
) &&
7889 (!card
->options
.layer2
))
7890 if ((rc
= qeth_put_unique_id(card
)))
7891 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
7892 qeth_qdio_clear_card(card
, 0);
7893 qeth_clear_qdio_buffers(card
);
7894 qeth_clear_working_pool_list(card
);
7895 card
->state
= CARD_STATE_DOWN
;
7897 if (card
->state
== CARD_STATE_DOWN
) {
7898 qeth_clear_cmd_buffers(&card
->read
);
7899 qeth_clear_cmd_buffers(&card
->write
);
7901 card
->use_hard_stop
= 0;
7907 qeth_get_unique_id(struct qeth_card
*card
)
7910 #ifdef CONFIG_QETH_IPV6
7911 struct qeth_cmd_buffer
*iob
;
7912 struct qeth_ipa_cmd
*cmd
;
7914 QETH_DBF_TEXT(setup
, 2, "guniqeid");
7916 if (!qeth_is_supported(card
,IPA_IPV6
)) {
7917 card
->info
.unique_id
= UNIQUE_ID_IF_CREATE_ADDR_FAILED
|
7918 UNIQUE_ID_NOT_BY_CARD
;
7922 iob
= qeth_get_ipacmd_buffer(card
, IPA_CMD_CREATE_ADDR
,
7924 cmd
= (struct qeth_ipa_cmd
*)(iob
->data
+IPA_PDU_HEADER_SIZE
);
7925 *((__u16
*) &cmd
->data
.create_destroy_addr
.unique_id
[6]) =
7926 card
->info
.unique_id
;
7928 rc
= qeth_send_ipa_cmd(card
, iob
, qeth_get_unique_id_cb
, NULL
);
7930 card
->info
.unique_id
= UNIQUE_ID_IF_CREATE_ADDR_FAILED
|
7931 UNIQUE_ID_NOT_BY_CARD
;
7936 qeth_print_status_with_portname(struct qeth_card
*card
)
7941 sprintf(dbf_text
, "%s", card
->info
.portname
+ 1);
7942 for (i
= 0; i
< 8; i
++)
7944 (char) _ebcasc
[(__u8
) dbf_text
[i
]];
7946 printk("qeth: Device %s/%s/%s is a%s card%s%s%s\n"
7947 "with link type %s (portname: %s)\n",
7951 qeth_get_cardname(card
),
7952 (card
->info
.mcl_level
[0]) ? " (level: " : "",
7953 (card
->info
.mcl_level
[0]) ? card
->info
.mcl_level
: "",
7954 (card
->info
.mcl_level
[0]) ? ")" : "",
7955 qeth_get_cardname_short(card
),
7961 qeth_print_status_no_portname(struct qeth_card
*card
)
7963 if (card
->info
.portname
[0])
7964 printk("qeth: Device %s/%s/%s is a%s "
7965 "card%s%s%s\nwith link type %s "
7966 "(no portname needed by interface).\n",
7970 qeth_get_cardname(card
),
7971 (card
->info
.mcl_level
[0]) ? " (level: " : "",
7972 (card
->info
.mcl_level
[0]) ? card
->info
.mcl_level
: "",
7973 (card
->info
.mcl_level
[0]) ? ")" : "",
7974 qeth_get_cardname_short(card
));
7976 printk("qeth: Device %s/%s/%s is a%s "
7977 "card%s%s%s\nwith link type %s.\n",
7981 qeth_get_cardname(card
),
7982 (card
->info
.mcl_level
[0]) ? " (level: " : "",
7983 (card
->info
.mcl_level
[0]) ? card
->info
.mcl_level
: "",
7984 (card
->info
.mcl_level
[0]) ? ")" : "",
7985 qeth_get_cardname_short(card
));
7989 qeth_print_status_message(struct qeth_card
*card
)
7991 switch (card
->info
.type
) {
7992 case QETH_CARD_TYPE_OSAE
:
7993 /* VM will use a non-zero first character
7994 * to indicate a HiperSockets like reporting
7995 * of the level OSA sets the first character to zero
7997 if (!card
->info
.mcl_level
[0]) {
7998 sprintf(card
->info
.mcl_level
,"%02x%02x",
7999 card
->info
.mcl_level
[2],
8000 card
->info
.mcl_level
[3]);
8002 card
->info
.mcl_level
[QETH_MCL_LENGTH
] = 0;
8006 case QETH_CARD_TYPE_IQD
:
8007 if (card
->info
.guestlan
) {
8008 card
->info
.mcl_level
[0] = (char) _ebcasc
[(__u8
)
8009 card
->info
.mcl_level
[0]];
8010 card
->info
.mcl_level
[1] = (char) _ebcasc
[(__u8
)
8011 card
->info
.mcl_level
[1]];
8012 card
->info
.mcl_level
[2] = (char) _ebcasc
[(__u8
)
8013 card
->info
.mcl_level
[2]];
8014 card
->info
.mcl_level
[3] = (char) _ebcasc
[(__u8
)
8015 card
->info
.mcl_level
[3]];
8016 card
->info
.mcl_level
[QETH_MCL_LENGTH
] = 0;
8020 memset(&card
->info
.mcl_level
[0], 0, QETH_MCL_LENGTH
+ 1);
8022 if (card
->info
.portname_required
)
8023 qeth_print_status_with_portname(card
);
8025 qeth_print_status_no_portname(card
);
8029 qeth_register_netdev(struct qeth_card
*card
)
8031 QETH_DBF_TEXT(setup
, 3, "regnetd");
8032 if (card
->dev
->reg_state
!= NETREG_UNINITIALIZED
)
8035 SET_NETDEV_DEV(card
->dev
, &card
->gdev
->dev
);
8036 return register_netdev(card
->dev
);
8040 qeth_start_again(struct qeth_card
*card
, int recovery_mode
)
8042 QETH_DBF_TEXT(setup
,2, "startag");
8044 if (recovery_mode
&&
8045 card
->info
.type
!= QETH_CARD_TYPE_OSN
) {
8046 qeth_open(card
->dev
);
8049 dev_open(card
->dev
);
8052 /* this also sets saved unicast addresses */
8053 qeth_set_multicast_list(card
->dev
);
8057 /* Layer 2 specific stuff */
8058 #define IGNORE_PARAM_EQ(option,value,reset_value,msg) \
8059 if (card->options.option == value) { \
8060 PRINT_ERR("%s not supported with layer 2 " \
8061 "functionality, ignoring option on read" \
8062 "channel device %s .\n",msg,CARD_RDEV_ID(card)); \
8063 card->options.option = reset_value; \
8065 #define IGNORE_PARAM_NEQ(option,value,reset_value,msg) \
8066 if (card->options.option != value) { \
8067 PRINT_ERR("%s not supported with layer 2 " \
8068 "functionality, ignoring option on read" \
8069 "channel device %s .\n",msg,CARD_RDEV_ID(card)); \
8070 card->options.option = reset_value; \
8074 static void qeth_make_parameters_consistent(struct qeth_card
*card
)
8077 if (card
->options
.layer2
== 0)
8079 if (card
->info
.type
== QETH_CARD_TYPE_OSN
)
8081 if (card
->info
.type
== QETH_CARD_TYPE_IQD
) {
8082 PRINT_ERR("Device %s does not support layer 2 functionality." \
8083 " Ignoring layer2 option.\n",CARD_BUS_ID(card
));
8084 card
->options
.layer2
= 0;
8087 IGNORE_PARAM_NEQ(route4
.type
, NO_ROUTER
, NO_ROUTER
,
8088 "Routing options are");
8089 #ifdef CONFIG_QETH_IPV6
8090 IGNORE_PARAM_NEQ(route6
.type
, NO_ROUTER
, NO_ROUTER
,
8091 "Routing options are");
8093 IGNORE_PARAM_EQ(checksum_type
, HW_CHECKSUMMING
,
8094 QETH_CHECKSUM_DEFAULT
,
8095 "Checksumming options are");
8096 IGNORE_PARAM_NEQ(broadcast_mode
, QETH_TR_BROADCAST_ALLRINGS
,
8097 QETH_TR_BROADCAST_ALLRINGS
,
8098 "Broadcast mode options are");
8099 IGNORE_PARAM_NEQ(macaddr_mode
, QETH_TR_MACADDR_NONCANONICAL
,
8100 QETH_TR_MACADDR_NONCANONICAL
,
8101 "Canonical MAC addr options are");
8102 IGNORE_PARAM_NEQ(fake_broadcast
, 0, 0,
8103 "Broadcast faking options are");
8104 IGNORE_PARAM_NEQ(add_hhlen
, DEFAULT_ADD_HHLEN
,
8105 DEFAULT_ADD_HHLEN
,"Option add_hhlen is");
8106 IGNORE_PARAM_NEQ(fake_ll
, 0, 0,"Option fake_ll is");
8111 __qeth_set_online(struct ccwgroup_device
*gdev
, int recovery_mode
)
8113 struct qeth_card
*card
= gdev
->dev
.driver_data
;
8115 enum qeth_card_states recover_flag
;
8118 QETH_DBF_TEXT(setup
,2, "setonlin");
8119 QETH_DBF_HEX(setup
, 2, &card
, sizeof(void *));
8121 qeth_set_allowed_threads(card
, QETH_RECOVER_THREAD
, 1);
8122 if (qeth_wait_for_threads(card
, ~QETH_RECOVER_THREAD
)){
8123 PRINT_WARN("set_online of card %s interrupted by user!\n",
8125 return -ERESTARTSYS
;
8128 recover_flag
= card
->state
;
8129 if ((rc
= ccw_device_set_online(CARD_RDEV(card
))) ||
8130 (rc
= ccw_device_set_online(CARD_WDEV(card
))) ||
8131 (rc
= ccw_device_set_online(CARD_DDEV(card
)))){
8132 QETH_DBF_TEXT_(setup
, 2, "1err%d", rc
);
8136 qeth_make_parameters_consistent(card
);
8138 if ((rc
= qeth_hardsetup_card(card
))){
8139 QETH_DBF_TEXT_(setup
, 2, "2err%d", rc
);
8142 card
->state
= CARD_STATE_HARDSETUP
;
8144 if (!(rc
= qeth_query_ipassists(card
,QETH_PROT_IPV4
)))
8145 rc
= qeth_get_unique_id(card
);
8147 if (rc
&& card
->options
.layer2
== 0) {
8148 QETH_DBF_TEXT_(setup
, 2, "3err%d", rc
);
8151 qeth_print_status_message(card
);
8152 if ((rc
= qeth_register_netdev(card
))){
8153 QETH_DBF_TEXT_(setup
, 2, "4err%d", rc
);
8156 if ((rc
= qeth_softsetup_card(card
))){
8157 QETH_DBF_TEXT_(setup
, 2, "5err%d", rc
);
8161 if ((rc
= qeth_init_qdio_queues(card
))){
8162 QETH_DBF_TEXT_(setup
, 2, "6err%d", rc
);
8165 card
->state
= CARD_STATE_SOFTSETUP
;
8166 netif_carrier_on(card
->dev
);
8168 qeth_set_allowed_threads(card
, 0xffffffff, 0);
8169 if (recover_flag
== CARD_STATE_RECOVER
)
8170 qeth_start_again(card
, recovery_mode
);
8171 qeth_notify_processes();
8174 card
->use_hard_stop
= 1;
8175 qeth_stop_card(card
, 0);
8176 ccw_device_set_offline(CARD_DDEV(card
));
8177 ccw_device_set_offline(CARD_WDEV(card
));
8178 ccw_device_set_offline(CARD_RDEV(card
));
8179 if (recover_flag
== CARD_STATE_RECOVER
)
8180 card
->state
= CARD_STATE_RECOVER
;
8182 card
->state
= CARD_STATE_DOWN
;
8187 qeth_set_online(struct ccwgroup_device
*gdev
)
8189 return __qeth_set_online(gdev
, 0);
8192 static struct ccw_device_id qeth_ids
[] = {
8193 {CCW_DEVICE(0x1731, 0x01), .driver_info
= QETH_CARD_TYPE_OSAE
},
8194 {CCW_DEVICE(0x1731, 0x05), .driver_info
= QETH_CARD_TYPE_IQD
},
8195 {CCW_DEVICE(0x1731, 0x06), .driver_info
= QETH_CARD_TYPE_OSN
},
8198 MODULE_DEVICE_TABLE(ccw
, qeth_ids
);
8200 struct device
*qeth_root_dev
= NULL
;
8202 struct ccwgroup_driver qeth_ccwgroup_driver
= {
8203 .owner
= THIS_MODULE
,
8205 .driver_id
= 0xD8C5E3C8,
8206 .probe
= qeth_probe_device
,
8207 .remove
= qeth_remove_device
,
8208 .set_online
= qeth_set_online
,
8209 .set_offline
= qeth_set_offline
,
8212 struct ccw_driver qeth_ccw_driver
= {
8215 .probe
= ccwgroup_probe_ccwdev
,
8216 .remove
= ccwgroup_remove_ccwdev
,
8221 qeth_unregister_dbf_views(void)
8224 debug_unregister(qeth_dbf_setup
);
8226 debug_unregister(qeth_dbf_qerr
);
8228 debug_unregister(qeth_dbf_sense
);
8230 debug_unregister(qeth_dbf_misc
);
8232 debug_unregister(qeth_dbf_data
);
8233 if (qeth_dbf_control
)
8234 debug_unregister(qeth_dbf_control
);
8236 debug_unregister(qeth_dbf_trace
);
8239 qeth_register_dbf_views(void)
8241 qeth_dbf_setup
= debug_register(QETH_DBF_SETUP_NAME
,
8242 QETH_DBF_SETUP_PAGES
,
8243 QETH_DBF_SETUP_NR_AREAS
,
8244 QETH_DBF_SETUP_LEN
);
8245 qeth_dbf_misc
= debug_register(QETH_DBF_MISC_NAME
,
8246 QETH_DBF_MISC_PAGES
,
8247 QETH_DBF_MISC_NR_AREAS
,
8249 qeth_dbf_data
= debug_register(QETH_DBF_DATA_NAME
,
8250 QETH_DBF_DATA_PAGES
,
8251 QETH_DBF_DATA_NR_AREAS
,
8253 qeth_dbf_control
= debug_register(QETH_DBF_CONTROL_NAME
,
8254 QETH_DBF_CONTROL_PAGES
,
8255 QETH_DBF_CONTROL_NR_AREAS
,
8256 QETH_DBF_CONTROL_LEN
);
8257 qeth_dbf_sense
= debug_register(QETH_DBF_SENSE_NAME
,
8258 QETH_DBF_SENSE_PAGES
,
8259 QETH_DBF_SENSE_NR_AREAS
,
8260 QETH_DBF_SENSE_LEN
);
8261 qeth_dbf_qerr
= debug_register(QETH_DBF_QERR_NAME
,
8262 QETH_DBF_QERR_PAGES
,
8263 QETH_DBF_QERR_NR_AREAS
,
8265 qeth_dbf_trace
= debug_register(QETH_DBF_TRACE_NAME
,
8266 QETH_DBF_TRACE_PAGES
,
8267 QETH_DBF_TRACE_NR_AREAS
,
8268 QETH_DBF_TRACE_LEN
);
8270 if ((qeth_dbf_setup
== NULL
) || (qeth_dbf_misc
== NULL
) ||
8271 (qeth_dbf_data
== NULL
) || (qeth_dbf_control
== NULL
) ||
8272 (qeth_dbf_sense
== NULL
) || (qeth_dbf_qerr
== NULL
) ||
8273 (qeth_dbf_trace
== NULL
)) {
8274 qeth_unregister_dbf_views();
8277 debug_register_view(qeth_dbf_setup
, &debug_hex_ascii_view
);
8278 debug_set_level(qeth_dbf_setup
, QETH_DBF_SETUP_LEVEL
);
8280 debug_register_view(qeth_dbf_misc
, &debug_hex_ascii_view
);
8281 debug_set_level(qeth_dbf_misc
, QETH_DBF_MISC_LEVEL
);
8283 debug_register_view(qeth_dbf_data
, &debug_hex_ascii_view
);
8284 debug_set_level(qeth_dbf_data
, QETH_DBF_DATA_LEVEL
);
8286 debug_register_view(qeth_dbf_control
, &debug_hex_ascii_view
);
8287 debug_set_level(qeth_dbf_control
, QETH_DBF_CONTROL_LEVEL
);
8289 debug_register_view(qeth_dbf_sense
, &debug_hex_ascii_view
);
8290 debug_set_level(qeth_dbf_sense
, QETH_DBF_SENSE_LEVEL
);
8292 debug_register_view(qeth_dbf_qerr
, &debug_hex_ascii_view
);
8293 debug_set_level(qeth_dbf_qerr
, QETH_DBF_QERR_LEVEL
);
8295 debug_register_view(qeth_dbf_trace
, &debug_hex_ascii_view
);
8296 debug_set_level(qeth_dbf_trace
, QETH_DBF_TRACE_LEVEL
);
8301 #ifdef CONFIG_QETH_IPV6
8302 extern struct neigh_table arp_tbl
;
8303 static struct neigh_ops
*arp_direct_ops
;
8304 static int (*qeth_old_arp_constructor
) (struct neighbour
*);
8306 static struct neigh_ops arp_direct_ops_template
= {
8309 .error_report
= NULL
,
8310 .output
= dev_queue_xmit
,
8311 .connected_output
= dev_queue_xmit
,
8312 .hh_output
= dev_queue_xmit
,
8313 .queue_xmit
= dev_queue_xmit
8317 qeth_arp_constructor(struct neighbour
*neigh
)
8319 struct net_device
*dev
= neigh
->dev
;
8320 struct in_device
*in_dev
;
8321 struct neigh_parms
*parms
;
8322 struct qeth_card
*card
;
8324 card
= qeth_get_card_from_dev(dev
);
8327 if((card
->options
.layer2
) ||
8328 (card
->dev
->header_ops
== &qeth_fake_ops
))
8332 in_dev
= __in_dev_get_rcu(dev
);
8333 if (in_dev
== NULL
) {
8338 parms
= in_dev
->arp_parms
;
8339 __neigh_parms_put(neigh
->parms
);
8340 neigh
->parms
= neigh_parms_clone(parms
);
8343 neigh
->type
= inet_addr_type(&init_net
, *(__be32
*) neigh
->primary_key
);
8344 neigh
->nud_state
= NUD_NOARP
;
8345 neigh
->ops
= arp_direct_ops
;
8346 neigh
->output
= neigh
->ops
->queue_xmit
;
8349 return qeth_old_arp_constructor(neigh
);
8351 #endif /*CONFIG_QETH_IPV6*/
8354 * IP address takeover related functions
8357 qeth_clear_ipato_list(struct qeth_card
*card
)
8359 struct qeth_ipato_entry
*ipatoe
, *tmp
;
8360 unsigned long flags
;
8362 spin_lock_irqsave(&card
->ip_lock
, flags
);
8363 list_for_each_entry_safe(ipatoe
, tmp
, &card
->ipato
.entries
, entry
) {
8364 list_del(&ipatoe
->entry
);
8367 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
8371 qeth_add_ipato_entry(struct qeth_card
*card
, struct qeth_ipato_entry
*new)
8373 struct qeth_ipato_entry
*ipatoe
;
8374 unsigned long flags
;
8377 QETH_DBF_TEXT(trace
, 2, "addipato");
8378 spin_lock_irqsave(&card
->ip_lock
, flags
);
8379 list_for_each_entry(ipatoe
, &card
->ipato
.entries
, entry
){
8380 if (ipatoe
->proto
!= new->proto
)
8382 if (!memcmp(ipatoe
->addr
, new->addr
,
8383 (ipatoe
->proto
== QETH_PROT_IPV4
)? 4:16) &&
8384 (ipatoe
->mask_bits
== new->mask_bits
)){
8385 PRINT_WARN("ipato entry already exists!\n");
8391 list_add_tail(&new->entry
, &card
->ipato
.entries
);
8393 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
8398 qeth_del_ipato_entry(struct qeth_card
*card
, enum qeth_prot_versions proto
,
8399 u8
*addr
, int mask_bits
)
8401 struct qeth_ipato_entry
*ipatoe
, *tmp
;
8402 unsigned long flags
;
8404 QETH_DBF_TEXT(trace
, 2, "delipato");
8405 spin_lock_irqsave(&card
->ip_lock
, flags
);
8406 list_for_each_entry_safe(ipatoe
, tmp
, &card
->ipato
.entries
, entry
){
8407 if (ipatoe
->proto
!= proto
)
8409 if (!memcmp(ipatoe
->addr
, addr
,
8410 (proto
== QETH_PROT_IPV4
)? 4:16) &&
8411 (ipatoe
->mask_bits
== mask_bits
)){
8412 list_del(&ipatoe
->entry
);
8416 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
8420 qeth_convert_addr_to_bits(u8
*addr
, u8
*bits
, int len
)
8425 for (i
= 0; i
< len
; ++i
){
8427 for (j
= 7; j
>= 0; --j
){
8428 bits
[i
*8 + j
] = octet
& 1;
8435 qeth_is_addr_covered_by_ipato(struct qeth_card
*card
, struct qeth_ipaddr
*addr
)
8437 struct qeth_ipato_entry
*ipatoe
;
8438 u8 addr_bits
[128] = {0, };
8439 u8 ipatoe_bits
[128] = {0, };
8442 if (!card
->ipato
.enabled
)
8445 qeth_convert_addr_to_bits((u8
*) &addr
->u
, addr_bits
,
8446 (addr
->proto
== QETH_PROT_IPV4
)? 4:16);
8447 list_for_each_entry(ipatoe
, &card
->ipato
.entries
, entry
){
8448 if (addr
->proto
!= ipatoe
->proto
)
8450 qeth_convert_addr_to_bits(ipatoe
->addr
, ipatoe_bits
,
8451 (ipatoe
->proto
==QETH_PROT_IPV4
) ?
8453 if (addr
->proto
== QETH_PROT_IPV4
)
8454 rc
= !memcmp(addr_bits
, ipatoe_bits
,
8455 min(32, ipatoe
->mask_bits
));
8457 rc
= !memcmp(addr_bits
, ipatoe_bits
,
8458 min(128, ipatoe
->mask_bits
));
8463 if ((addr
->proto
== QETH_PROT_IPV4
) && card
->ipato
.invert4
)
8465 else if ((addr
->proto
== QETH_PROT_IPV6
) && card
->ipato
.invert6
)
8472 * VIPA related functions
8475 qeth_add_vipa(struct qeth_card
*card
, enum qeth_prot_versions proto
,
8478 struct qeth_ipaddr
*ipaddr
;
8479 unsigned long flags
;
8482 ipaddr
= qeth_get_addr_buffer(proto
);
8484 if (proto
== QETH_PROT_IPV4
){
8485 QETH_DBF_TEXT(trace
, 2, "addvipa4");
8486 memcpy(&ipaddr
->u
.a4
.addr
, addr
, 4);
8487 ipaddr
->u
.a4
.mask
= 0;
8488 #ifdef CONFIG_QETH_IPV6
8489 } else if (proto
== QETH_PROT_IPV6
){
8490 QETH_DBF_TEXT(trace
, 2, "addvipa6");
8491 memcpy(&ipaddr
->u
.a6
.addr
, addr
, 16);
8492 ipaddr
->u
.a6
.pfxlen
= 0;
8495 ipaddr
->type
= QETH_IP_TYPE_VIPA
;
8496 ipaddr
->set_flags
= QETH_IPA_SETIP_VIPA_FLAG
;
8497 ipaddr
->del_flags
= QETH_IPA_DELIP_VIPA_FLAG
;
8500 spin_lock_irqsave(&card
->ip_lock
, flags
);
8501 if (__qeth_address_exists_in_list(&card
->ip_list
, ipaddr
, 0) ||
8502 __qeth_address_exists_in_list(card
->ip_tbd_list
, ipaddr
, 0))
8504 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
8506 PRINT_WARN("Cannot add VIPA. Address already exists!\n");
8509 if (!qeth_add_ip(card
, ipaddr
))
8511 qeth_set_ip_addr_list(card
);
8516 qeth_del_vipa(struct qeth_card
*card
, enum qeth_prot_versions proto
,
8519 struct qeth_ipaddr
*ipaddr
;
8521 ipaddr
= qeth_get_addr_buffer(proto
);
8523 if (proto
== QETH_PROT_IPV4
){
8524 QETH_DBF_TEXT(trace
, 2, "delvipa4");
8525 memcpy(&ipaddr
->u
.a4
.addr
, addr
, 4);
8526 ipaddr
->u
.a4
.mask
= 0;
8527 #ifdef CONFIG_QETH_IPV6
8528 } else if (proto
== QETH_PROT_IPV6
){
8529 QETH_DBF_TEXT(trace
, 2, "delvipa6");
8530 memcpy(&ipaddr
->u
.a6
.addr
, addr
, 16);
8531 ipaddr
->u
.a6
.pfxlen
= 0;
8534 ipaddr
->type
= QETH_IP_TYPE_VIPA
;
8537 if (!qeth_delete_ip(card
, ipaddr
))
8539 qeth_set_ip_addr_list(card
);
8543 * proxy ARP related functions
8546 qeth_add_rxip(struct qeth_card
*card
, enum qeth_prot_versions proto
,
8549 struct qeth_ipaddr
*ipaddr
;
8550 unsigned long flags
;
8553 ipaddr
= qeth_get_addr_buffer(proto
);
8555 if (proto
== QETH_PROT_IPV4
){
8556 QETH_DBF_TEXT(trace
, 2, "addrxip4");
8557 memcpy(&ipaddr
->u
.a4
.addr
, addr
, 4);
8558 ipaddr
->u
.a4
.mask
= 0;
8559 #ifdef CONFIG_QETH_IPV6
8560 } else if (proto
== QETH_PROT_IPV6
){
8561 QETH_DBF_TEXT(trace
, 2, "addrxip6");
8562 memcpy(&ipaddr
->u
.a6
.addr
, addr
, 16);
8563 ipaddr
->u
.a6
.pfxlen
= 0;
8566 ipaddr
->type
= QETH_IP_TYPE_RXIP
;
8567 ipaddr
->set_flags
= QETH_IPA_SETIP_TAKEOVER_FLAG
;
8568 ipaddr
->del_flags
= 0;
8571 spin_lock_irqsave(&card
->ip_lock
, flags
);
8572 if (__qeth_address_exists_in_list(&card
->ip_list
, ipaddr
, 0) ||
8573 __qeth_address_exists_in_list(card
->ip_tbd_list
, ipaddr
, 0))
8575 spin_unlock_irqrestore(&card
->ip_lock
, flags
);
8577 PRINT_WARN("Cannot add RXIP. Address already exists!\n");
8580 if (!qeth_add_ip(card
, ipaddr
))
8582 qeth_set_ip_addr_list(card
);
8587 qeth_del_rxip(struct qeth_card
*card
, enum qeth_prot_versions proto
,
8590 struct qeth_ipaddr
*ipaddr
;
8592 ipaddr
= qeth_get_addr_buffer(proto
);
8594 if (proto
== QETH_PROT_IPV4
){
8595 QETH_DBF_TEXT(trace
, 2, "addrxip4");
8596 memcpy(&ipaddr
->u
.a4
.addr
, addr
, 4);
8597 ipaddr
->u
.a4
.mask
= 0;
8598 #ifdef CONFIG_QETH_IPV6
8599 } else if (proto
== QETH_PROT_IPV6
){
8600 QETH_DBF_TEXT(trace
, 2, "addrxip6");
8601 memcpy(&ipaddr
->u
.a6
.addr
, addr
, 16);
8602 ipaddr
->u
.a6
.pfxlen
= 0;
8605 ipaddr
->type
= QETH_IP_TYPE_RXIP
;
8608 if (!qeth_delete_ip(card
, ipaddr
))
8610 qeth_set_ip_addr_list(card
);
8617 qeth_ip_event(struct notifier_block
*this,
8618 unsigned long event
,void *ptr
)
8620 struct in_ifaddr
*ifa
= (struct in_ifaddr
*)ptr
;
8621 struct net_device
*dev
=(struct net_device
*) ifa
->ifa_dev
->dev
;
8622 struct qeth_ipaddr
*addr
;
8623 struct qeth_card
*card
;
8625 QETH_DBF_TEXT(trace
,3,"ipevent");
8626 card
= qeth_get_card_from_dev(dev
);
8629 if (card
->options
.layer2
)
8632 addr
= qeth_get_addr_buffer(QETH_PROT_IPV4
);
8634 addr
->u
.a4
.addr
= ifa
->ifa_address
;
8635 addr
->u
.a4
.mask
= ifa
->ifa_mask
;
8636 addr
->type
= QETH_IP_TYPE_NORMAL
;
8642 if (!qeth_add_ip(card
, addr
))
8646 if (!qeth_delete_ip(card
, addr
))
8652 qeth_set_ip_addr_list(card
);
8657 static struct notifier_block qeth_ip_notifier
= {
8662 #ifdef CONFIG_QETH_IPV6
8664 * IPv6 event handler
8667 qeth_ip6_event(struct notifier_block
*this,
8668 unsigned long event
,void *ptr
)
8671 struct inet6_ifaddr
*ifa
= (struct inet6_ifaddr
*)ptr
;
8672 struct net_device
*dev
= (struct net_device
*)ifa
->idev
->dev
;
8673 struct qeth_ipaddr
*addr
;
8674 struct qeth_card
*card
;
8676 QETH_DBF_TEXT(trace
,3,"ip6event");
8678 card
= qeth_get_card_from_dev(dev
);
8681 if (!qeth_is_supported(card
, IPA_IPV6
))
8684 addr
= qeth_get_addr_buffer(QETH_PROT_IPV6
);
8686 memcpy(&addr
->u
.a6
.addr
, &ifa
->addr
, sizeof(struct in6_addr
));
8687 addr
->u
.a6
.pfxlen
= ifa
->prefix_len
;
8688 addr
->type
= QETH_IP_TYPE_NORMAL
;
8694 if (!qeth_add_ip(card
, addr
))
8698 if (!qeth_delete_ip(card
, addr
))
8704 qeth_set_ip_addr_list(card
);
8709 static struct notifier_block qeth_ip6_notifier
= {
8716 __qeth_reboot_event_card(struct device
*dev
, void *data
)
8718 struct qeth_card
*card
;
8720 card
= (struct qeth_card
*) dev
->driver_data
;
8721 qeth_clear_ip_list(card
, 0, 0);
8722 qeth_qdio_clear_card(card
, 0);
8723 qeth_clear_qdio_buffers(card
);
8728 qeth_reboot_event(struct notifier_block
*this, unsigned long event
, void *ptr
)
8732 ret
= driver_for_each_device(&qeth_ccwgroup_driver
.driver
, NULL
, NULL
,
8733 __qeth_reboot_event_card
);
8734 return ret
? NOTIFY_BAD
: NOTIFY_DONE
;
8738 static struct notifier_block qeth_reboot_notifier
= {
8744 qeth_register_notifiers(void)
8748 QETH_DBF_TEXT(trace
,5,"regnotif");
8749 if ((r
= register_reboot_notifier(&qeth_reboot_notifier
)))
8751 if ((r
= register_inetaddr_notifier(&qeth_ip_notifier
)))
8753 #ifdef CONFIG_QETH_IPV6
8754 if ((r
= register_inet6addr_notifier(&qeth_ip6_notifier
)))
8759 #ifdef CONFIG_QETH_IPV6
8761 unregister_inetaddr_notifier(&qeth_ip_notifier
);
8764 unregister_reboot_notifier(&qeth_reboot_notifier
);
8769 * unregister all event notifiers
8772 qeth_unregister_notifiers(void)
8775 QETH_DBF_TEXT(trace
,5,"unregnot");
8776 BUG_ON(unregister_reboot_notifier(&qeth_reboot_notifier
));
8777 BUG_ON(unregister_inetaddr_notifier(&qeth_ip_notifier
));
8778 #ifdef CONFIG_QETH_IPV6
8779 BUG_ON(unregister_inet6addr_notifier(&qeth_ip6_notifier
));
8780 #endif /* QETH_IPV6 */
8784 #ifdef CONFIG_QETH_IPV6
8786 qeth_ipv6_init(void)
8788 qeth_old_arp_constructor
= arp_tbl
.constructor
;
8789 write_lock_bh(&arp_tbl
.lock
);
8790 arp_tbl
.constructor
= qeth_arp_constructor
;
8791 write_unlock_bh(&arp_tbl
.lock
);
8793 arp_direct_ops
= (struct neigh_ops
*)
8794 kmalloc(sizeof(struct neigh_ops
), GFP_KERNEL
);
8795 if (!arp_direct_ops
)
8798 memcpy(arp_direct_ops
, &arp_direct_ops_template
,
8799 sizeof(struct neigh_ops
));
8805 qeth_ipv6_uninit(void)
8807 write_lock_bh(&arp_tbl
.lock
);
8808 arp_tbl
.constructor
= qeth_old_arp_constructor
;
8809 write_unlock_bh(&arp_tbl
.lock
);
8810 kfree(arp_direct_ops
);
8812 #endif /* CONFIG_QETH_IPV6 */
8815 qeth_sysfs_unregister(void)
8817 s390_root_dev_unregister(qeth_root_dev
);
8818 qeth_remove_driver_attributes();
8819 ccw_driver_unregister(&qeth_ccw_driver
);
8820 ccwgroup_driver_unregister(&qeth_ccwgroup_driver
);
8824 * register qeth at sysfs
8827 qeth_sysfs_register(void)
8831 rc
= ccwgroup_driver_register(&qeth_ccwgroup_driver
);
8835 rc
= ccw_driver_register(&qeth_ccw_driver
);
8837 goto out_ccw_driver
;
8839 rc
= qeth_create_driver_attributes();
8843 qeth_root_dev
= s390_root_dev_register("qeth");
8844 rc
= IS_ERR(qeth_root_dev
) ? PTR_ERR(qeth_root_dev
) : 0;
8848 qeth_remove_driver_attributes();
8850 ccw_driver_unregister(&qeth_ccw_driver
);
8852 ccwgroup_driver_unregister(&qeth_ccwgroup_driver
);
8865 PRINT_INFO("loading %s\n", version
);
8867 INIT_LIST_HEAD(&qeth_card_list
.list
);
8868 INIT_LIST_HEAD(&qeth_notify_list
);
8869 spin_lock_init(&qeth_notify_lock
);
8870 rwlock_init(&qeth_card_list
.rwlock
);
8872 rc
= qeth_register_dbf_views();
8876 rc
= qeth_sysfs_register();
8880 #ifdef CONFIG_QETH_IPV6
8881 rc
= qeth_ipv6_init();
8883 PRINT_ERR("Out of memory during ipv6 init code = %d\n", rc
);
8886 #endif /* QETH_IPV6 */
8887 rc
= qeth_register_notifiers();
8890 rc
= qeth_create_procfs_entries();
8897 qeth_unregister_notifiers();
8899 #ifdef CONFIG_QETH_IPV6
8902 #endif /* QETH_IPV6 */
8903 qeth_sysfs_unregister();
8905 qeth_unregister_dbf_views();
8907 PRINT_ERR("Initialization failed with code %d\n", rc
);
8912 __exit
qeth_exit(void)
8914 struct qeth_card
*card
, *tmp
;
8915 unsigned long flags
;
8917 QETH_DBF_TEXT(trace
,1, "cleanup.");
8920 * Weed would not need to clean up our devices here, because the
8921 * common device layer calls qeth_remove_device for each device
8922 * as soon as we unregister our driver (done in qeth_sysfs_unregister).
8923 * But we do cleanup here so we can do a "soft" shutdown of our cards.
8924 * qeth_remove_device called by the common device layer would otherwise
8925 * do a "hard" shutdown (card->use_hard_stop is set to one in
8926 * qeth_remove_device).
8929 read_lock_irqsave(&qeth_card_list
.rwlock
, flags
);
8930 list_for_each_entry_safe(card
, tmp
, &qeth_card_list
.list
, list
){
8931 read_unlock_irqrestore(&qeth_card_list
.rwlock
, flags
);
8932 qeth_set_offline(card
->gdev
);
8933 qeth_remove_device(card
->gdev
);
8936 read_unlock_irqrestore(&qeth_card_list
.rwlock
, flags
);
8937 #ifdef CONFIG_QETH_IPV6
8940 qeth_unregister_notifiers();
8941 qeth_remove_procfs_entries();
8942 qeth_sysfs_unregister();
8943 qeth_unregister_dbf_views();
8944 printk("qeth: removed\n");
8947 EXPORT_SYMBOL(qeth_osn_register
);
8948 EXPORT_SYMBOL(qeth_osn_deregister
);
8949 EXPORT_SYMBOL(qeth_osn_assist
);
8950 module_init(qeth_init
);
8951 module_exit(qeth_exit
);
8952 MODULE_AUTHOR("Frank Pavlic <fpavlic@de.ibm.com>");
8953 MODULE_DESCRIPTION("Linux on zSeries OSA Express and HiperSockets support\n" \
8954 "Copyright 2000,2003 IBM Corporation\n");
8956 MODULE_LICENSE("GPL");