Lines Matching refs:tcl

109 #define	KCINCR(vn)	KINCR(tcl, tcl_kstats, vn)
110 #define KCDECR(vn) KDECR(tcl, tcl_kstats, vn)
275 tuncl_t *tcl = NULL; in tuncl_alloc() local
335 tcl = kmem_cache_alloc(tcl_cache, KM_NOSLEEP); in tuncl_alloc()
336 if (tcl == NULL) { in tuncl_alloc()
341 bzero(tcl, sizeof (*tcl)); in tuncl_alloc()
342 tcl->tcl_lsessid = dminor; in tuncl_alloc()
344 tcl_slots[dminor - 1] = tcl; in tuncl_alloc()
348 return (tcl); in tuncl_alloc()
359 tuncl_free(tuncl_t *tcl) in tuncl_free() argument
362 ASSERT(tcl->tcl_lsessid <= tcl_nslots); in tuncl_free()
363 ASSERT(tcl_slots[tcl->tcl_lsessid - 1] == tcl); in tuncl_free()
366 tcl_slots[tcl->tcl_lsessid - 1] = NULL; in tuncl_free()
368 if (tcl->tcl_ksp != NULL) { in tuncl_free()
369 kstat_delete(tcl->tcl_ksp); in tuncl_free()
370 tcl->tcl_ksp = NULL; in tuncl_free()
374 vmem_free(tcl_minor_arena, (void *)(uintptr_t)tcl->tcl_lsessid, 1); in tuncl_free()
377 kmem_cache_free(tcl_cache, tcl); in tuncl_free()
390 tuncl_t *tcl = NULL; in tcl_by_minor() local
393 tcl = tcl_slots[dminor - 1]; in tcl_by_minor()
396 return (tcl); in tcl_by_minor()
494 tuncl_t *tcl; in sppptun_open() local
498 tcl = tuncl_alloc(-1); in sppptun_open()
509 if (mn == 0 || (tcl = tcl_by_minor(mn)) != NULL) { in sppptun_open()
512 tcl = tuncl_alloc(mn); in sppptun_open()
514 if (tcl == NULL) in sppptun_open()
516 tcl->tcl_rq = q; /* save read queue pointer */ in sppptun_open()
517 tcl->tcl_flags |= TCLF_ISCLIENT; /* sanity check */ in sppptun_open()
518 tcl->tcl_zoneid = crgetzoneid(credp); in sppptun_open()
520 q->q_ptr = WR(q)->q_ptr = (caddr_t)tcl; in sppptun_open()
521 *devp = makedevice(getmajor(*devp), tcl->tcl_lsessid); in sppptun_open()
523 tcl->tcl_ksp = kstat_setup((kstat_named_t *)&tcl->tcl_kstats, in sppptun_open()
525 tcl->tcl_lsessid); in sppptun_open()
564 send_control(tuncl_t *tclabout, tunll_t *tllabout, int action, tuncl_t *tcl) in send_control() argument
568 if (tcl->tcl_rq != NULL) { in send_control()
569 mp = make_control(tclabout, tllabout, action, tcl); in send_control()
572 putnext(tcl->tcl_rq, mp); in send_control()
593 tuncl_t *tcl; in tclvm_remove_tll() local
597 tcl = tcl_slots[minorn - 1]; in tclvm_remove_tll()
598 ASSERT(tcl != NULL); in tclvm_remove_tll()
599 if (tcl->tcl_data_tll == tll && tcl->tcl_rq != NULL) { in tclvm_remove_tll()
600 tcl->tcl_data_tll = NULL; in tclvm_remove_tll()
604 putnext(tcl->tcl_rq, mp); in tclvm_remove_tll()
605 if (tcl->tcl_ctrl_tll == tll) in tclvm_remove_tll()
606 tcl->tcl_ctrl_tll = NULL; in tclvm_remove_tll()
609 if (tcl->tcl_ctrl_tll == tll) { in tclvm_remove_tll()
610 send_control(tcl, tll, PTCA_UNPLUMB, tcl); in tclvm_remove_tll()
611 tcl->tcl_ctrl_tll = NULL; in tclvm_remove_tll()
633 tuncl_t *tcl; in sppptun_close() local
647 if ((tcl = tll->tll_defcl) != NULL) in sppptun_close()
648 send_control(NULL, tll, PTCA_UNPLUMB, tcl); in sppptun_close()
670 tcl = qptr; in sppptun_close()
676 DTRACE_PROBE1(sppptun__client__close, tuncl_t *, tcl); in sppptun_close()
677 tcl->tcl_rq = NULL; in sppptun_close()
682 if (tll->tll_defcl == tcl) in sppptun_close()
684 if (tll->tll_lastcl == tcl) in sppptun_close()
691 if (!(tcl->tcl_flags & TCLF_DAEMON) && in sppptun_close()
692 (tll = tcl->tcl_ctrl_tll) != NULL && in sppptun_close()
694 send_control(tcl, tll, PTCA_DISCONNECT, in sppptun_close()
699 if ((tll = tcl->tcl_data_tll) != NULL) { in sppptun_close()
702 if ((tll = tcl->tcl_ctrl_tll) != NULL) { in sppptun_close()
706 tuncl_free(tcl); in sppptun_close()
786 tuncl_t *tcl; in sppptun_outpkt() local
800 tcl = q->q_ptr; in sppptun_outpkt()
803 if (!(tcl->tcl_flags & TCLF_ISCLIENT)) { in sppptun_outpkt()
811 tll = tcl->tcl_data_tll; in sppptun_outpkt()
821 DTRACE_PROBE2(sppptun__bad__control, tuncl_t *, tcl, in sppptun_outpkt()
823 send_control(tcl, tcl->tcl_ctrl_tll, PTCA_BADCTRL, tcl); in sppptun_outpkt()
830 if (tcl->tcl_ctlval == 0) in sppptun_outpkt()
831 tcl->tcl_ctlval = ptc->ptc_discrim; in sppptun_outpkt()
835 DTRACE_PROBE2(sppptun__test, tuncl_t *, tcl, in sppptun_outpkt()
841 ptc->ptc_discrim = tcl->tcl_ctlval; in sppptun_outpkt()
847 if (tcl->tcl_ctlval != ptc->ptc_discrim) { in sppptun_outpkt()
848 DTRACE_PROBE2(sppptun__bad__discrim, tuncl_t *, tcl, in sppptun_outpkt()
855 tll = tcl->tcl_ctrl_tll; in sppptun_outpkt()
858 DTRACE_PROBE2(sppptun__bad__control, tuncl_t *, tcl, in sppptun_outpkt()
860 send_control(tcl, tll, PTCA_BADCTRL, tcl); in sppptun_outpkt()
867 DTRACE_PROBE3(sppptun__cannot__send, tuncl_t *, tcl, in sppptun_outpkt()
869 send_control(tcl, tll, PTCA_UNPLUMB, tcl); in sppptun_outpkt()
872 tcl->tcl_stats.ppp_oerrors++; in sppptun_outpkt()
886 DTRACE_PROBE3(sppptun__flow__control, tuncl_t *, tcl, in sppptun_outpkt()
902 bcmp(&tcl->tcl_address, &tll->tll_lcladdr, in sppptun_outpkt()
918 if (tcl->tcl_address.pta_pppoe.ptma_mac[0] & 1) in sppptun_outpkt()
929 ether_copy(tcl->tcl_address.pta_pppoe.ptma_mac, in sppptun_outpkt()
942 poep->poep_session_id = htons(tcl->tcl_rsessid); in sppptun_outpkt()
989 if (bcmp(tcl->tcl_address.pta_pppoe.ptma_mac, in sppptun_outpkt()
991 (tcl->tcl_flags & TCLF_DAEMON)) { in sppptun_outpkt()
995 ether_copy(tcl->tcl_address.pta_pppoe.ptma_mac, in sppptun_outpkt()
1015 DTRACE_PROBE1(sppptun__output__failure, tuncl_t *, tcl); in sppptun_outpkt()
1019 tcl->tcl_stats.ppp_oerrors++; in sppptun_outpkt()
1027 tcl->tcl_stats.ppp_obytes += msgsize(mp); in sppptun_outpkt()
1028 tcl->tcl_stats.ppp_opackets++; in sppptun_outpkt()
1112 tuncl_t *tcl; in sppptun_inner_ioctl() local
1123 tcl = NULL; in sppptun_inner_ioctl()
1126 tcl = (tuncl_t *)tll; in sppptun_inner_ioctl()
1130 DTRACE_PROBE3(sppptun__ioctl, tuncl_t *, tcl, tunll_t *, tll, in sppptun_inner_ioctl()
1147 if (tcl == NULL) { in sppptun_inner_ioctl()
1161 psp->p = tcl->tcl_stats; in sppptun_inner_ioctl()
1197 tcl == NULL ? tll->tll_zoneid : tcl->tcl_zoneid); in sppptun_inner_ioctl()
1200 if (tcl != NULL && pti->pti_name[0] == '\0') in sppptun_inner_ioctl()
1246 zoneid = tcl == NULL ? tll->tll_zoneid : tcl->tcl_zoneid; in sppptun_inner_ioctl()
1283 if (tcl == NULL || mp->b_cont == NULL || in sppptun_inner_ioctl()
1288 if (tcl->tcl_data_tll != NULL) { in sppptun_inner_ioctl()
1293 DTRACE_PROBE2(sppptun__speer, tuncl_t *, tcl, in sppptun_inner_ioctl()
1296 if (tcl->tcl_style != PTS_NONE && in sppptun_inner_ioctl()
1297 tcl->tcl_style != ptp->ptp_style) { in sppptun_inner_ioctl()
1303 if ((tcl->tcl_flags & TCLF_SPEER_DONE) || in sppptun_inner_ioctl()
1309 tcl->tcl_flags |= TCLF_DAEMON; in sppptun_inner_ioctl()
1312 if (tcl->tcl_flags & TCLF_DAEMON) { in sppptun_inner_ioctl()
1317 ptp->ptp_lsessid != tcl->tcl_lsessid) { in sppptun_inner_ioctl()
1326 if ((tcl->tcl_flags & TCLF_SPEER_DONE) && in sppptun_inner_ioctl()
1327 ((tcl->tcl_ltunid != 0 && in sppptun_inner_ioctl()
1328 tcl->tcl_ltunid != ptp->ptp_ltunid) || in sppptun_inner_ioctl()
1329 (tcl->tcl_rtunid != 0 && in sppptun_inner_ioctl()
1330 tcl->tcl_rtunid != ptp->ptp_rtunid) || in sppptun_inner_ioctl()
1331 (tcl->tcl_rsessid != 0 && in sppptun_inner_ioctl()
1332 tcl->tcl_rsessid != ptp->ptp_rsessid))) { in sppptun_inner_ioctl()
1336 if ((tcl->tcl_ltunid = ptp->ptp_ltunid) == 0 && in sppptun_inner_ioctl()
1337 tcl->tcl_style == PTS_L2FTP) in sppptun_inner_ioctl()
1338 tcl->tcl_ltunid = ptp->ptp_lsessid; in sppptun_inner_ioctl()
1339 tcl->tcl_rtunid = ptp->ptp_rtunid; in sppptun_inner_ioctl()
1340 tcl->tcl_rsessid = ptp->ptp_rsessid; in sppptun_inner_ioctl()
1342 tcl->tcl_flags |= TCLF_SPEER_DONE; in sppptun_inner_ioctl()
1343 tcl->tcl_style = ptp->ptp_style; in sppptun_inner_ioctl()
1344 tcl->tcl_address = ptp->ptp_address; in sppptun_inner_ioctl()
1349 if (tcl == NULL) { in sppptun_inner_ioctl()
1362 ptp->ptp_style = tcl->tcl_style; in sppptun_inner_ioctl()
1363 ptp->ptp_flags = (tcl->tcl_flags & TCLF_DAEMON) ? PTPF_DAEMON : in sppptun_inner_ioctl()
1365 ptp->ptp_ltunid = tcl->tcl_ltunid; in sppptun_inner_ioctl()
1366 ptp->ptp_rtunid = tcl->tcl_rtunid; in sppptun_inner_ioctl()
1367 ptp->ptp_lsessid = tcl->tcl_lsessid; in sppptun_inner_ioctl()
1368 ptp->ptp_rsessid = tcl->tcl_rsessid; in sppptun_inner_ioctl()
1369 ptp->ptp_address = tcl->tcl_address; in sppptun_inner_ioctl()
1376 if (tcl == NULL || mp->b_cont == NULL || in sppptun_inner_ioctl()
1382 if (!(tcl->tcl_flags & TCLF_SPEER_DONE)) { in sppptun_inner_ioctl()
1388 tll = tll_lookup_on_name(ptn->ptn_name, tcl->tcl_zoneid); in sppptun_inner_ioctl()
1393 if (tll->tll_style != tcl->tcl_style) { in sppptun_inner_ioctl()
1398 if (tcl->tcl_data_tll != NULL) { in sppptun_inner_ioctl()
1403 if (tcl->tcl_flags & TCLF_DAEMON) { in sppptun_inner_ioctl()
1407 tcl->tcl_data_tll = tll; in sppptun_inner_ioctl()
1408 } else if (tcl->tcl_flags & TCLF_DAEMON) { in sppptun_inner_ioctl()
1409 if (tll->tll_defcl != NULL && tll->tll_defcl != tcl) { in sppptun_inner_ioctl()
1413 tll->tll_defcl = tcl; in sppptun_inner_ioctl()
1414 if (tcl->tcl_ctrl_tll != NULL) { in sppptun_inner_ioctl()
1415 KDECR(tcl->tcl_ctrl_tll, tll_kstats, in sppptun_inner_ioctl()
1418 tcl->tcl_ctrl_tll = tll; in sppptun_inner_ioctl()
1420 if (tcl->tcl_ctrl_tll != NULL) { in sppptun_inner_ioctl()
1424 tcl->tcl_ctrl_tll = tll; in sppptun_inner_ioctl()
1432 if (tcl == NULL) { in sppptun_inner_ioctl()
1445 tll = tcl->tcl_data_tll; in sppptun_inner_ioctl()
1447 tll = tcl->tcl_ctrl_tll; in sppptun_inner_ioctl()
1458 if (tcl == NULL || mp->b_cont == NULL || in sppptun_inner_ioctl()
1460 !(tcl->tcl_flags & TCLF_DAEMON)) { in sppptun_inner_ioctl()
1466 tll = tll_lookup_on_name(ptn->ptn_name, tcl->tcl_zoneid); in sppptun_inner_ioctl()
1467 if (tll == NULL || tll->tll_defcl != tcl) { in sppptun_inner_ioctl()
1608 tuncl_t *tcl; in sppptun_inner_mctl() local
1610 tcl = q->q_ptr; in sppptun_inner_mctl()
1612 if (!(tcl->tcl_flags & TCLF_ISCLIENT)) { in sppptun_inner_mctl()
1621 tcl->tcl_unit = mp->b_rptr[1]; in sppptun_inner_mctl()
1623 tcl->tcl_unit = ((uint32_t *)mp->b_rptr)[1]; in sppptun_inner_mctl()
1642 tuncl_t *tcl; in sppptun_uwput() local
1664 tcl = (tuncl_t *)q->q_ptr; in sppptun_uwput()
1669 if (tcl->tcl_flags & TCLF_ISCLIENT) in sppptun_uwput()
1756 tuncl_t *tcl; in tclvm_backenable() local
1760 tcl = tcl_slots[minorn - 1]; in tclvm_backenable()
1761 if ((tcl->tcl_data_tll == tll || in tclvm_backenable()
1762 tcl->tcl_ctrl_tll == tll) && in tclvm_backenable()
1763 (q = tcl->tcl_rq) != NULL) { in tclvm_backenable()
1786 tuncl_t *tcl; in sppptun_uwsrv() local
1790 tcl = q->q_ptr; in sppptun_uwsrv()
1791 if (!(tcl->tcl_flags & TCLF_ISCLIENT)) { in sppptun_uwsrv()
1792 tunll_t *tll = (tunll_t *)tcl; in sppptun_uwsrv()
1857 tuncl_t *tcl; in sppptun_lrput() local
1880 if ((tcl = (tuncl_t *)q->q_ptr) == NULL || tcl->tcl_rq == NULL) { in sppptun_lrput()
1885 (q->q_first == NULL && canput(tcl->tcl_rq))) { in sppptun_lrput()
1886 put(tcl->tcl_rq, mp); in sppptun_lrput()
1975 tuncl_t *tcl; member
2001 tuncl_t *tcl; in tclvm_pppoe_search() local
2003 if (poedat->tcl != NULL) in tclvm_pppoe_search()
2006 tcl = tcl_slots[minorn - 1]; in tclvm_pppoe_search()
2007 ASSERT(tcl != NULL); in tclvm_pppoe_search()
2008 if (tcl->tcl_rsessid == poedat->sessid && in tclvm_pppoe_search()
2009 ((!poedat->isdata && tcl->tcl_ctrl_tll == poedat->tll) || in tclvm_pppoe_search()
2010 (poedat->isdata && tcl->tcl_data_tll == poedat->tll)) && in tclvm_pppoe_search()
2011 bcmp(tcl->tcl_address.pta_pppoe.ptma_mac, in tclvm_pppoe_search()
2013 sizeof (tcl->tcl_address.pta_pppoe.ptma_mac)) == 0) { in tclvm_pppoe_search()
2014 poedat->tcl = tcl; in tclvm_pppoe_search()
2074 tuncl_t *tcl; in sppptun_recv() local
2090 tcl = NULL; in sppptun_recv()
2112 tcl = tll->tll_defcl; in sppptun_recv()
2135 tcl = tcl_by_minor((minor_t)sessid); in sppptun_recv()
2147 tcl = tcl_by_minor((minor_t)sessid); in sppptun_recv()
2148 if (tcl == NULL || in sppptun_recv()
2149 (!isdata && tcl->tcl_ctrl_tll != tll) || in sppptun_recv()
2150 (isdata && tcl->tcl_data_tll != tll) || in sppptun_recv()
2151 sessid != tcl->tcl_rsessid || in sppptun_recv()
2152 bcmp(srcaddr, tcl->tcl_address.pta_pppoe.ptma_mac, in sppptun_recv()
2153 sizeof (tcl->tcl_address.pta_pppoe.ptma_mac)) != 0) in sppptun_recv()
2154 tcl = tll->tll_lastcl; in sppptun_recv()
2155 if (tcl == NULL || in sppptun_recv()
2156 (!isdata && tcl->tcl_ctrl_tll != tll) || in sppptun_recv()
2157 (isdata && tcl->tcl_data_tll != tll) || in sppptun_recv()
2158 sessid != tcl->tcl_rsessid || in sppptun_recv()
2159 bcmp(srcaddr, tcl->tcl_address.pta_pppoe.ptma_mac, in sppptun_recv()
2160 sizeof (tcl->tcl_address.pta_pppoe.ptma_mac)) != 0) in sppptun_recv()
2161 tcl = NULL; in sppptun_recv()
2162 if (tcl == NULL && sessid != 0) { in sppptun_recv()
2172 poedat.tcl = NULL; in sppptun_recv()
2177 if ((tcl = poedat.tcl) != NULL) { in sppptun_recv()
2178 tll->tll_lastcl = tcl; in sppptun_recv()
2186 if (tcl == NULL || tcl->tcl_rq == NULL) { in sppptun_recv()
2188 tuncl_t *, tcl, mblk_t *, mp); in sppptun_recv()
2189 if (tcl == NULL) { in sppptun_recv()
2194 if (tcl != NULL) in sppptun_recv()
2195 tcl->tcl_stats.ppp_ierrors++; in sppptun_recv()
2198 if (tcl != NULL) { in sppptun_recv()
2206 if (tcl->tcl_data_tll == tll && isdata) { in sppptun_recv()
2211 tcl->tcl_stats.ppp_ierrors++; in sppptun_recv()
2219 tcl->tcl_stats.ppp_ierrors++; in sppptun_recv()
2226 tcl->tcl_stats.ppp_ibytes += msgsize(mp); in sppptun_recv()
2227 tcl->tcl_stats.ppp_ipackets++; in sppptun_recv()
2230 if (isdata || tcl->tcl_ctrl_tll != tll || in sppptun_recv()
2231 (mnew = make_control(tcl, tll, PTCA_CONTROL, tcl)) == in sppptun_recv()
2248 return (tcl->tcl_rq); in sppptun_recv()