Lines Matching refs:vcc

122 static int idt77252_open(struct atm_vcc *vcc);
123 static void idt77252_close(struct atm_vcc *vcc);
124 static int idt77252_send(struct atm_vcc *vcc, struct sk_buff *skb);
125 static int idt77252_send_oam(struct atm_vcc *vcc, void *cell,
130 static int idt77252_change_qos(struct atm_vcc *vcc, struct atm_qos *qos,
549 struct atm_vcc *vcc; in idt77252_tx_dump() local
559 vcc = NULL; in idt77252_tx_dump()
561 vcc = vc->rx_vcc; in idt77252_tx_dump()
563 vcc = vc->tx_vcc; in idt77252_tx_dump()
565 if (!vcc) in idt77252_tx_dump()
671 struct atm_vcc *vcc; in free_scq() local
680 vcc = ATM_SKB(skb)->vcc; in free_scq()
681 if (vcc->pop) in free_scq()
682 vcc->pop(vcc, skb); in free_scq()
691 vcc = ATM_SKB(skb)->vcc; in free_scq()
692 if (vcc->pop) in free_scq()
693 vcc->pop(vcc, skb); in free_scq()
723 struct atm_vcc *vcc = vc->tx_vcc; in push_on_scq() local
724 struct sock *sk = sk_atm(vcc); in push_on_scq()
795 struct atm_vcc *vcc; in drain_scq() local
807 vcc = ATM_SKB(skb)->vcc; in drain_scq()
809 if (vcc->pop) in drain_scq()
810 vcc->pop(vcc, skb); in drain_scq()
814 atomic_inc(&vcc->stats->tx); in drain_scq()
833 struct atm_vcc *vcc; in queue_skb() local
848 vcc = ATM_SKB(skb)->vcc; in queue_skb()
876 aal = vcc->qos.aal; in queue_skb()
901 tbd->word_4 = (vcc->vpi << SAR_TBD_VPI_SHIFT) | in queue_skb()
902 (vcc->vci << SAR_TBD_VCI_SHIFT); in queue_skb()
1012 struct atm_vcc *vcc; in dequeue_rx() local
1059 vcc = vc->rx_vcc; in dequeue_rx()
1065 if ((vcc->qos.aal == ATM_AAL0) || in dequeue_rx()
1066 (vcc->qos.aal == ATM_AAL34)) { in dequeue_rx()
1076 atomic_add(i, &vcc->stats->rx_drop); in dequeue_rx()
1079 if (!atm_charge(vcc, sb->truesize)) { in dequeue_rx()
1082 atomic_add(i - 1, &vcc->stats->rx_drop); in dequeue_rx()
1096 ATM_SKB(sb)->vcc = vcc; in dequeue_rx()
1098 vcc->push(vcc, sb); in dequeue_rx()
1099 atomic_inc(&vcc->stats->rx); in dequeue_rx()
1107 if (vcc->qos.aal != ATM_AAL5) { in dequeue_rx()
1109 card->name, vcc->qos.aal); in dequeue_rx()
1136 atomic_inc(&vcc->stats->rx_err); in dequeue_rx()
1142 atomic_inc(&vcc->stats->rx_err); in dequeue_rx()
1153 atomic_inc(&vcc->stats->rx_err); in dequeue_rx()
1156 if (!atm_charge(vcc, skb->truesize)) { in dequeue_rx()
1168 ATM_SKB(skb)->vcc = vcc; in dequeue_rx()
1171 vcc->push(vcc, skb); in dequeue_rx()
1172 atomic_inc(&vcc->stats->rx); in dequeue_rx()
1179 if (!atm_charge(vcc, skb->truesize)) { in dequeue_rx()
1190 ATM_SKB(skb)->vcc = vcc; in dequeue_rx()
1193 vcc->push(vcc, skb); in dequeue_rx()
1194 atomic_inc(&vcc->stats->rx); in dequeue_rx()
1242 struct atm_vcc *vcc; in idt77252_rx_raw() local
1300 vcc = vc->rx_vcc; in idt77252_rx_raw()
1302 if (vcc->qos.aal != ATM_AAL0) { in idt77252_rx_raw()
1305 atomic_inc(&vcc->stats->rx_drop); in idt77252_rx_raw()
1312 atomic_inc(&vcc->stats->rx_err); in idt77252_rx_raw()
1316 if (!atm_charge(vcc, sb->truesize)) { in idt77252_rx_raw()
1328 ATM_SKB(sb)->vcc = vcc; in idt77252_rx_raw()
1330 vcc->push(vcc, sb); in idt77252_rx_raw()
1331 atomic_inc(&vcc->stats->rx); in idt77252_rx_raw()
1947 idt77252_send_skb(struct atm_vcc *vcc, struct sk_buff *skb, int oam) in idt77252_send_skb() argument
1949 struct atm_dev *dev = vcc->dev; in idt77252_send_skb()
1951 struct vc_map *vc = vcc->dev_data; in idt77252_send_skb()
1956 atomic_inc(&vcc->stats->tx_err); in idt77252_send_skb()
1962 atomic_inc(&vcc->stats->tx_err); in idt77252_send_skb()
1967 switch (vcc->qos.aal) { in idt77252_send_skb()
1973 printk("%s: Unsupported AAL: %d\n", card->name, vcc->qos.aal); in idt77252_send_skb()
1974 atomic_inc(&vcc->stats->tx_err); in idt77252_send_skb()
1981 atomic_inc(&vcc->stats->tx_err); in idt77252_send_skb()
1985 ATM_SKB(skb)->vcc = vcc; in idt77252_send_skb()
1989 atomic_inc(&vcc->stats->tx_err); in idt77252_send_skb()
1997 static int idt77252_send(struct atm_vcc *vcc, struct sk_buff *skb) in idt77252_send() argument
1999 return idt77252_send_skb(vcc, skb, 0); in idt77252_send()
2003 idt77252_send_oam(struct atm_vcc *vcc, void *cell, int flags) in idt77252_send_oam() argument
2005 struct atm_dev *dev = vcc->dev; in idt77252_send_oam()
2012 atomic_inc(&vcc->stats->tx_err); in idt77252_send_oam()
2015 atomic_add(skb->truesize, &sk_atm(vcc)->sk_wmem_alloc); in idt77252_send_oam()
2019 return idt77252_send_skb(vcc, skb, 1); in idt77252_send_oam()
2147 struct atm_vcc *vcc, struct atm_qos *qos) in idt77252_init_cbr() argument
2217 struct atm_vcc *vcc, struct atm_qos *qos) in idt77252_init_ubr() argument
2249 struct atm_vcc *vcc, struct atm_qos *qos) in idt77252_init_tx() argument
2297 error = idt77252_init_cbr(card, vc, vcc, qos); in idt77252_init_tx()
2309 error = idt77252_init_ubr(card, vc, vcc, qos); in idt77252_init_tx()
2320 vc->tx_vcc = vcc; in idt77252_init_tx()
2327 struct atm_vcc *vcc, struct atm_qos *qos) in idt77252_init_rx() argument
2336 vc->rx_vcc = vcc; in idt77252_init_rx()
2339 if ((vcc->vci == 3) || (vcc->vci == 4)) in idt77252_init_rx()
2390 idt77252_open(struct atm_vcc *vcc) in idt77252_open() argument
2392 struct atm_dev *dev = vcc->dev; in idt77252_open()
2398 int vci = vcc->vci; in idt77252_open()
2399 short vpi = vcc->vpi; in idt77252_open()
2414 set_bit(ATM_VF_ADDR, &vcc->flags); in idt77252_open()
2420 switch (vcc->qos.aal) { in idt77252_open()
2426 printk("%s: Unsupported AAL: %d\n", card->name, vcc->qos.aal); in idt77252_open()
2446 vcc->dev_data = vc; in idt77252_open()
2449 card->name, vc->index, vcc->vpi, vcc->vci, in idt77252_open()
2450 vcc->qos.rxtp.traffic_class != ATM_NONE ? "rx" : "--", in idt77252_open()
2451 vcc->qos.txtp.traffic_class != ATM_NONE ? "tx" : "--", in idt77252_open()
2452 vcc->qos.rxtp.max_sdu); in idt77252_open()
2455 if (vcc->qos.txtp.traffic_class != ATM_NONE && in idt77252_open()
2458 if (vcc->qos.rxtp.traffic_class != ATM_NONE && in idt77252_open()
2469 if (vcc->qos.txtp.traffic_class != ATM_NONE) { in idt77252_open()
2470 error = idt77252_init_tx(card, vc, vcc, &vcc->qos); in idt77252_open()
2477 if (vcc->qos.rxtp.traffic_class != ATM_NONE) { in idt77252_open()
2478 error = idt77252_init_rx(card, vc, vcc, &vcc->qos); in idt77252_open()
2485 set_bit(ATM_VF_READY, &vcc->flags); in idt77252_open()
2492 idt77252_close(struct atm_vcc *vcc) in idt77252_close() argument
2494 struct atm_dev *dev = vcc->dev; in idt77252_close()
2496 struct vc_map *vc = vcc->dev_data; in idt77252_close()
2504 card->name, vc->index, vcc->vpi, vcc->vci); in idt77252_close()
2506 clear_bit(ATM_VF_READY, &vcc->flags); in idt77252_close()
2508 if (vcc->qos.rxtp.traffic_class != ATM_NONE) { in idt77252_close()
2515 if ((vcc->vci == 3) || (vcc->vci == 4)) in idt77252_close()
2534 if (vcc->qos.txtp.traffic_class != ATM_NONE) { in idt77252_close()
2576 idt77252_change_qos(struct atm_vcc *vcc, struct atm_qos *qos, int flags) in idt77252_change_qos() argument
2578 struct atm_dev *dev = vcc->dev; in idt77252_change_qos()
2580 struct vc_map *vc = vcc->dev_data; in idt77252_change_qos()
2587 error = idt77252_init_tx(card, vc, vcc, qos); in idt77252_change_qos()
2593 error = idt77252_init_cbr(card, vc, vcc, qos); in idt77252_change_qos()
2599 error = idt77252_init_ubr(card, vc, vcc, qos); in idt77252_change_qos()
2619 error = idt77252_init_rx(card, vc, vcc, qos); in idt77252_change_qos()
2624 memcpy(&vcc->qos, qos, sizeof(struct atm_qos)); in idt77252_change_qos()
2626 set_bit(ATM_VF_HASQOS, &vcc->flags); in idt77252_change_qos()
2673 struct atm_vcc *vcc; in idt77252_proc_read() local
2681 vcc = NULL; in idt77252_proc_read()
2683 vcc = vc->tx_vcc; in idt77252_proc_read()
2684 if (!vcc) in idt77252_proc_read()
2690 p += sprintf(p, " %4u: %u.%u: ", i, vcc->vpi, vcc->vci); in idt77252_proc_read()