Lines Matching refs:rcv
340 struct plip_local *rcv,
349 struct plip_local *snd, struct plip_local *rcv);
366 struct plip_local *rcv = &nl->rcv_data; in plip_bh() local
372 if ((r = (*f)(nl->dev, nl, snd, rcv)) != OK in plip_bh()
373 && (r = plip_bh_timeout_error(nl->dev, nl, snd, rcv, r)) != OK) { in plip_bh()
397 struct plip_local *snd, struct plip_local *rcv, in plip_bh_timeout_error() argument
431 if (rcv->state == PLIP_PK_TRIGGER) { in plip_bh_timeout_error()
444 dev->name, rcv->state, c0); in plip_bh_timeout_error()
448 rcv->state = PLIP_PK_DONE; in plip_bh_timeout_error()
449 if (rcv->skb) { in plip_bh_timeout_error()
450 kfree_skb(rcv->skb); in plip_bh_timeout_error()
451 rcv->skb = NULL; in plip_bh_timeout_error()
473 struct plip_local *snd, struct plip_local *rcv) in plip_none() argument
584 struct plip_local *snd, struct plip_local *rcv) in plip_receive_packet() argument
589 switch (rcv->state) { in plip_receive_packet()
597 rcv->state = PLIP_PK_LENGTH_LSB; in plip_receive_packet()
598 rcv->nibble = PLIP_NB_BEGIN; in plip_receive_packet()
603 &rcv->nibble, &rcv->length.b.lsb)) { in plip_receive_packet()
605 rcv->state = PLIP_PK_DONE; in plip_receive_packet()
615 &rcv->nibble, &rcv->length.b.lsb)) in plip_receive_packet()
618 rcv->state = PLIP_PK_LENGTH_MSB; in plip_receive_packet()
622 &rcv->nibble, &rcv->length.b.msb)) in plip_receive_packet()
624 if (rcv->length.h > dev->mtu + dev->hard_header_len in plip_receive_packet()
625 || rcv->length.h < 8) { in plip_receive_packet()
626 printk(KERN_WARNING "%s: bogus packet size %d.\n", dev->name, rcv->length.h); in plip_receive_packet()
630 rcv->skb = dev_alloc_skb(rcv->length.h + 2); in plip_receive_packet()
631 if (rcv->skb == NULL) { in plip_receive_packet()
635 skb_reserve(rcv->skb, 2); /* Align IP on 16 byte boundaries */ in plip_receive_packet()
636 skb_put(rcv->skb,rcv->length.h); in plip_receive_packet()
637 rcv->skb->dev = dev; in plip_receive_packet()
638 rcv->state = PLIP_PK_DATA; in plip_receive_packet()
639 rcv->byte = 0; in plip_receive_packet()
640 rcv->checksum = 0; in plip_receive_packet()
643 lbuf = rcv->skb->data; in plip_receive_packet()
646 &rcv->nibble, &lbuf[rcv->byte])) in plip_receive_packet()
648 } while (++rcv->byte < rcv->length.h); in plip_receive_packet()
650 rcv->checksum += lbuf[--rcv->byte]; in plip_receive_packet()
651 } while (rcv->byte); in plip_receive_packet()
652 rcv->state = PLIP_PK_CHECKSUM; in plip_receive_packet()
656 &rcv->nibble, &rcv->data)) in plip_receive_packet()
658 if (rcv->data != rcv->checksum) { in plip_receive_packet()
664 rcv->state = PLIP_PK_DONE; in plip_receive_packet()
668 rcv->skb->protocol=plip_type_trans(rcv->skb, dev); in plip_receive_packet()
669 netif_rx_ni(rcv->skb); in plip_receive_packet()
670 dev->stats.rx_bytes += rcv->length.h; in plip_receive_packet()
672 rcv->skb = NULL; in plip_receive_packet()
745 struct plip_local *snd, struct plip_local *rcv) in plip_send_packet() argument
860 struct plip_local *snd, struct plip_local *rcv) in plip_connection_close() argument
878 struct plip_local *snd, struct plip_local *rcv) in plip_error() argument
906 struct plip_local *rcv; in plip_interrupt() local
911 rcv = &nl->rcv_data; in plip_interrupt()
931 rcv->state = PLIP_PK_TRIGGER; in plip_interrupt()
1110 struct plip_local *rcv = &nl->rcv_data; in plip_close() local
1138 rcv->state = PLIP_PK_DONE; in plip_close()
1139 if (rcv->skb) { in plip_close()
1140 kfree_skb(rcv->skb); in plip_close()
1141 rcv->skb = NULL; in plip_close()