tcp_nanqinlang.c 320 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <link rel="dns-prefetch" href="https://assets-cdn.github.com">
  6. <link rel="dns-prefetch" href="https://avatars0.githubusercontent.com">
  7. <link rel="dns-prefetch" href="https://avatars1.githubusercontent.com">
  8. <link rel="dns-prefetch" href="https://avatars2.githubusercontent.com">
  9. <link rel="dns-prefetch" href="https://avatars3.githubusercontent.com">
  10. <link rel="dns-prefetch" href="https://github-cloud.s3.amazonaws.com">
  11. <link rel="dns-prefetch" href="https://user-images.githubusercontent.com/">
  12. <link crossorigin="anonymous" media="all" integrity="sha512-ffMzRgUi/mtdt6xiC1jtSP1kZPeTBajWgak1AnijhQVTr6eCui3vcdxCvFCJjbjAXg730wT/i/rceI+PIwS6kQ==" rel="stylesheet" href="https://assets-cdn.github.com/assets/frameworks-c4bbb32afb602dcf8c75be0bc4c83014.css" />
  13. <link crossorigin="anonymous" media="all" integrity="sha512-WZklPJpB37+ljTfVNn0494msEFLupIvcsVPpv1UCNJvCJAf0oFgpGlw4+OV4hQ3WMFTKbmuSVLk6uMmWuhnuqQ==" rel="stylesheet" href="https://assets-cdn.github.com/assets/github-0c21e211e4fd150ac107ccf0fcf751e5.css" />
  14. <meta name="viewport" content="width=device-width">
  15. <title>tcp_nanqinlang/tcp_nanqinlang.c at master · nanqinlang-tcp/tcp_nanqinlang</title>
  16. <meta name="description" content="GitHub is where people build software. More than 27 million people use GitHub to discover, fork, and contribute to over 80 million projects.">
  17. <link rel="search" type="application/opensearchdescription+xml" href="/opensearch.xml" title="GitHub">
  18. <link rel="fluid-icon" href="https://github.com/fluidicon.png" title="GitHub">
  19. <meta property="fb:app_id" content="1401488693436528">
  20. <meta property="og:image" content="https://avatars2.githubusercontent.com/u/31369986?s=400&amp;v=4" /><meta property="og:site_name" content="GitHub" /><meta property="og:type" content="object" /><meta property="og:title" content="nanqinlang-tcp/tcp_nanqinlang" /><meta property="og:url" content="https://github.com/nanqinlang-tcp/tcp_nanqinlang" /><meta property="og:description" content="tcp_nanqinlang - BBR Enhancement" />
  21. <link rel="assets" href="https://assets-cdn.github.com/">
  22. <link rel="web-socket" href="wss://live.github.com/_sockets/VjI6MjY4MDIwOTY1OmM0MTUxODMwYTRiMjhhZmVmOWZhOWUwZDdiYTNkZDFmOTU5N2E2YzJiY2YxZGFmMGY2OWQ0YWU0ZGM2M2RkMmQ=--f3c6e5338048c96ba9cceff2341b45daa6ca47b2">
  23. <meta name="pjax-timeout" content="1000">
  24. <link rel="sudo-modal" href="/sessions/sudo_modal">
  25. <meta name="request-id" content="99BD:087C:12F39CB:21C3E52:5AE00BD6" data-pjax-transient>
  26. <meta name="selected-link" value="repo_source" data-pjax-transient>
  27. <meta name="google-site-verification" content="KT5gs8h0wvaagLKAVWq8bbeNwnZZK1r1XQysX3xurLU">
  28. <meta name="google-site-verification" content="ZzhVyEFwb7w3e0-uOTltm8Jsck2F5StVihD0exw2fsA">
  29. <meta name="google-site-verification" content="GXs5KoUUkNCoaAZn7wPN-t01Pywp9M3sEjnt_3_ZWPc">
  30. <meta name="google-analytics" content="UA-3769691-2">
  31. <meta name="octolytics-host" content="collector.githubapp.com" /><meta name="octolytics-app-id" content="github" /><meta name="octolytics-event-url" content="https://collector.githubapp.com/github-external/browser_event" /><meta name="octolytics-dimension-request_id" content="99BD:087C:12F39CB:21C3E52:5AE00BD6" /><meta name="octolytics-dimension-region_edge" content="iad" /><meta name="octolytics-dimension-region_render" content="iad" /><meta name="octolytics-actor-id" content="33163118" /><meta name="octolytics-actor-login" content="chiakge" /><meta name="octolytics-actor-hash" content="954ba8f2f7ca63128be4b792cac53cc4a75a234a5edbcf4fbf418cbdbdac0650" />
  32. <meta name="analytics-location" content="/&lt;user-name&gt;/&lt;repo-name&gt;/blob/show" data-pjax-transient="true" />
  33. <meta class="js-ga-set" name="dimension1" content="Logged In">
  34. <meta name="hostname" content="github.com">
  35. <meta name="user-login" content="chiakge">
  36. <meta name="expected-hostname" content="github.com">
  37. <meta name="js-proxy-site-detection-payload" content="OGE4MjhjOGU5OTM2ODdhYWUzNWU0MDBjZjcyMDc2ZGNmY2VmNzU3NWJhM2NkMmQ3NDBmYmNlYWQ1MWVkODQ4ZXx7InJlbW90ZV9hZGRyZXNzIjoiNDcuNTIuMjA2LjIyMSIsInJlcXVlc3RfaWQiOiI5OUJEOjA4N0M6MTJGMzlDQjoyMUMzRTUyOjVBRTAwQkQ2IiwidGltZXN0YW1wIjoxNTI0NjMyNTU3LCJob3N0IjoiZ2l0aHViLmNvbSJ9">
  38. <meta name="enabled-features" content="LOG_ACCESSIBILITY,UNIVERSE_BANNER,FREE_TRIALS,MARKETPLACE_INSIGHTS,MARKETPLACE_SELF_SERVE,MARKETPLACE_INSIGHTS_CONVERSION_PERCENTAGES">
  39. <meta name="html-safe-nonce" content="c62f2189196c9d1345f00456c3e7ac48fd80d1cb">
  40. <meta http-equiv="x-pjax-version" content="4c7593edb85f662c04d2c0c9b648e225">
  41. <link href="https://github.com/nanqinlang-tcp/tcp_nanqinlang/commits/master.atom" rel="alternate" title="Recent Commits to tcp_nanqinlang:master" type="application/atom+xml">
  42. <meta name="description" content="tcp_nanqinlang - BBR Enhancement">
  43. <meta name="go-import" content="github.com/nanqinlang-tcp/tcp_nanqinlang git https://github.com/nanqinlang-tcp/tcp_nanqinlang.git">
  44. <meta name="octolytics-dimension-user_id" content="31369986" /><meta name="octolytics-dimension-user_login" content="nanqinlang-tcp" /><meta name="octolytics-dimension-repository_id" content="97065258" /><meta name="octolytics-dimension-repository_nwo" content="nanqinlang-tcp/tcp_nanqinlang" /><meta name="octolytics-dimension-repository_public" content="true" /><meta name="octolytics-dimension-repository_is_fork" content="false" /><meta name="octolytics-dimension-repository_network_root_id" content="97065258" /><meta name="octolytics-dimension-repository_network_root_nwo" content="nanqinlang-tcp/tcp_nanqinlang" /><meta name="octolytics-dimension-repository_explore_github_marketplace_ci_cta_shown" content="false" />
  45. <link rel="canonical" href="https://github.com/nanqinlang-tcp/tcp_nanqinlang/blob/master/General/CentOS/source/tcp_nanqinlang.c" data-pjax-transient>
  46. <meta name="browser-stats-url" content="https://api.github.com/_private/browser/stats">
  47. <meta name="browser-errors-url" content="https://api.github.com/_private/browser/errors">
  48. <link rel="mask-icon" href="https://assets-cdn.github.com/pinned-octocat.svg" color="#000000">
  49. <link rel="icon" type="image/x-icon" class="js-site-favicon" href="https://assets-cdn.github.com/favicon.ico">
  50. <meta name="theme-color" content="#1e2327">
  51. <meta name="u2f-support" content="true">
  52. <link rel="manifest" href="/manifest.json" crossOrigin="use-credentials">
  53. </head>
  54. <body class="logged-in env-production page-blob">
  55. <div class="position-relative js-header-wrapper ">
  56. <a href="#start-of-content" tabindex="1" class="p-3 bg-blue text-white show-on-focus js-skip-to-content">Skip to content</a>
  57. <div id="js-pjax-loader-bar" class="pjax-loader-bar"><div class="progress"></div></div>
  58. <header class="Header f5" role="banner">
  59. <div class="d-flex flex-justify-between px-3 container-lg">
  60. <div class="d-flex flex-justify-between ">
  61. <div class="">
  62. <a class="header-logo-invertocat" href="https://github.com/" data-hotkey="g d" aria-label="Homepage" data-ga-click="Header, go to dashboard, icon:logo">
  63. <svg height="32" class="octicon octicon-mark-github" viewBox="0 0 16 16" version="1.1" width="32" aria-hidden="true"><path fill-rule="evenodd" d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z"/></svg>
  64. </a>
  65. </div>
  66. </div>
  67. <div class="HeaderMenu d-flex flex-justify-between flex-auto">
  68. <div class="d-flex">
  69. <div class="">
  70. <div class="header-search scoped-search site-scoped-search js-site-search" role="search">
  71. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-site-search-form" data-scoped-search-url="/nanqinlang-tcp/tcp_nanqinlang/search" data-unscoped-search-url="/search" action="/nanqinlang-tcp/tcp_nanqinlang/search" accept-charset="UTF-8" method="get"><input name="utf8" type="hidden" value="&#x2713;" />
  72. <label class="form-control header-search-wrapper js-chromeless-input-container">
  73. <a class="header-search-scope no-underline" href="/nanqinlang-tcp/tcp_nanqinlang/blob/master/General/CentOS/source/tcp_nanqinlang.c">This repository</a>
  74. <input type="text"
  75. class="form-control header-search-input js-site-search-focus js-site-search-field is-clearable"
  76. data-hotkey="s,/"
  77. name="q"
  78. value=""
  79. placeholder="Search"
  80. aria-label="Search this repository"
  81. data-unscoped-placeholder="Search GitHub"
  82. data-scoped-placeholder="Search"
  83. autocapitalize="off"
  84. >
  85. <input type="hidden" class="js-site-search-type-field" name="type" >
  86. </label>
  87. </form></div>
  88. </div>
  89. <ul class="d-flex pl-2 flex-items-center text-bold list-style-none" role="navigation">
  90. <li>
  91. <a class="js-selected-navigation-item HeaderNavlink px-2" data-hotkey="g p" data-ga-click="Header, click, Nav menu - item:pulls context:user" aria-label="Pull requests you created" data-selected-links="/pulls /pulls/assigned /pulls/mentioned /pulls" href="/pulls">
  92. Pull requests
  93. </a> </li>
  94. <li>
  95. <a class="js-selected-navigation-item HeaderNavlink px-2" data-hotkey="g i" data-ga-click="Header, click, Nav menu - item:issues context:user" aria-label="Issues you created" data-selected-links="/issues /issues/assigned /issues/mentioned /issues" href="/issues">
  96. Issues
  97. </a> </li>
  98. <li>
  99. <a class="js-selected-navigation-item HeaderNavlink px-2" data-ga-click="Header, click, Nav menu - item:marketplace context:user" data-octo-click="marketplace_click" data-octo-dimensions="location:nav_bar, group:" data-selected-links=" /marketplace" href="/marketplace">
  100. Marketplace
  101. </a> </li>
  102. <li>
  103. <a class="js-selected-navigation-item HeaderNavlink px-2" data-ga-click="Header, click, Nav menu - item:explore" data-selected-links="/explore /trending /trending/developers /integrations /integrations/feature/code /integrations/feature/collaborate /integrations/feature/ship showcases showcases_search showcases_landing /explore" href="/explore">
  104. Explore
  105. </a> </li>
  106. </ul>
  107. </div>
  108. <div class="d-flex">
  109. <ul class="user-nav d-flex flex-items-center list-style-none" id="user-links">
  110. <li class="dropdown js-menu-container">
  111. <span class="d-inline-block px-2">
  112. <a aria-label="You have no unread notifications" class="notification-indicator tooltipped tooltipped-s js-socket-channel js-notification-indicator" data-hotkey="g n" data-ga-click="Header, go to notifications, icon:read" data-channel="notification-changed:33163118" href="/notifications">
  113. <span class="mail-status "></span>
  114. <svg class="octicon octicon-bell" viewBox="0 0 14 16" version="1.1" width="14" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M14 12v1H0v-1l.73-.58c.77-.77.81-2.55 1.19-4.42C2.69 3.23 6 2 6 2c0-.55.45-1 1-1s1 .45 1 1c0 0 3.39 1.23 4.16 5 .38 1.88.42 3.66 1.19 4.42l.66.58H14zm-7 4c1.11 0 2-.89 2-2H5c0 1.11.89 2 2 2z"/></svg>
  115. </a>
  116. </span>
  117. </li>
  118. <li class="dropdown js-menu-container">
  119. <details class="dropdown-details details-reset js-dropdown-details d-flex px-2 flex-items-center">
  120. <summary class="HeaderNavlink"
  121. aria-label="Create new…"
  122. data-ga-click="Header, create new, icon:add">
  123. <svg class="octicon octicon-plus float-left mr-1 mt-1" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 9H7v5H5V9H0V7h5V2h2v5h5z"/></svg>
  124. <span class="dropdown-caret mt-1"></span>
  125. </summary>
  126. <ul class="dropdown-menu dropdown-menu-sw">
  127. <a class="dropdown-item" href="/new" data-ga-click="Header, create new repository">
  128. New repository
  129. </a>
  130. <a class="dropdown-item" href="/new/import" data-ga-click="Header, import a repository">
  131. Import repository
  132. </a>
  133. <a class="dropdown-item" href="https://gist.github.com/" data-ga-click="Header, create new gist">
  134. New gist
  135. </a>
  136. <a class="dropdown-item" href="/organizations/new" data-ga-click="Header, create new organization">
  137. New organization
  138. </a>
  139. <div class="dropdown-divider"></div>
  140. <div class="dropdown-header">
  141. <span title="nanqinlang-tcp/tcp_nanqinlang">This repository</span>
  142. </div>
  143. <a class="dropdown-item" href="/nanqinlang-tcp/tcp_nanqinlang/issues/new" data-ga-click="Header, create new issue">
  144. New issue
  145. </a>
  146. </ul>
  147. </details>
  148. </li>
  149. <li class="dropdown js-menu-container">
  150. <details class="dropdown-details details-reset js-dropdown-details d-flex pl-2 flex-items-center">
  151. <summary class="HeaderNavlink name mt-1"
  152. aria-label="View profile and more"
  153. data-ga-click="Header, show menu, icon:avatar">
  154. <img alt="@chiakge" class="avatar float-left mr-1" src="https://avatars0.githubusercontent.com/u/33163118?s=40&amp;v=4" height="20" width="20">
  155. <span class="dropdown-caret"></span>
  156. </summary>
  157. <ul class="dropdown-menu dropdown-menu-sw">
  158. <li class="dropdown-header header-nav-current-user css-truncate">
  159. Signed in as <strong class="css-truncate-target">chiakge</strong>
  160. </li>
  161. <li class="dropdown-divider"></li>
  162. <li><a class="dropdown-item" href="/chiakge" data-ga-click="Header, go to profile, text:your profile">
  163. Your profile
  164. </a></li>
  165. <li><a class="dropdown-item" href="/chiakge?tab=stars" data-ga-click="Header, go to starred repos, text:your stars">
  166. Your stars
  167. </a></li>
  168. <li><a class="dropdown-item" href="https://gist.github.com/" data-ga-click="Header, your gists, text:your gists">Your gists</a></li>
  169. <li class="dropdown-divider"></li>
  170. <li><a class="dropdown-item" href="https://help.github.com" data-ga-click="Header, go to help, text:help">
  171. Help
  172. </a></li>
  173. <li><a class="dropdown-item" href="/settings/profile" data-ga-click="Header, go to settings, icon:settings">
  174. Settings
  175. </a></li>
  176. <li><!-- '"` --><!-- </textarea></xmp> --></option></form><form class="logout-form" action="/logout" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="lGbncIugkBmM6Jj7q8p79M+NXA8xjVE9EBw9arTilfiZJyIqHSi+3q45KjgprgreVi5ij73V7aci/OHU902ARA==" />
  177. <button type="submit" class="dropdown-item dropdown-signout" data-ga-click="Header, sign out, icon:logout">
  178. Sign out
  179. </button>
  180. </form></li>
  181. </ul>
  182. </details>
  183. </li>
  184. </ul>
  185. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="sr-only right-0" action="/logout" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="+VdJX+nOyxUYouoCa1wyT8wjEJdOld+G3oW0SGYA3Pf0FowFf0bl0jpzWMHpOENlVYAuF8LNYxzsZWj2Ja/JSw==" />
  186. <button type="submit" class="dropdown-item dropdown-signout" data-ga-click="Header, sign out, icon:logout">
  187. Sign out
  188. </button>
  189. </form> </div>
  190. </div>
  191. </div>
  192. </header>
  193. </div>
  194. <div id="start-of-content" class="show-on-focus"></div>
  195. <div id="js-flash-container">
  196. </div>
  197. <div role="main" class="application-main ">
  198. <div itemscope itemtype="http://schema.org/SoftwareSourceCode" class="">
  199. <div id="js-repo-pjax-container" data-pjax-container >
  200. <div class="pagehead repohead instapaper_ignore readability-menu experiment-repo-nav ">
  201. <div class="repohead-details-container clearfix container">
  202. <ul class="pagehead-actions">
  203. <li>
  204. <!-- '"` --><!-- </textarea></xmp> --></option></form><form data-autosubmit="true" data-remote="true" class="js-social-container" action="/notifications/subscribe" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="cikq/QQwZqJtUgX7wIf/SRzPm2c4nwVpdPTb8+yNjAhKyGEAufKFPZ2UdtOTeSVYxhycL6cR0hbm9bCuG3pe+Q==" /> <input type="hidden" name="repository_id" id="repository_id" value="97065258" class="form-control" />
  205. <div class="select-menu js-menu-container js-select-menu">
  206. <a href="/nanqinlang-tcp/tcp_nanqinlang/subscription"
  207. class="btn btn-sm btn-with-count select-menu-button js-menu-target"
  208. role="button"
  209. aria-haspopup="true"
  210. aria-expanded="false"
  211. aria-label="Toggle repository notifications menu"
  212. data-ga-click="Repository, click Watch settings, action:blob#show">
  213. <span class="js-select-button">
  214. <svg class="octicon octicon-eye" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M8.06 2C3 2 0 8 0 8s3 6 8.06 6C13 14 16 8 16 8s-3-6-7.94-6zM8 12c-2.2 0-4-1.78-4-4 0-2.2 1.8-4 4-4 2.22 0 4 1.8 4 4 0 2.22-1.78 4-4 4zm2-4c0 1.11-.89 2-2 2-1.11 0-2-.89-2-2 0-1.11.89-2 2-2 1.11 0 2 .89 2 2z"/></svg>
  215. Watch
  216. </span>
  217. </a>
  218. <a class="social-count js-social-count"
  219. href="/nanqinlang-tcp/tcp_nanqinlang/watchers"
  220. aria-label="18 users are watching this repository">
  221. 18
  222. </a>
  223. <div class="select-menu-modal-holder">
  224. <div class="select-menu-modal subscription-menu-modal js-menu-content">
  225. <div class="select-menu-header js-navigation-enable" tabindex="-1">
  226. <svg class="octicon octicon-x js-menu-close" role="img" aria-label="Close" viewBox="0 0 12 16" version="1.1" width="12" height="16"><path fill-rule="evenodd" d="M7.48 8l3.75 3.75-1.48 1.48L6 9.48l-3.75 3.75-1.48-1.48L4.52 8 .77 4.25l1.48-1.48L6 6.52l3.75-3.75 1.48 1.48z"/></svg>
  227. <span class="select-menu-title">Notifications</span>
  228. </div>
  229. <div class="select-menu-list js-navigation-container" role="menu">
  230. <div class="select-menu-item js-navigation-item selected" role="menuitem" tabindex="0">
  231. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  232. <div class="select-menu-item-text">
  233. <input type="radio" name="do" id="do_included" value="included" checked="checked" />
  234. <span class="select-menu-item-heading">Not watching</span>
  235. <span class="description">Be notified when participating or @mentioned.</span>
  236. <span class="js-select-button-text hidden-select-button-text">
  237. <svg class="octicon octicon-eye" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M8.06 2C3 2 0 8 0 8s3 6 8.06 6C13 14 16 8 16 8s-3-6-7.94-6zM8 12c-2.2 0-4-1.78-4-4 0-2.2 1.8-4 4-4 2.22 0 4 1.8 4 4 0 2.22-1.78 4-4 4zm2-4c0 1.11-.89 2-2 2-1.11 0-2-.89-2-2 0-1.11.89-2 2-2 1.11 0 2 .89 2 2z"/></svg>
  238. Watch
  239. </span>
  240. </div>
  241. </div>
  242. <div class="select-menu-item js-navigation-item " role="menuitem" tabindex="0">
  243. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  244. <div class="select-menu-item-text">
  245. <input type="radio" name="do" id="do_subscribed" value="subscribed" />
  246. <span class="select-menu-item-heading">Watching</span>
  247. <span class="description">Be notified of all conversations.</span>
  248. <span class="js-select-button-text hidden-select-button-text">
  249. <svg class="octicon octicon-eye" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M8.06 2C3 2 0 8 0 8s3 6 8.06 6C13 14 16 8 16 8s-3-6-7.94-6zM8 12c-2.2 0-4-1.78-4-4 0-2.2 1.8-4 4-4 2.22 0 4 1.8 4 4 0 2.22-1.78 4-4 4zm2-4c0 1.11-.89 2-2 2-1.11 0-2-.89-2-2 0-1.11.89-2 2-2 1.11 0 2 .89 2 2z"/></svg>
  250. Unwatch
  251. </span>
  252. </div>
  253. </div>
  254. <div class="select-menu-item js-navigation-item " role="menuitem" tabindex="0">
  255. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  256. <div class="select-menu-item-text">
  257. <input type="radio" name="do" id="do_ignore" value="ignore" />
  258. <span class="select-menu-item-heading">Ignoring</span>
  259. <span class="description">Never be notified.</span>
  260. <span class="js-select-button-text hidden-select-button-text">
  261. <svg class="octicon octicon-mute" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M8 2.81v10.38c0 .67-.81 1-1.28.53L3 10H1c-.55 0-1-.45-1-1V7c0-.55.45-1 1-1h2l3.72-3.72C7.19 1.81 8 2.14 8 2.81zm7.53 3.22l-1.06-1.06-1.97 1.97-1.97-1.97-1.06 1.06L11.44 8 9.47 9.97l1.06 1.06 1.97-1.97 1.97 1.97 1.06-1.06L13.56 8l1.97-1.97z"/></svg>
  262. Stop ignoring
  263. </span>
  264. </div>
  265. </div>
  266. </div>
  267. </div>
  268. </div>
  269. </div>
  270. </form>
  271. </li>
  272. <li>
  273. <div class="js-toggler-container js-social-container starring-container ">
  274. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="starred js-social-form" action="/nanqinlang-tcp/tcp_nanqinlang/unstar" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="3FYJ6Va3P/Bwb0cs464WHK5a+nj0+esSzXtZrnSdzlU5k5P92mcTxVb6oWHsXGELTP3OZ2fk7PwB6OEGXdEcXg==" />
  275. <input type="hidden" name="context" value="repository"></input>
  276. <button
  277. type="submit"
  278. class="btn btn-sm btn-with-count js-toggler-target"
  279. aria-label="Unstar this repository" title="Unstar nanqinlang-tcp/tcp_nanqinlang"
  280. data-ga-click="Repository, click unstar button, action:blob#show; text:Unstar">
  281. <svg class="octicon octicon-star" viewBox="0 0 14 16" version="1.1" width="14" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M14 6l-4.9-.64L7 1 4.9 5.36 0 6l3.6 3.26L2.67 14 7 11.67 11.33 14l-.93-4.74z"/></svg>
  282. Unstar
  283. </button>
  284. <a class="social-count js-social-count" href="/nanqinlang-tcp/tcp_nanqinlang/stargazers"
  285. aria-label="237 users starred this repository">
  286. 237
  287. </a>
  288. </form>
  289. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="unstarred js-social-form" action="/nanqinlang-tcp/tcp_nanqinlang/star" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="jANz4qkeSQ6bZKhA1UoGzlkgBAbjFpE58oKBUWlheHDpCqwLkAvJs1/NyuAEP1l0PAJjQv9AtZBzMKmPJd2nOQ==" />
  290. <input type="hidden" name="context" value="repository"></input>
  291. <button
  292. type="submit"
  293. class="btn btn-sm btn-with-count js-toggler-target"
  294. aria-label="Star this repository" title="Star nanqinlang-tcp/tcp_nanqinlang"
  295. data-ga-click="Repository, click star button, action:blob#show; text:Star">
  296. <svg class="octicon octicon-star" viewBox="0 0 14 16" version="1.1" width="14" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M14 6l-4.9-.64L7 1 4.9 5.36 0 6l3.6 3.26L2.67 14 7 11.67 11.33 14l-.93-4.74z"/></svg>
  297. Star
  298. </button>
  299. <a class="social-count js-social-count" href="/nanqinlang-tcp/tcp_nanqinlang/stargazers"
  300. aria-label="237 users starred this repository">
  301. 237
  302. </a>
  303. </form> </div>
  304. </li>
  305. <li>
  306. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="btn-with-count" action="/nanqinlang-tcp/tcp_nanqinlang/fork" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="Y8TGk9MeRwBqiGSXCQHo0VbZZG1ioLVbxRODyv8GP0D8rQUsqLY9vXhSkWsATPlPu9/pyGWEfBCbBwW3Pt2vFg==" />
  307. <button
  308. type="submit"
  309. class="btn btn-sm btn-with-count"
  310. data-ga-click="Repository, show fork modal, action:blob#show; text:Fork"
  311. title="Fork your own copy of nanqinlang-tcp/tcp_nanqinlang to your account"
  312. aria-label="Fork your own copy of nanqinlang-tcp/tcp_nanqinlang to your account">
  313. <svg class="octicon octicon-repo-forked" viewBox="0 0 10 16" version="1.1" width="10" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M8 1a1.993 1.993 0 0 0-1 3.72V6L5 8 3 6V4.72A1.993 1.993 0 0 0 2 1a1.993 1.993 0 0 0-1 3.72V6.5l3 3v1.78A1.993 1.993 0 0 0 5 15a1.993 1.993 0 0 0 1-3.72V9.5l3-3V4.72A1.993 1.993 0 0 0 8 1zM2 4.2C1.34 4.2.8 3.65.8 3c0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2zm3 10c-.66 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2zm3-10c-.66 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2z"/></svg>
  314. Fork
  315. </button>
  316. </form>
  317. <a href="/nanqinlang-tcp/tcp_nanqinlang/network" class="social-count"
  318. aria-label="172 users forked this repository">
  319. 172
  320. </a>
  321. </li>
  322. </ul>
  323. <h1 class="public ">
  324. <svg class="octicon octicon-repo" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M4 9H3V8h1v1zm0-3H3v1h1V6zm0-2H3v1h1V4zm0-2H3v1h1V2zm8-1v12c0 .55-.45 1-1 1H6v2l-1.5-1.5L3 16v-2H1c-.55 0-1-.45-1-1V1c0-.55.45-1 1-1h10c.55 0 1 .45 1 1zm-1 10H1v2h2v-1h3v1h5v-2zm0-10H2v9h9V1z"/></svg>
  325. <span class="author" itemprop="author"><a class="url fn" rel="author" href="/nanqinlang-tcp">nanqinlang-tcp</a></span><!--
  326. --><span class="path-divider">/</span><!--
  327. --><strong itemprop="name"><a data-pjax="#js-repo-pjax-container" href="/nanqinlang-tcp/tcp_nanqinlang">tcp_nanqinlang</a></strong>
  328. </h1>
  329. </div>
  330. <nav class="reponav js-repo-nav js-sidenav-container-pjax container"
  331. itemscope
  332. itemtype="http://schema.org/BreadcrumbList"
  333. role="navigation"
  334. data-pjax="#js-repo-pjax-container">
  335. <span itemscope itemtype="http://schema.org/ListItem" itemprop="itemListElement">
  336. <a class="js-selected-navigation-item selected reponav-item" itemprop="url" data-hotkey="g c" data-selected-links="repo_source repo_downloads repo_commits repo_releases repo_tags repo_branches repo_packages /nanqinlang-tcp/tcp_nanqinlang" href="/nanqinlang-tcp/tcp_nanqinlang">
  337. <svg class="octicon octicon-code" viewBox="0 0 14 16" version="1.1" width="14" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M9.5 3L8 4.5 11.5 8 8 11.5 9.5 13 14 8 9.5 3zm-5 0L0 8l4.5 5L6 11.5 2.5 8 6 4.5 4.5 3z"/></svg>
  338. <span itemprop="name">Code</span>
  339. <meta itemprop="position" content="1">
  340. </a> </span>
  341. <span itemscope itemtype="http://schema.org/ListItem" itemprop="itemListElement">
  342. <a itemprop="url" data-hotkey="g i" class="js-selected-navigation-item reponav-item" data-selected-links="repo_issues repo_labels repo_milestones /nanqinlang-tcp/tcp_nanqinlang/issues" href="/nanqinlang-tcp/tcp_nanqinlang/issues">
  343. <svg class="octicon octicon-issue-opened" viewBox="0 0 14 16" version="1.1" width="14" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M7 2.3c3.14 0 5.7 2.56 5.7 5.7s-2.56 5.7-5.7 5.7A5.71 5.71 0 0 1 1.3 8c0-3.14 2.56-5.7 5.7-5.7zM7 1C3.14 1 0 4.14 0 8s3.14 7 7 7 7-3.14 7-7-3.14-7-7-7zm1 3H6v5h2V4zm0 6H6v2h2v-2z"/></svg>
  344. <span itemprop="name">Issues</span>
  345. <span class="Counter">3</span>
  346. <meta itemprop="position" content="2">
  347. </a> </span>
  348. <span itemscope itemtype="http://schema.org/ListItem" itemprop="itemListElement">
  349. <a data-hotkey="g p" itemprop="url" class="js-selected-navigation-item reponav-item" data-selected-links="repo_pulls checks /nanqinlang-tcp/tcp_nanqinlang/pulls" href="/nanqinlang-tcp/tcp_nanqinlang/pulls">
  350. <svg class="octicon octicon-git-pull-request" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M11 11.28V5c-.03-.78-.34-1.47-.94-2.06C9.46 2.35 8.78 2.03 8 2H7V0L4 3l3 3V4h1c.27.02.48.11.69.31.21.2.3.42.31.69v6.28A1.993 1.993 0 0 0 10 15a1.993 1.993 0 0 0 1-3.72zm-1 2.92c-.66 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2zM4 3c0-1.11-.89-2-2-2a1.993 1.993 0 0 0-1 3.72v6.56A1.993 1.993 0 0 0 2 15a1.993 1.993 0 0 0 1-3.72V4.72c.59-.34 1-.98 1-1.72zm-.8 10c0 .66-.55 1.2-1.2 1.2-.65 0-1.2-.55-1.2-1.2 0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2zM2 4.2C1.34 4.2.8 3.65.8 3c0-.65.55-1.2 1.2-1.2.65 0 1.2.55 1.2 1.2 0 .65-.55 1.2-1.2 1.2z"/></svg>
  351. <span itemprop="name">Pull requests</span>
  352. <span class="Counter">0</span>
  353. <meta itemprop="position" content="3">
  354. </a> </span>
  355. <a class="js-selected-navigation-item reponav-item" data-selected-links="repo_graphs repo_contributors dependency_graph pulse /nanqinlang-tcp/tcp_nanqinlang/pulse" href="/nanqinlang-tcp/tcp_nanqinlang/pulse">
  356. <svg class="octicon octicon-graph" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M16 14v1H0V0h1v14h15zM5 13H3V8h2v5zm4 0H7V3h2v10zm4 0h-2V6h2v7z"/></svg>
  357. Insights
  358. </a>
  359. </nav>
  360. </div>
  361. <div class="container new-discussion-timeline experiment-repo-nav ">
  362. <div class="repository-content ">
  363. <a class="d-none js-permalink-shortcut" data-hotkey="y" href="/nanqinlang-tcp/tcp_nanqinlang/blob/b0a491158a2262641e4664c70ceaf70e53da9003/General/CentOS/source/tcp_nanqinlang.c">Permalink</a>
  364. <!-- blob contrib key: blob_contributors:v21:ab64a64d34697b0dd75c673e71a65929 -->
  365. <div class="file-navigation">
  366. <div class="select-menu branch-select-menu js-menu-container js-select-menu float-left">
  367. <button class=" btn btn-sm select-menu-button js-menu-target css-truncate" data-hotkey="w"
  368. type="button" aria-label="Switch branches or tags" aria-expanded="false" aria-haspopup="true">
  369. <i>Branch:</i>
  370. <span class="js-select-button css-truncate-target">master</span>
  371. </button>
  372. <div class="select-menu-modal-holder js-menu-content js-navigation-container" data-pjax>
  373. <div class="select-menu-modal">
  374. <div class="select-menu-header">
  375. <svg class="octicon octicon-x js-menu-close" role="img" aria-label="Close" viewBox="0 0 12 16" version="1.1" width="12" height="16"><path fill-rule="evenodd" d="M7.48 8l3.75 3.75-1.48 1.48L6 9.48l-3.75 3.75-1.48-1.48L4.52 8 .77 4.25l1.48-1.48L6 6.52l3.75-3.75 1.48 1.48z"/></svg>
  376. <span class="select-menu-title">Switch branches/tags</span>
  377. </div>
  378. <div class="select-menu-filters">
  379. <div class="select-menu-text-filter">
  380. <input type="text" aria-label="Filter branches/tags" id="context-commitish-filter-field" class="form-control js-filterable-field js-navigation-enable" placeholder="Filter branches/tags">
  381. </div>
  382. <div class="select-menu-tabs">
  383. <ul>
  384. <li class="select-menu-tab">
  385. <a href="#" data-tab-filter="branches" data-filter-placeholder="Filter branches/tags" class="js-select-menu-tab" role="tab">Branches</a>
  386. </li>
  387. <li class="select-menu-tab">
  388. <a href="#" data-tab-filter="tags" data-filter-placeholder="Find a tag…" class="js-select-menu-tab" role="tab">Tags</a>
  389. </li>
  390. </ul>
  391. </div>
  392. </div>
  393. <div class="select-menu-list select-menu-tab-bucket js-select-menu-tab-bucket" data-tab-filter="branches" role="menu">
  394. <div data-filterable-for="context-commitish-filter-field" data-filterable-type="substring">
  395. <a class="select-menu-item js-navigation-item js-navigation-open selected"
  396. href="/nanqinlang-tcp/tcp_nanqinlang/blob/master/General/CentOS/source/tcp_nanqinlang.c"
  397. data-name="master"
  398. data-skip-pjax="true"
  399. rel="nofollow">
  400. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  401. <span class="select-menu-item-text css-truncate-target js-select-menu-filter-text">
  402. master
  403. </span>
  404. </a>
  405. </div>
  406. <div class="select-menu-no-results">Nothing to show</div>
  407. </div>
  408. <div class="select-menu-list select-menu-tab-bucket js-select-menu-tab-bucket" data-tab-filter="tags">
  409. <div data-filterable-for="context-commitish-filter-field" data-filterable-type="substring">
  410. <a class="select-menu-item js-navigation-item js-navigation-open "
  411. href="/nanqinlang-tcp/tcp_nanqinlang/tree/v4.15-rc8/General/CentOS/source/tcp_nanqinlang.c"
  412. data-name="v4.15-rc8"
  413. data-skip-pjax="true"
  414. rel="nofollow">
  415. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  416. <span class="select-menu-item-text css-truncate-target" title="v4.15-rc8">
  417. v4.15-rc8
  418. </span>
  419. </a>
  420. <a class="select-menu-item js-navigation-item js-navigation-open "
  421. href="/nanqinlang-tcp/tcp_nanqinlang/tree/rinetd/General/CentOS/source/tcp_nanqinlang.c"
  422. data-name="rinetd"
  423. data-skip-pjax="true"
  424. rel="nofollow">
  425. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  426. <span class="select-menu-item-text css-truncate-target" title="rinetd">
  427. rinetd
  428. </span>
  429. </a>
  430. <a class="select-menu-item js-navigation-item js-navigation-open "
  431. href="/nanqinlang-tcp/tcp_nanqinlang/tree/rinetd-linhua/General/CentOS/source/tcp_nanqinlang.c"
  432. data-name="rinetd-linhua"
  433. data-skip-pjax="true"
  434. rel="nofollow">
  435. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  436. <span class="select-menu-item-text css-truncate-target" title="rinetd-linhua">
  437. rinetd-linhua
  438. </span>
  439. </a>
  440. <a class="select-menu-item js-navigation-item js-navigation-open selected"
  441. href="/nanqinlang-tcp/tcp_nanqinlang/tree/master/General/CentOS/source/tcp_nanqinlang.c"
  442. data-name="master"
  443. data-skip-pjax="true"
  444. rel="nofollow">
  445. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  446. <span class="select-menu-item-text css-truncate-target" title="master">
  447. master
  448. </span>
  449. </a>
  450. <a class="select-menu-item js-navigation-item js-navigation-open "
  451. href="/nanqinlang-tcp/tcp_nanqinlang/tree/daily-20180105/General/CentOS/source/tcp_nanqinlang.c"
  452. data-name="daily-20180105"
  453. data-skip-pjax="true"
  454. rel="nofollow">
  455. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  456. <span class="select-menu-item-text css-truncate-target" title="daily-20180105">
  457. daily-20180105
  458. </span>
  459. </a>
  460. <a class="select-menu-item js-navigation-item js-navigation-open "
  461. href="/nanqinlang-tcp/tcp_nanqinlang/tree/centos/General/CentOS/source/tcp_nanqinlang.c"
  462. data-name="centos"
  463. data-skip-pjax="true"
  464. rel="nofollow">
  465. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  466. <span class="select-menu-item-text css-truncate-target" title="centos">
  467. centos
  468. </span>
  469. </a>
  470. <a class="select-menu-item js-navigation-item js-navigation-open "
  471. href="/nanqinlang-tcp/tcp_nanqinlang/tree/20180105-aptupgrade/General/CentOS/source/tcp_nanqinlang.c"
  472. data-name="20180105-aptupgrade"
  473. data-skip-pjax="true"
  474. rel="nofollow">
  475. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  476. <span class="select-menu-item-text css-truncate-target" title="20180105-aptupgrade">
  477. 20180105-aptupgrade
  478. </span>
  479. </a>
  480. <a class="select-menu-item js-navigation-item js-navigation-open "
  481. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.5.0/General/CentOS/source/tcp_nanqinlang.c"
  482. data-name="3.4.5.0"
  483. data-skip-pjax="true"
  484. rel="nofollow">
  485. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  486. <span class="select-menu-item-text css-truncate-target" title="3.4.5.0">
  487. 3.4.5.0
  488. </span>
  489. </a>
  490. <a class="select-menu-item js-navigation-item js-navigation-open "
  491. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.4.0/General/CentOS/source/tcp_nanqinlang.c"
  492. data-name="3.4.4.0"
  493. data-skip-pjax="true"
  494. rel="nofollow">
  495. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  496. <span class="select-menu-item-text css-truncate-target" title="3.4.4.0">
  497. 3.4.4.0
  498. </span>
  499. </a>
  500. <a class="select-menu-item js-navigation-item js-navigation-open "
  501. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.3.1/General/CentOS/source/tcp_nanqinlang.c"
  502. data-name="3.4.3.1"
  503. data-skip-pjax="true"
  504. rel="nofollow">
  505. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  506. <span class="select-menu-item-text css-truncate-target" title="3.4.3.1">
  507. 3.4.3.1
  508. </span>
  509. </a>
  510. <a class="select-menu-item js-navigation-item js-navigation-open "
  511. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.3/General/CentOS/source/tcp_nanqinlang.c"
  512. data-name="3.4.3"
  513. data-skip-pjax="true"
  514. rel="nofollow">
  515. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  516. <span class="select-menu-item-text css-truncate-target" title="3.4.3">
  517. 3.4.3
  518. </span>
  519. </a>
  520. <a class="select-menu-item js-navigation-item js-navigation-open "
  521. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.2/General/CentOS/source/tcp_nanqinlang.c"
  522. data-name="3.4.2"
  523. data-skip-pjax="true"
  524. rel="nofollow">
  525. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  526. <span class="select-menu-item-text css-truncate-target" title="3.4.2">
  527. 3.4.2
  528. </span>
  529. </a>
  530. <a class="select-menu-item js-navigation-item js-navigation-open "
  531. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.2-nocheckvirt/General/CentOS/source/tcp_nanqinlang.c"
  532. data-name="3.4.2-nocheckvirt"
  533. data-skip-pjax="true"
  534. rel="nofollow">
  535. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  536. <span class="select-menu-item-text css-truncate-target" title="3.4.2-nocheckvirt">
  537. 3.4.2-nocheckvirt
  538. </span>
  539. </a>
  540. <a class="select-menu-item js-navigation-item js-navigation-open "
  541. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.1/General/CentOS/source/tcp_nanqinlang.c"
  542. data-name="3.4.1"
  543. data-skip-pjax="true"
  544. rel="nofollow">
  545. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  546. <span class="select-menu-item-text css-truncate-target" title="3.4.1">
  547. 3.4.1
  548. </span>
  549. </a>
  550. <a class="select-menu-item js-navigation-item js-navigation-open "
  551. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.4.0/General/CentOS/source/tcp_nanqinlang.c"
  552. data-name="3.4.0"
  553. data-skip-pjax="true"
  554. rel="nofollow">
  555. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  556. <span class="select-menu-item-text css-truncate-target" title="3.4.0">
  557. 3.4.0
  558. </span>
  559. </a>
  560. <a class="select-menu-item js-navigation-item js-navigation-open "
  561. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.3.0/General/CentOS/source/tcp_nanqinlang.c"
  562. data-name="3.3.0"
  563. data-skip-pjax="true"
  564. rel="nofollow">
  565. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  566. <span class="select-menu-item-text css-truncate-target" title="3.3.0">
  567. 3.3.0
  568. </span>
  569. </a>
  570. <a class="select-menu-item js-navigation-item js-navigation-open "
  571. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.3.0-only-test/General/CentOS/source/tcp_nanqinlang.c"
  572. data-name="3.3.0-only-test"
  573. data-skip-pjax="true"
  574. rel="nofollow">
  575. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  576. <span class="select-menu-item-text css-truncate-target" title="3.3.0-only-test">
  577. 3.3.0-only-test
  578. </span>
  579. </a>
  580. <a class="select-menu-item js-navigation-item js-navigation-open "
  581. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.2.1/General/CentOS/source/tcp_nanqinlang.c"
  582. data-name="3.2.1"
  583. data-skip-pjax="true"
  584. rel="nofollow">
  585. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  586. <span class="select-menu-item-text css-truncate-target" title="3.2.1">
  587. 3.2.1
  588. </span>
  589. </a>
  590. <a class="select-menu-item js-navigation-item js-navigation-open "
  591. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.2.0/General/CentOS/source/tcp_nanqinlang.c"
  592. data-name="3.2.0"
  593. data-skip-pjax="true"
  594. rel="nofollow">
  595. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  596. <span class="select-menu-item-text css-truncate-target" title="3.2.0">
  597. 3.2.0
  598. </span>
  599. </a>
  600. <a class="select-menu-item js-navigation-item js-navigation-open "
  601. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.1/General/CentOS/source/tcp_nanqinlang.c"
  602. data-name="3.1"
  603. data-skip-pjax="true"
  604. rel="nofollow">
  605. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  606. <span class="select-menu-item-text css-truncate-target" title="3.1">
  607. 3.1
  608. </span>
  609. </a>
  610. <a class="select-menu-item js-navigation-item js-navigation-open "
  611. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.0.1/General/CentOS/source/tcp_nanqinlang.c"
  612. data-name="3.0.1"
  613. data-skip-pjax="true"
  614. rel="nofollow">
  615. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  616. <span class="select-menu-item-text css-truncate-target" title="3.0.1">
  617. 3.0.1
  618. </span>
  619. </a>
  620. <a class="select-menu-item js-navigation-item js-navigation-open "
  621. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.0.1-no-use/General/CentOS/source/tcp_nanqinlang.c"
  622. data-name="3.0.1-no-use"
  623. data-skip-pjax="true"
  624. rel="nofollow">
  625. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  626. <span class="select-menu-item-text css-truncate-target" title="3.0.1-no-use">
  627. 3.0.1-no-use
  628. </span>
  629. </a>
  630. <a class="select-menu-item js-navigation-item js-navigation-open "
  631. href="/nanqinlang-tcp/tcp_nanqinlang/tree/3.0/General/CentOS/source/tcp_nanqinlang.c"
  632. data-name="3.0"
  633. data-skip-pjax="true"
  634. rel="nofollow">
  635. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  636. <span class="select-menu-item-text css-truncate-target" title="3.0">
  637. 3.0
  638. </span>
  639. </a>
  640. <a class="select-menu-item js-navigation-item js-navigation-open "
  641. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.9.1/General/CentOS/source/tcp_nanqinlang.c"
  642. data-name="2.9.1"
  643. data-skip-pjax="true"
  644. rel="nofollow">
  645. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  646. <span class="select-menu-item-text css-truncate-target" title="2.9.1">
  647. 2.9.1
  648. </span>
  649. </a>
  650. <a class="select-menu-item js-navigation-item js-navigation-open "
  651. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.9/General/CentOS/source/tcp_nanqinlang.c"
  652. data-name="2.9"
  653. data-skip-pjax="true"
  654. rel="nofollow">
  655. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  656. <span class="select-menu-item-text css-truncate-target" title="2.9">
  657. 2.9
  658. </span>
  659. </a>
  660. <a class="select-menu-item js-navigation-item js-navigation-open "
  661. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.8/General/CentOS/source/tcp_nanqinlang.c"
  662. data-name="2.8"
  663. data-skip-pjax="true"
  664. rel="nofollow">
  665. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  666. <span class="select-menu-item-text css-truncate-target" title="2.8">
  667. 2.8
  668. </span>
  669. </a>
  670. <a class="select-menu-item js-navigation-item js-navigation-open "
  671. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.7/General/CentOS/source/tcp_nanqinlang.c"
  672. data-name="2.7"
  673. data-skip-pjax="true"
  674. rel="nofollow">
  675. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  676. <span class="select-menu-item-text css-truncate-target" title="2.7">
  677. 2.7
  678. </span>
  679. </a>
  680. <a class="select-menu-item js-navigation-item js-navigation-open "
  681. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.6.1/General/CentOS/source/tcp_nanqinlang.c"
  682. data-name="2.6.1"
  683. data-skip-pjax="true"
  684. rel="nofollow">
  685. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  686. <span class="select-menu-item-text css-truncate-target" title="2.6.1">
  687. 2.6.1
  688. </span>
  689. </a>
  690. <a class="select-menu-item js-navigation-item js-navigation-open "
  691. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.6/General/CentOS/source/tcp_nanqinlang.c"
  692. data-name="2.6"
  693. data-skip-pjax="true"
  694. rel="nofollow">
  695. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  696. <span class="select-menu-item-text css-truncate-target" title="2.6">
  697. 2.6
  698. </span>
  699. </a>
  700. <a class="select-menu-item js-navigation-item js-navigation-open "
  701. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.5/General/CentOS/source/tcp_nanqinlang.c"
  702. data-name="2.5"
  703. data-skip-pjax="true"
  704. rel="nofollow">
  705. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  706. <span class="select-menu-item-text css-truncate-target" title="2.5">
  707. 2.5
  708. </span>
  709. </a>
  710. <a class="select-menu-item js-navigation-item js-navigation-open "
  711. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.4.1/General/CentOS/source/tcp_nanqinlang.c"
  712. data-name="2.4.1"
  713. data-skip-pjax="true"
  714. rel="nofollow">
  715. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  716. <span class="select-menu-item-text css-truncate-target" title="2.4.1">
  717. 2.4.1
  718. </span>
  719. </a>
  720. <a class="select-menu-item js-navigation-item js-navigation-open "
  721. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.4/General/CentOS/source/tcp_nanqinlang.c"
  722. data-name="2.4"
  723. data-skip-pjax="true"
  724. rel="nofollow">
  725. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  726. <span class="select-menu-item-text css-truncate-target" title="2.4">
  727. 2.4
  728. </span>
  729. </a>
  730. <a class="select-menu-item js-navigation-item js-navigation-open "
  731. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.3/General/CentOS/source/tcp_nanqinlang.c"
  732. data-name="2.3"
  733. data-skip-pjax="true"
  734. rel="nofollow">
  735. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  736. <span class="select-menu-item-text css-truncate-target" title="2.3">
  737. 2.3
  738. </span>
  739. </a>
  740. <a class="select-menu-item js-navigation-item js-navigation-open "
  741. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.2/General/CentOS/source/tcp_nanqinlang.c"
  742. data-name="2.2"
  743. data-skip-pjax="true"
  744. rel="nofollow">
  745. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  746. <span class="select-menu-item-text css-truncate-target" title="2.2">
  747. 2.2
  748. </span>
  749. </a>
  750. <a class="select-menu-item js-navigation-item js-navigation-open "
  751. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.1/General/CentOS/source/tcp_nanqinlang.c"
  752. data-name="2.1"
  753. data-skip-pjax="true"
  754. rel="nofollow">
  755. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  756. <span class="select-menu-item-text css-truncate-target" title="2.1">
  757. 2.1
  758. </span>
  759. </a>
  760. <a class="select-menu-item js-navigation-item js-navigation-open "
  761. href="/nanqinlang-tcp/tcp_nanqinlang/tree/2.0/General/CentOS/source/tcp_nanqinlang.c"
  762. data-name="2.0"
  763. data-skip-pjax="true"
  764. rel="nofollow">
  765. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  766. <span class="select-menu-item-text css-truncate-target" title="2.0">
  767. 2.0
  768. </span>
  769. </a>
  770. <a class="select-menu-item js-navigation-item js-navigation-open "
  771. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.3.1/General/CentOS/source/tcp_nanqinlang.c"
  772. data-name="1.3.1"
  773. data-skip-pjax="true"
  774. rel="nofollow">
  775. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  776. <span class="select-menu-item-text css-truncate-target" title="1.3.1">
  777. 1.3.1
  778. </span>
  779. </a>
  780. <a class="select-menu-item js-navigation-item js-navigation-open "
  781. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.3.0/General/CentOS/source/tcp_nanqinlang.c"
  782. data-name="1.3.0"
  783. data-skip-pjax="true"
  784. rel="nofollow">
  785. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  786. <span class="select-menu-item-text css-truncate-target" title="1.3.0">
  787. 1.3.0
  788. </span>
  789. </a>
  790. <a class="select-menu-item js-navigation-item js-navigation-open "
  791. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.2.0/General/CentOS/source/tcp_nanqinlang.c"
  792. data-name="1.2.0"
  793. data-skip-pjax="true"
  794. rel="nofollow">
  795. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  796. <span class="select-menu-item-text css-truncate-target" title="1.2.0">
  797. 1.2.0
  798. </span>
  799. </a>
  800. <a class="select-menu-item js-navigation-item js-navigation-open "
  801. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.1.3/General/CentOS/source/tcp_nanqinlang.c"
  802. data-name="1.1.3"
  803. data-skip-pjax="true"
  804. rel="nofollow">
  805. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  806. <span class="select-menu-item-text css-truncate-target" title="1.1.3">
  807. 1.1.3
  808. </span>
  809. </a>
  810. <a class="select-menu-item js-navigation-item js-navigation-open "
  811. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.1.1/General/CentOS/source/tcp_nanqinlang.c"
  812. data-name="1.1.1"
  813. data-skip-pjax="true"
  814. rel="nofollow">
  815. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  816. <span class="select-menu-item-text css-truncate-target" title="1.1.1">
  817. 1.1.1
  818. </span>
  819. </a>
  820. <a class="select-menu-item js-navigation-item js-navigation-open "
  821. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.1.0/General/CentOS/source/tcp_nanqinlang.c"
  822. data-name="1.1.0"
  823. data-skip-pjax="true"
  824. rel="nofollow">
  825. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  826. <span class="select-menu-item-text css-truncate-target" title="1.1.0">
  827. 1.1.0
  828. </span>
  829. </a>
  830. <a class="select-menu-item js-navigation-item js-navigation-open "
  831. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.0.1/General/CentOS/source/tcp_nanqinlang.c"
  832. data-name="1.0.1"
  833. data-skip-pjax="true"
  834. rel="nofollow">
  835. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  836. <span class="select-menu-item-text css-truncate-target" title="1.0.1">
  837. 1.0.1
  838. </span>
  839. </a>
  840. <a class="select-menu-item js-navigation-item js-navigation-open "
  841. href="/nanqinlang-tcp/tcp_nanqinlang/tree/1.0.1beta/General/CentOS/source/tcp_nanqinlang.c"
  842. data-name="1.0.1beta"
  843. data-skip-pjax="true"
  844. rel="nofollow">
  845. <svg class="octicon octicon-check select-menu-item-icon" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M12 5l-8 8-4-4 1.5-1.5L4 10l6.5-6.5z"/></svg>
  846. <span class="select-menu-item-text css-truncate-target" title="1.0.1beta">
  847. 1.0.1beta
  848. </span>
  849. </a>
  850. </div>
  851. <div class="select-menu-no-results">Nothing to show</div>
  852. </div>
  853. </div>
  854. </div>
  855. </div>
  856. <div class="BtnGroup float-right">
  857. <a href="/nanqinlang-tcp/tcp_nanqinlang/find/master"
  858. class="js-pjax-capture-input btn btn-sm BtnGroup-item"
  859. data-pjax
  860. data-hotkey="t">
  861. Find file
  862. </a>
  863. <clipboard-copy for="blob-path" class="btn btn-sm BtnGroup-item">
  864. Copy path
  865. </clipboard-copy>
  866. </div>
  867. <div id="blob-path" class="breadcrumb">
  868. <span class="repo-root js-repo-root"><span class="js-path-segment"><a data-pjax="true" href="/nanqinlang-tcp/tcp_nanqinlang"><span>tcp_nanqinlang</span></a></span></span><span class="separator">/</span><span class="js-path-segment"><a data-pjax="true" href="/nanqinlang-tcp/tcp_nanqinlang/tree/master/General"><span>General</span></a></span><span class="separator">/</span><span class="js-path-segment"><a data-pjax="true" href="/nanqinlang-tcp/tcp_nanqinlang/tree/master/General/CentOS"><span>CentOS</span></a></span><span class="separator">/</span><span class="js-path-segment"><a data-pjax="true" href="/nanqinlang-tcp/tcp_nanqinlang/tree/master/General/CentOS/source"><span>source</span></a></span><span class="separator">/</span><strong class="final-path">tcp_nanqinlang.c</strong>
  869. </div>
  870. </div>
  871. <include-fragment src="/nanqinlang-tcp/tcp_nanqinlang/contributors/master/General/CentOS/source/tcp_nanqinlang.c" class="commit-tease">
  872. <div>
  873. Fetching contributors&hellip;
  874. </div>
  875. <div class="commit-tease-contributors">
  876. <img alt="" class="loader-loading float-left" src="https://assets-cdn.github.com/images/spinners/octocat-spinner-32-EAF2F5.gif" width="16" height="16" />
  877. <span class="loader-error">Cannot retrieve contributors at this time</span>
  878. </div>
  879. </include-fragment>
  880. <div class="file">
  881. <div class="file-header">
  882. <div class="file-actions">
  883. <div class="BtnGroup">
  884. <a id="raw-url" class="btn btn-sm BtnGroup-item" href="/nanqinlang-tcp/tcp_nanqinlang/raw/master/General/CentOS/source/tcp_nanqinlang.c">Raw</a>
  885. <a class="btn btn-sm js-update-url-with-hash BtnGroup-item" data-hotkey="b" href="/nanqinlang-tcp/tcp_nanqinlang/blame/master/General/CentOS/source/tcp_nanqinlang.c">Blame</a>
  886. <a rel="nofollow" class="btn btn-sm BtnGroup-item" href="/nanqinlang-tcp/tcp_nanqinlang/commits/master/General/CentOS/source/tcp_nanqinlang.c">History</a>
  887. </div>
  888. <a class="btn-octicon tooltipped tooltipped-nw"
  889. href="x-github-client://openRepo/https://github.com/nanqinlang-tcp/tcp_nanqinlang?branch=master&amp;filepath=General%2FCentOS%2Fsource%2Ftcp_nanqinlang.c"
  890. aria-label="Open this file in GitHub Desktop"
  891. data-ga-click="Repository, open with desktop, type:windows">
  892. <svg class="octicon octicon-device-desktop" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M15 2H1c-.55 0-1 .45-1 1v9c0 .55.45 1 1 1h5.34c-.25.61-.86 1.39-2.34 2h8c-1.48-.61-2.09-1.39-2.34-2H15c.55 0 1-.45 1-1V3c0-.55-.45-1-1-1zm0 9H1V3h14v8z"/></svg>
  893. </a>
  894. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="inline-form js-update-url-with-hash" action="/nanqinlang-tcp/tcp_nanqinlang/edit/master/General/CentOS/source/tcp_nanqinlang.c" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="DPcTlFgHqkerT2aIcYE4qheNpsTDmuw557cEJ+Oyo2UEvvTdSOPYWI/zIaugb+0lacoyIJw8iOxT5LVRcQ38OQ==" />
  895. <button class="btn-octicon tooltipped tooltipped-nw" type="submit"
  896. aria-label="Fork this project and edit the file" data-hotkey="e" data-disable-with>
  897. <svg class="octicon octicon-pencil" viewBox="0 0 14 16" version="1.1" width="14" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M0 12v3h3l8-8-3-3-8 8zm3 2H1v-2h1v1h1v1zm10.3-9.3L12 6 9 3l1.3-1.3a.996.996 0 0 1 1.41 0l1.59 1.59c.39.39.39 1.02 0 1.41z"/></svg>
  898. </button>
  899. </form>
  900. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="inline-form" action="/nanqinlang-tcp/tcp_nanqinlang/delete/master/General/CentOS/source/tcp_nanqinlang.c" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="&#x2713;" /><input type="hidden" name="authenticity_token" value="IOua6yTGci2XgGYWH2ndktF7S2I/wWAJ6vFAFdnZKCfozQ9UwK4pOsugu8M3OXSnJAh6LoO6vNh/i9oZgfxIjA==" />
  901. <button class="btn-octicon btn-octicon-danger tooltipped tooltipped-nw" type="submit"
  902. aria-label="Fork this project and delete the file" data-disable-with>
  903. <svg class="octicon octicon-trashcan" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M11 2H9c0-.55-.45-1-1-1H5c-.55 0-1 .45-1 1H2c-.55 0-1 .45-1 1v1c0 .55.45 1 1 1v9c0 .55.45 1 1 1h7c.55 0 1-.45 1-1V5c.55 0 1-.45 1-1V3c0-.55-.45-1-1-1zm-1 12H3V5h1v8h1V5h1v8h1V5h1v8h1V5h1v9zm1-10H2V3h9v1z"/></svg>
  904. </button>
  905. </form> </div>
  906. <div class="file-info">
  907. 976 lines (855 sloc)
  908. <span class="file-info-divider"></span>
  909. 35.3 KB
  910. </div>
  911. </div>
  912. <div itemprop="text" class="blob-wrapper data type-c">
  913. <table class="highlight tab-size js-file-line-container" data-tab-size="8">
  914. <tr>
  915. <td id="L1" class="blob-num js-line-number" data-line-number="1"></td>
  916. <td id="LC1" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> tcp_nanqinlang</span></td>
  917. </tr>
  918. <tr>
  919. <td id="L2" class="blob-num js-line-number" data-line-number="2"></td>
  920. <td id="LC2" class="blob-code blob-code-inner js-file-line"><span class="pl-c"></span></td>
  921. </tr>
  922. <tr>
  923. <td id="L3" class="blob-num js-line-number" data-line-number="3"></td>
  924. <td id="LC3" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * CentOS</span></td>
  925. </tr>
  926. <tr>
  927. <td id="L4" class="blob-num js-line-number" data-line-number="4"></td>
  928. <td id="LC4" class="blob-code blob-code-inner js-file-line"><span class="pl-c"></span></td>
  929. </tr>
  930. <tr>
  931. <td id="L5" class="blob-num js-line-number" data-line-number="5"></td>
  932. <td id="LC5" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * v4.12.10 mainline kernel</span></td>
  933. </tr>
  934. <tr>
  935. <td id="L6" class="blob-num js-line-number" data-line-number="6"></td>
  936. <td id="LC6" class="blob-code blob-code-inner js-file-line"><span class="pl-c"></span></td>
  937. </tr>
  938. <tr>
  939. <td id="L7" class="blob-num js-line-number" data-line-number="7"></td>
  940. <td id="LC7" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> × New BBR Congestion Control</span></td>
  941. </tr>
  942. <tr>
  943. <td id="L8" class="blob-num js-line-number" data-line-number="8"></td>
  944. <td id="LC8" class="blob-code blob-code-inner js-file-line"><span class="pl-c"></span></td>
  945. </tr>
  946. <tr>
  947. <td id="L9" class="blob-num js-line-number" data-line-number="9"></td>
  948. <td id="LC9" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Modified by (C) 2017 nanqinlang</span></td>
  949. </tr>
  950. <tr>
  951. <td id="L10" class="blob-num js-line-number" data-line-number="10"></td>
  952. <td id="LC10" class="blob-code blob-code-inner js-file-line"><span class="pl-c"></span></td>
  953. </tr>
  954. <tr>
  955. <td id="L11" class="blob-num js-line-number" data-line-number="11"></td>
  956. <td id="LC11" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *******************************************************************************</span></td>
  957. </tr>
  958. <tr>
  959. <td id="L12" class="blob-num js-line-number" data-line-number="12"></td>
  960. <td id="LC12" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Bottleneck Bandwidth and RTT (BBR) congestion control</span></td>
  961. </tr>
  962. <tr>
  963. <td id="L13" class="blob-num js-line-number" data-line-number="13"></td>
  964. <td id="LC13" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  965. </tr>
  966. <tr>
  967. <td id="L14" class="blob-num js-line-number" data-line-number="14"></td>
  968. <td id="LC14" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * BBR congestion control computes the sending rate based on the delivery</span></td>
  969. </tr>
  970. <tr>
  971. <td id="L15" class="blob-num js-line-number" data-line-number="15"></td>
  972. <td id="LC15" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * rate (throughput) estimated from ACKs. In a nutshell:</span></td>
  973. </tr>
  974. <tr>
  975. <td id="L16" class="blob-num js-line-number" data-line-number="16"></td>
  976. <td id="LC16" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  977. </tr>
  978. <tr>
  979. <td id="L17" class="blob-num js-line-number" data-line-number="17"></td>
  980. <td id="LC17" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * On each ACK, update our model of the network path:</span></td>
  981. </tr>
  982. <tr>
  983. <td id="L18" class="blob-num js-line-number" data-line-number="18"></td>
  984. <td id="LC18" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * bottleneck_bandwidth = windowed_max(delivered / elapsed, 10 round trips)</span></td>
  985. </tr>
  986. <tr>
  987. <td id="L19" class="blob-num js-line-number" data-line-number="19"></td>
  988. <td id="LC19" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * min_rtt = windowed_min(rtt, 10 seconds)</span></td>
  989. </tr>
  990. <tr>
  991. <td id="L20" class="blob-num js-line-number" data-line-number="20"></td>
  992. <td id="LC20" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * pacing_rate = pacing_gain * bottleneck_bandwidth</span></td>
  993. </tr>
  994. <tr>
  995. <td id="L21" class="blob-num js-line-number" data-line-number="21"></td>
  996. <td id="LC21" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * cwnd = max(cwnd_gain * bottleneck_bandwidth * min_rtt, 4)</span></td>
  997. </tr>
  998. <tr>
  999. <td id="L22" class="blob-num js-line-number" data-line-number="22"></td>
  1000. <td id="LC22" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  1001. </tr>
  1002. <tr>
  1003. <td id="L23" class="blob-num js-line-number" data-line-number="23"></td>
  1004. <td id="LC23" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * The core algorithm does not react directly to packet losses or delays,</span></td>
  1005. </tr>
  1006. <tr>
  1007. <td id="L24" class="blob-num js-line-number" data-line-number="24"></td>
  1008. <td id="LC24" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * although BBR may adjust the size of next send per ACK when loss is</span></td>
  1009. </tr>
  1010. <tr>
  1011. <td id="L25" class="blob-num js-line-number" data-line-number="25"></td>
  1012. <td id="LC25" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * observed, or adjust the sending rate if it estimates there is a</span></td>
  1013. </tr>
  1014. <tr>
  1015. <td id="L26" class="blob-num js-line-number" data-line-number="26"></td>
  1016. <td id="LC26" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * traffic policer, in order to keep the drop rate reasonable.</span></td>
  1017. </tr>
  1018. <tr>
  1019. <td id="L27" class="blob-num js-line-number" data-line-number="27"></td>
  1020. <td id="LC27" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  1021. </tr>
  1022. <tr>
  1023. <td id="L28" class="blob-num js-line-number" data-line-number="28"></td>
  1024. <td id="LC28" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Here is a state transition diagram for BBR:</span></td>
  1025. </tr>
  1026. <tr>
  1027. <td id="L29" class="blob-num js-line-number" data-line-number="29"></td>
  1028. <td id="LC29" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  1029. </tr>
  1030. <tr>
  1031. <td id="L30" class="blob-num js-line-number" data-line-number="30"></td>
  1032. <td id="LC30" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * |</span></td>
  1033. </tr>
  1034. <tr>
  1035. <td id="L31" class="blob-num js-line-number" data-line-number="31"></td>
  1036. <td id="LC31" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * V</span></td>
  1037. </tr>
  1038. <tr>
  1039. <td id="L32" class="blob-num js-line-number" data-line-number="32"></td>
  1040. <td id="LC32" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * +---&gt; STARTUP ----+</span></td>
  1041. </tr>
  1042. <tr>
  1043. <td id="L33" class="blob-num js-line-number" data-line-number="33"></td>
  1044. <td id="LC33" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | | |</span></td>
  1045. </tr>
  1046. <tr>
  1047. <td id="L34" class="blob-num js-line-number" data-line-number="34"></td>
  1048. <td id="LC34" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | V |</span></td>
  1049. </tr>
  1050. <tr>
  1051. <td id="L35" class="blob-num js-line-number" data-line-number="35"></td>
  1052. <td id="LC35" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | DRAIN ----+</span></td>
  1053. </tr>
  1054. <tr>
  1055. <td id="L36" class="blob-num js-line-number" data-line-number="36"></td>
  1056. <td id="LC36" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | | |</span></td>
  1057. </tr>
  1058. <tr>
  1059. <td id="L37" class="blob-num js-line-number" data-line-number="37"></td>
  1060. <td id="LC37" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | V |</span></td>
  1061. </tr>
  1062. <tr>
  1063. <td id="L38" class="blob-num js-line-number" data-line-number="38"></td>
  1064. <td id="LC38" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * +---&gt; PROBE_BW ----+</span></td>
  1065. </tr>
  1066. <tr>
  1067. <td id="L39" class="blob-num js-line-number" data-line-number="39"></td>
  1068. <td id="LC39" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | ^ | |</span></td>
  1069. </tr>
  1070. <tr>
  1071. <td id="L40" class="blob-num js-line-number" data-line-number="40"></td>
  1072. <td id="LC40" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | | | |</span></td>
  1073. </tr>
  1074. <tr>
  1075. <td id="L41" class="blob-num js-line-number" data-line-number="41"></td>
  1076. <td id="LC41" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | +----+ |</span></td>
  1077. </tr>
  1078. <tr>
  1079. <td id="L42" class="blob-num js-line-number" data-line-number="42"></td>
  1080. <td id="LC42" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * | |</span></td>
  1081. </tr>
  1082. <tr>
  1083. <td id="L43" class="blob-num js-line-number" data-line-number="43"></td>
  1084. <td id="LC43" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * +---- PROBE_RTT &lt;--+</span></td>
  1085. </tr>
  1086. <tr>
  1087. <td id="L44" class="blob-num js-line-number" data-line-number="44"></td>
  1088. <td id="LC44" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  1089. </tr>
  1090. <tr>
  1091. <td id="L45" class="blob-num js-line-number" data-line-number="45"></td>
  1092. <td id="LC45" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * A BBR flow starts in STARTUP, and ramps up its sending rate quickly.</span></td>
  1093. </tr>
  1094. <tr>
  1095. <td id="L46" class="blob-num js-line-number" data-line-number="46"></td>
  1096. <td id="LC46" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * When it estimates the pipe is full, it enters DRAIN to drain the queue.</span></td>
  1097. </tr>
  1098. <tr>
  1099. <td id="L47" class="blob-num js-line-number" data-line-number="47"></td>
  1100. <td id="LC47" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * In steady state a BBR flow only uses PROBE_BW and PROBE_RTT.</span></td>
  1101. </tr>
  1102. <tr>
  1103. <td id="L48" class="blob-num js-line-number" data-line-number="48"></td>
  1104. <td id="LC48" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * A long-lived BBR flow spends the vast majority of its time remaining</span></td>
  1105. </tr>
  1106. <tr>
  1107. <td id="L49" class="blob-num js-line-number" data-line-number="49"></td>
  1108. <td id="LC49" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * (repeatedly) in PROBE_BW, fully probing and utilizing the pipe&#39;s bandwidth</span></td>
  1109. </tr>
  1110. <tr>
  1111. <td id="L50" class="blob-num js-line-number" data-line-number="50"></td>
  1112. <td id="LC50" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * in a fair manner, with a small, bounded queue. *If* a flow has been</span></td>
  1113. </tr>
  1114. <tr>
  1115. <td id="L51" class="blob-num js-line-number" data-line-number="51"></td>
  1116. <td id="LC51" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * continuously sending for the entire min_rtt window, and hasn&#39;t seen an RTT</span></td>
  1117. </tr>
  1118. <tr>
  1119. <td id="L52" class="blob-num js-line-number" data-line-number="52"></td>
  1120. <td id="LC52" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * sample that matches or decreases its min_rtt estimate for 10 seconds, then</span></td>
  1121. </tr>
  1122. <tr>
  1123. <td id="L53" class="blob-num js-line-number" data-line-number="53"></td>
  1124. <td id="LC53" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * it briefly enters PROBE_RTT to cut inflight to a minimum value to re-probe</span></td>
  1125. </tr>
  1126. <tr>
  1127. <td id="L54" class="blob-num js-line-number" data-line-number="54"></td>
  1128. <td id="LC54" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * the path&#39;s two-way propagation delay (min_rtt). When exiting PROBE_RTT, if</span></td>
  1129. </tr>
  1130. <tr>
  1131. <td id="L55" class="blob-num js-line-number" data-line-number="55"></td>
  1132. <td id="LC55" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * we estimated that we reached the full bw of the pipe then we enter PROBE_BW;</span></td>
  1133. </tr>
  1134. <tr>
  1135. <td id="L56" class="blob-num js-line-number" data-line-number="56"></td>
  1136. <td id="LC56" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * otherwise we enter STARTUP to try to fill the pipe.</span></td>
  1137. </tr>
  1138. <tr>
  1139. <td id="L57" class="blob-num js-line-number" data-line-number="57"></td>
  1140. <td id="LC57" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  1141. </tr>
  1142. <tr>
  1143. <td id="L58" class="blob-num js-line-number" data-line-number="58"></td>
  1144. <td id="LC58" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * BBR is described in detail in:</span></td>
  1145. </tr>
  1146. <tr>
  1147. <td id="L59" class="blob-num js-line-number" data-line-number="59"></td>
  1148. <td id="LC59" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * &quot;BBR: Congestion-Based Congestion Control&quot;,</span></td>
  1149. </tr>
  1150. <tr>
  1151. <td id="L60" class="blob-num js-line-number" data-line-number="60"></td>
  1152. <td id="LC60" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Neal Cardwell, Yuchung Cheng, C. Stephen Gunn, Soheil Hassas Yeganeh,</span></td>
  1153. </tr>
  1154. <tr>
  1155. <td id="L61" class="blob-num js-line-number" data-line-number="61"></td>
  1156. <td id="LC61" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Van Jacobson. ACM Queue, Vol. 14 No. 5, September-October 2016.</span></td>
  1157. </tr>
  1158. <tr>
  1159. <td id="L62" class="blob-num js-line-number" data-line-number="62"></td>
  1160. <td id="LC62" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  1161. </tr>
  1162. <tr>
  1163. <td id="L63" class="blob-num js-line-number" data-line-number="63"></td>
  1164. <td id="LC63" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * There is a public e-mail list for discussing BBR development and testing:</span></td>
  1165. </tr>
  1166. <tr>
  1167. <td id="L64" class="blob-num js-line-number" data-line-number="64"></td>
  1168. <td id="LC64" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * https://groups.google.com/forum/#!forum/bbr-dev</span></td>
  1169. </tr>
  1170. <tr>
  1171. <td id="L65" class="blob-num js-line-number" data-line-number="65"></td>
  1172. <td id="LC65" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  1173. </tr>
  1174. <tr>
  1175. <td id="L66" class="blob-num js-line-number" data-line-number="66"></td>
  1176. <td id="LC66" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * NOTE: BBR *must* be used with the fq qdisc (&quot;man tc-fq&quot;) with pacing enabled,</span></td>
  1177. </tr>
  1178. <tr>
  1179. <td id="L67" class="blob-num js-line-number" data-line-number="67"></td>
  1180. <td id="LC67" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * since pacing is integral to the BBR design and implementation.</span></td>
  1181. </tr>
  1182. <tr>
  1183. <td id="L68" class="blob-num js-line-number" data-line-number="68"></td>
  1184. <td id="LC68" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * BBR without pacing would not function properly, and may incur unnecessary</span></td>
  1185. </tr>
  1186. <tr>
  1187. <td id="L69" class="blob-num js-line-number" data-line-number="69"></td>
  1188. <td id="LC69" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * high packet loss rates.</span></td>
  1189. </tr>
  1190. <tr>
  1191. <td id="L70" class="blob-num js-line-number" data-line-number="70"></td>
  1192. <td id="LC70" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  1193. </tr>
  1194. <tr>
  1195. <td id="L71" class="blob-num js-line-number" data-line-number="71"></td>
  1196. <td id="LC71" class="blob-code blob-code-inner js-file-line">
  1197. </td>
  1198. </tr>
  1199. <tr>
  1200. <td id="L72" class="blob-num js-line-number" data-line-number="72"></td>
  1201. <td id="LC72" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">include</span> <span class="pl-s"><span class="pl-pds">&lt;</span>linux/module.h<span class="pl-pds">&gt;</span></span></td>
  1202. </tr>
  1203. <tr>
  1204. <td id="L73" class="blob-num js-line-number" data-line-number="73"></td>
  1205. <td id="LC73" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">include</span> <span class="pl-s"><span class="pl-pds">&lt;</span>linux/inet.h<span class="pl-pds">&gt;</span></span></td>
  1206. </tr>
  1207. <tr>
  1208. <td id="L74" class="blob-num js-line-number" data-line-number="74"></td>
  1209. <td id="LC74" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">include</span> <span class="pl-s"><span class="pl-pds">&lt;</span>linux/inet_diag.h<span class="pl-pds">&gt;</span></span></td>
  1210. </tr>
  1211. <tr>
  1212. <td id="L75" class="blob-num js-line-number" data-line-number="75"></td>
  1213. <td id="LC75" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">include</span> <span class="pl-s"><span class="pl-pds">&lt;</span>linux/random.h<span class="pl-pds">&gt;</span></span></td>
  1214. </tr>
  1215. <tr>
  1216. <td id="L76" class="blob-num js-line-number" data-line-number="76"></td>
  1217. <td id="LC76" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">include</span> <span class="pl-s"><span class="pl-pds">&lt;</span>linux/win_minmax.h<span class="pl-pds">&gt;</span></span></td>
  1218. </tr>
  1219. <tr>
  1220. <td id="L77" class="blob-num js-line-number" data-line-number="77"></td>
  1221. <td id="LC77" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">include</span> <span class="pl-s"><span class="pl-pds">&lt;</span>net/tcp.h<span class="pl-pds">&gt;</span></span></td>
  1222. </tr>
  1223. <tr>
  1224. <td id="L78" class="blob-num js-line-number" data-line-number="78"></td>
  1225. <td id="LC78" class="blob-code blob-code-inner js-file-line">
  1226. </td>
  1227. </tr>
  1228. <tr>
  1229. <td id="L79" class="blob-num js-line-number" data-line-number="79"></td>
  1230. <td id="LC79" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Scale factor for rate in pkt/uSec unit to avoid truncation in bandwidth</span></td>
  1231. </tr>
  1232. <tr>
  1233. <td id="L80" class="blob-num js-line-number" data-line-number="80"></td>
  1234. <td id="LC80" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * estimation. The rate unit ~= (1500 bytes / 1 usec / 2^24) ~= 715 bps.</span></td>
  1235. </tr>
  1236. <tr>
  1237. <td id="L81" class="blob-num js-line-number" data-line-number="81"></td>
  1238. <td id="LC81" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * This handles bandwidths from 0.06pps (715bps) to 256Mpps (3Tbps) in a u32.</span></td>
  1239. </tr>
  1240. <tr>
  1241. <td id="L82" class="blob-num js-line-number" data-line-number="82"></td>
  1242. <td id="LC82" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Since the minimum window is &gt;=4 packets, the lower bound isn&#39;t</span></td>
  1243. </tr>
  1244. <tr>
  1245. <td id="L83" class="blob-num js-line-number" data-line-number="83"></td>
  1246. <td id="LC83" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * an issue. The upper bound isn&#39;t an issue with existing technologies.</span></td>
  1247. </tr>
  1248. <tr>
  1249. <td id="L84" class="blob-num js-line-number" data-line-number="84"></td>
  1250. <td id="LC84" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  1251. </tr>
  1252. <tr>
  1253. <td id="L85" class="blob-num js-line-number" data-line-number="85"></td>
  1254. <td id="LC85" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">define</span> <span class="pl-en">BW_SCALE</span> <span class="pl-c1">24</span></td>
  1255. </tr>
  1256. <tr>
  1257. <td id="L86" class="blob-num js-line-number" data-line-number="86"></td>
  1258. <td id="LC86" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">define</span> <span class="pl-en">BW_UNIT</span> (<span class="pl-c1">1</span> &lt;&lt; BW_SCALE)</td>
  1259. </tr>
  1260. <tr>
  1261. <td id="L87" class="blob-num js-line-number" data-line-number="87"></td>
  1262. <td id="LC87" class="blob-code blob-code-inner js-file-line">
  1263. </td>
  1264. </tr>
  1265. <tr>
  1266. <td id="L88" class="blob-num js-line-number" data-line-number="88"></td>
  1267. <td id="LC88" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">define</span> <span class="pl-en">BBR_SCALE</span> <span class="pl-c1">8</span> <span class="pl-c"><span class="pl-c">/*</span> scaling factor for fractions in BBR (e.g. gains) <span class="pl-c">*/</span></span></td>
  1268. </tr>
  1269. <tr>
  1270. <td id="L89" class="blob-num js-line-number" data-line-number="89"></td>
  1271. <td id="LC89" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">define</span> <span class="pl-en">BBR_UNIT</span> (<span class="pl-c1">1</span> &lt;&lt; BBR_SCALE)</td>
  1272. </tr>
  1273. <tr>
  1274. <td id="L90" class="blob-num js-line-number" data-line-number="90"></td>
  1275. <td id="LC90" class="blob-code blob-code-inner js-file-line">
  1276. </td>
  1277. </tr>
  1278. <tr>
  1279. <td id="L91" class="blob-num js-line-number" data-line-number="91"></td>
  1280. <td id="LC91" class="blob-code blob-code-inner js-file-line">#<span class="pl-k">define</span> <span class="pl-en">CYCLE_LEN</span> <span class="pl-c1">8</span> <span class="pl-c"><span class="pl-c">/*</span> number of phases in a pacing gain cycle <span class="pl-c">*/</span></span></td>
  1281. </tr>
  1282. <tr>
  1283. <td id="L92" class="blob-num js-line-number" data-line-number="92"></td>
  1284. <td id="LC92" class="blob-code blob-code-inner js-file-line">
  1285. </td>
  1286. </tr>
  1287. <tr>
  1288. <td id="L93" class="blob-num js-line-number" data-line-number="93"></td>
  1289. <td id="LC93" class="blob-code blob-code-inner js-file-line">
  1290. </td>
  1291. </tr>
  1292. <tr>
  1293. <td id="L94" class="blob-num js-line-number" data-line-number="94"></td>
  1294. <td id="LC94" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> **************************************************************************</span></td>
  1295. </tr>
  1296. <tr>
  1297. <td id="L95" class="blob-num js-line-number" data-line-number="95"></td>
  1298. <td id="LC95" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> the following is the main</span></td>
  1299. </tr>
  1300. <tr>
  1301. <td id="L96" class="blob-num js-line-number" data-line-number="96"></td>
  1302. <td id="LC96" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> **************************************************************************</span></td>
  1303. </tr>
  1304. <tr>
  1305. <td id="L97" class="blob-num js-line-number" data-line-number="97"></td>
  1306. <td id="LC97" class="blob-code blob-code-inner js-file-line">
  1307. </td>
  1308. </tr>
  1309. <tr>
  1310. <td id="L98" class="blob-num js-line-number" data-line-number="98"></td>
  1311. <td id="LC98" class="blob-code blob-code-inner js-file-line">
  1312. </td>
  1313. </tr>
  1314. <tr>
  1315. <td id="L99" class="blob-num js-line-number" data-line-number="99"></td>
  1316. <td id="LC99" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> BBR has the following modes for deciding how fast to send: <span class="pl-c">*/</span></span></td>
  1317. </tr>
  1318. <tr>
  1319. <td id="L100" class="blob-num js-line-number" data-line-number="100"></td>
  1320. <td id="LC100" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> four working mode</span></td>
  1321. </tr>
  1322. <tr>
  1323. <td id="L101" class="blob-num js-line-number" data-line-number="101"></td>
  1324. <td id="LC101" class="blob-code blob-code-inner js-file-line"><span class="pl-k">enum</span> bbr_mode {</td>
  1325. </tr>
  1326. <tr>
  1327. <td id="L102" class="blob-num js-line-number" data-line-number="102"></td>
  1328. <td id="LC102" class="blob-code blob-code-inner js-file-line"> BBR_STARTUP, <span class="pl-c"><span class="pl-c">/*</span> ramp up sending rate rapidly to fill pipe <span class="pl-c">*/</span></span></td>
  1329. </tr>
  1330. <tr>
  1331. <td id="L103" class="blob-num js-line-number" data-line-number="103"></td>
  1332. <td id="LC103" class="blob-code blob-code-inner js-file-line"> BBR_DRAIN, <span class="pl-c"><span class="pl-c">/*</span> drain any queue created during startup <span class="pl-c">*/</span></span></td>
  1333. </tr>
  1334. <tr>
  1335. <td id="L104" class="blob-num js-line-number" data-line-number="104"></td>
  1336. <td id="LC104" class="blob-code blob-code-inner js-file-line"> BBR_PROBE_BW, <span class="pl-c"><span class="pl-c">/*</span> discover, share bw: pace around estimated bw <span class="pl-c">*/</span></span></td>
  1337. </tr>
  1338. <tr>
  1339. <td id="L105" class="blob-num js-line-number" data-line-number="105"></td>
  1340. <td id="LC105" class="blob-code blob-code-inner js-file-line"> BBR_PROBE_RTT, <span class="pl-c"><span class="pl-c">/*</span> cut cwnd to min to probe min_rtt <span class="pl-c">*/</span></span></td>
  1341. </tr>
  1342. <tr>
  1343. <td id="L106" class="blob-num js-line-number" data-line-number="106"></td>
  1344. <td id="LC106" class="blob-code blob-code-inner js-file-line">};</td>
  1345. </tr>
  1346. <tr>
  1347. <td id="L107" class="blob-num js-line-number" data-line-number="107"></td>
  1348. <td id="LC107" class="blob-code blob-code-inner js-file-line">
  1349. </td>
  1350. </tr>
  1351. <tr>
  1352. <td id="L108" class="blob-num js-line-number" data-line-number="108"></td>
  1353. <td id="LC108" class="blob-code blob-code-inner js-file-line">
  1354. </td>
  1355. </tr>
  1356. <tr>
  1357. <td id="L109" class="blob-num js-line-number" data-line-number="109"></td>
  1358. <td id="LC109" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> BBR congestion control block <span class="pl-c">*/</span></span></td>
  1359. </tr>
  1360. <tr>
  1361. <td id="L110" class="blob-num js-line-number" data-line-number="110"></td>
  1362. <td id="LC110" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> control block with u32 values you set</span></td>
  1363. </tr>
  1364. <tr>
  1365. <td id="L111" class="blob-num js-line-number" data-line-number="111"></td>
  1366. <td id="LC111" class="blob-code blob-code-inner js-file-line"><span class="pl-k">struct</span> bbr {</td>
  1367. </tr>
  1368. <tr>
  1369. <td id="L112" class="blob-num js-line-number" data-line-number="112"></td>
  1370. <td id="LC112" class="blob-code blob-code-inner js-file-line"> u32 min_rtt_us; <span class="pl-c"><span class="pl-c">/*</span> min RTT in min_rtt_win_sec window <span class="pl-c">*/</span></span></td>
  1371. </tr>
  1372. <tr>
  1373. <td id="L113" class="blob-num js-line-number" data-line-number="113"></td>
  1374. <td id="LC113" class="blob-code blob-code-inner js-file-line"> u32 min_rtt_stamp; <span class="pl-c"><span class="pl-c">/*</span> timestamp of min_rtt_us <span class="pl-c">*/</span></span></td>
  1375. </tr>
  1376. <tr>
  1377. <td id="L114" class="blob-num js-line-number" data-line-number="114"></td>
  1378. <td id="LC114" class="blob-code blob-code-inner js-file-line"> u32 probe_rtt_done_stamp; <span class="pl-c"><span class="pl-c">/*</span> end time for BBR_PROBE_RTT mode <span class="pl-c">*/</span></span></td>
  1379. </tr>
  1380. <tr>
  1381. <td id="L115" class="blob-num js-line-number" data-line-number="115"></td>
  1382. <td id="LC115" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> minmax bw; <span class="pl-c"><span class="pl-c">/*</span> Max recent delivery rate in pkts/uS &lt;&lt; 24 <span class="pl-c">*/</span></span></td>
  1383. </tr>
  1384. <tr>
  1385. <td id="L116" class="blob-num js-line-number" data-line-number="116"></td>
  1386. <td id="LC116" class="blob-code blob-code-inner js-file-line"> u32 rtt_cnt; <span class="pl-c"><span class="pl-c">/*</span> count of packet-timed rounds elapsed <span class="pl-c">*/</span></span></td>
  1387. </tr>
  1388. <tr>
  1389. <td id="L117" class="blob-num js-line-number" data-line-number="117"></td>
  1390. <td id="LC117" class="blob-code blob-code-inner js-file-line"> u32 next_rtt_delivered; <span class="pl-c"><span class="pl-c">/*</span> scb-&gt;tx.delivered at end of round <span class="pl-c">*/</span></span></td>
  1391. </tr>
  1392. <tr>
  1393. <td id="L118" class="blob-num js-line-number" data-line-number="118"></td>
  1394. <td id="LC118" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> skb_mstamp cycle_mstamp; <span class="pl-c"><span class="pl-c">/*</span> time of this cycle phase start <span class="pl-c">*/</span></span></td>
  1395. </tr>
  1396. <tr>
  1397. <td id="L119" class="blob-num js-line-number" data-line-number="119"></td>
  1398. <td id="LC119" class="blob-code blob-code-inner js-file-line"> u32 mode:<span class="pl-c1">3</span>, <span class="pl-c"><span class="pl-c">/*</span> current bbr_mode in state machine <span class="pl-c">*/</span></span></td>
  1399. </tr>
  1400. <tr>
  1401. <td id="L120" class="blob-num js-line-number" data-line-number="120"></td>
  1402. <td id="LC120" class="blob-code blob-code-inner js-file-line"> prev_ca_state:<span class="pl-c1">3</span>, <span class="pl-c"><span class="pl-c">/*</span> CA state on previous ACK <span class="pl-c">*/</span></span></td>
  1403. </tr>
  1404. <tr>
  1405. <td id="L121" class="blob-num js-line-number" data-line-number="121"></td>
  1406. <td id="LC121" class="blob-code blob-code-inner js-file-line"> packet_conservation:<span class="pl-c1">1</span>, <span class="pl-c"><span class="pl-c">/*</span> use packet conservation? <span class="pl-c">*/</span></span></td>
  1407. </tr>
  1408. <tr>
  1409. <td id="L122" class="blob-num js-line-number" data-line-number="122"></td>
  1410. <td id="LC122" class="blob-code blob-code-inner js-file-line"> restore_cwnd:<span class="pl-c1">1</span>, <span class="pl-c"><span class="pl-c">/*</span> decided to revert cwnd to old value <span class="pl-c">*/</span></span></td>
  1411. </tr>
  1412. <tr>
  1413. <td id="L123" class="blob-num js-line-number" data-line-number="123"></td>
  1414. <td id="LC123" class="blob-code blob-code-inner js-file-line"> round_start:<span class="pl-c1">1</span>, <span class="pl-c"><span class="pl-c">/*</span> start of packet-timed tx-&gt;ack round? <span class="pl-c">*/</span></span></td>
  1415. </tr>
  1416. <tr>
  1417. <td id="L124" class="blob-num js-line-number" data-line-number="124"></td>
  1418. <td id="LC124" class="blob-code blob-code-inner js-file-line"> tso_segs_goal:<span class="pl-c1">7</span>, <span class="pl-c"><span class="pl-c">/*</span> segments we want in each skb we send <span class="pl-c">*/</span></span></td>
  1419. </tr>
  1420. <tr>
  1421. <td id="L125" class="blob-num js-line-number" data-line-number="125"></td>
  1422. <td id="LC125" class="blob-code blob-code-inner js-file-line"> idle_restart:<span class="pl-c1">1</span>, <span class="pl-c"><span class="pl-c">/*</span> restarting after idle? <span class="pl-c">*/</span></span></td>
  1423. </tr>
  1424. <tr>
  1425. <td id="L126" class="blob-num js-line-number" data-line-number="126"></td>
  1426. <td id="LC126" class="blob-code blob-code-inner js-file-line"> probe_rtt_round_done:<span class="pl-c1">1</span>, <span class="pl-c"><span class="pl-c">/*</span> a BBR_PROBE_RTT round at 4 pkts? <span class="pl-c">*/</span></span></td>
  1427. </tr>
  1428. <tr>
  1429. <td id="L127" class="blob-num js-line-number" data-line-number="127"></td>
  1430. <td id="LC127" class="blob-code blob-code-inner js-file-line"> unused:<span class="pl-c1">5</span>,</td>
  1431. </tr>
  1432. <tr>
  1433. <td id="L128" class="blob-num js-line-number" data-line-number="128"></td>
  1434. <td id="LC128" class="blob-code blob-code-inner js-file-line"> lt_is_sampling:<span class="pl-c1">1</span>, <span class="pl-c"><span class="pl-c">/*</span> taking long-term (&quot;LT&quot;) samples now? <span class="pl-c">*/</span></span></td>
  1435. </tr>
  1436. <tr>
  1437. <td id="L129" class="blob-num js-line-number" data-line-number="129"></td>
  1438. <td id="LC129" class="blob-code blob-code-inner js-file-line"> lt_rtt_cnt:<span class="pl-c1">7</span>, <span class="pl-c"><span class="pl-c">/*</span> round trips in long-term interval <span class="pl-c">*/</span></span></td>
  1439. </tr>
  1440. <tr>
  1441. <td id="L130" class="blob-num js-line-number" data-line-number="130"></td>
  1442. <td id="LC130" class="blob-code blob-code-inner js-file-line"> lt_use_bw:<span class="pl-c1">1</span>; <span class="pl-c"><span class="pl-c">/*</span> use lt_bw as our bw estimate? <span class="pl-c">*/</span></span></td>
  1443. </tr>
  1444. <tr>
  1445. <td id="L131" class="blob-num js-line-number" data-line-number="131"></td>
  1446. <td id="LC131" class="blob-code blob-code-inner js-file-line"> u32 lt_bw; <span class="pl-c"><span class="pl-c">/*</span> LT est delivery rate in pkts/uS &lt;&lt; 24 <span class="pl-c">*/</span></span></td>
  1447. </tr>
  1448. <tr>
  1449. <td id="L132" class="blob-num js-line-number" data-line-number="132"></td>
  1450. <td id="LC132" class="blob-code blob-code-inner js-file-line"> u32 lt_last_delivered; <span class="pl-c"><span class="pl-c">/*</span> LT intvl start: tp-&gt;delivered <span class="pl-c">*/</span></span></td>
  1451. </tr>
  1452. <tr>
  1453. <td id="L133" class="blob-num js-line-number" data-line-number="133"></td>
  1454. <td id="LC133" class="blob-code blob-code-inner js-file-line"> u32 lt_last_stamp; <span class="pl-c"><span class="pl-c">/*</span> LT intvl start: tp-&gt;delivered_mstamp <span class="pl-c">*/</span></span></td>
  1455. </tr>
  1456. <tr>
  1457. <td id="L134" class="blob-num js-line-number" data-line-number="134"></td>
  1458. <td id="LC134" class="blob-code blob-code-inner js-file-line"> u32 lt_last_lost; <span class="pl-c"><span class="pl-c">/*</span> LT intvl start: tp-&gt;lost <span class="pl-c">*/</span></span></td>
  1459. </tr>
  1460. <tr>
  1461. <td id="L135" class="blob-num js-line-number" data-line-number="135"></td>
  1462. <td id="LC135" class="blob-code blob-code-inner js-file-line"> u32 pacing_gain:<span class="pl-c1">10</span>, <span class="pl-c"><span class="pl-c">/*</span> current gain for setting pacing rate <span class="pl-c">*/</span></span></td>
  1463. </tr>
  1464. <tr>
  1465. <td id="L136" class="blob-num js-line-number" data-line-number="136"></td>
  1466. <td id="LC136" class="blob-code blob-code-inner js-file-line"> cwnd_gain:<span class="pl-c1">10</span>, <span class="pl-c"><span class="pl-c">/*</span> current gain for setting cwnd <span class="pl-c">*/</span></span></td>
  1467. </tr>
  1468. <tr>
  1469. <td id="L137" class="blob-num js-line-number" data-line-number="137"></td>
  1470. <td id="LC137" class="blob-code blob-code-inner js-file-line"> full_bw_cnt:<span class="pl-c1">3</span>, <span class="pl-c"><span class="pl-c">/*</span> number of rounds without large bw gains <span class="pl-c">*/</span></span></td>
  1471. </tr>
  1472. <tr>
  1473. <td id="L138" class="blob-num js-line-number" data-line-number="138"></td>
  1474. <td id="LC138" class="blob-code blob-code-inner js-file-line"> cycle_idx:<span class="pl-c1">3</span>, <span class="pl-c"><span class="pl-c">/*</span> current index in pacing_gain cycle array <span class="pl-c">*/</span></span></td>
  1475. </tr>
  1476. <tr>
  1477. <td id="L139" class="blob-num js-line-number" data-line-number="139"></td>
  1478. <td id="LC139" class="blob-code blob-code-inner js-file-line"> unused_b:<span class="pl-c1">5</span>;</td>
  1479. </tr>
  1480. <tr>
  1481. <td id="L140" class="blob-num js-line-number" data-line-number="140"></td>
  1482. <td id="LC140" class="blob-code blob-code-inner js-file-line"> u32 prior_cwnd; <span class="pl-c"><span class="pl-c">/*</span> prior cwnd upon entering loss recovery <span class="pl-c">*/</span></span></td>
  1483. </tr>
  1484. <tr>
  1485. <td id="L141" class="blob-num js-line-number" data-line-number="141"></td>
  1486. <td id="LC141" class="blob-code blob-code-inner js-file-line"> u32 full_bw; <span class="pl-c"><span class="pl-c">/*</span> recent bw, to estimate if pipe is full <span class="pl-c">*/</span></span></td>
  1487. </tr>
  1488. <tr>
  1489. <td id="L142" class="blob-num js-line-number" data-line-number="142"></td>
  1490. <td id="LC142" class="blob-code blob-code-inner js-file-line">};</td>
  1491. </tr>
  1492. <tr>
  1493. <td id="L143" class="blob-num js-line-number" data-line-number="143"></td>
  1494. <td id="LC143" class="blob-code blob-code-inner js-file-line">
  1495. </td>
  1496. </tr>
  1497. <tr>
  1498. <td id="L144" class="blob-num js-line-number" data-line-number="144"></td>
  1499. <td id="LC144" class="blob-code blob-code-inner js-file-line">
  1500. </td>
  1501. </tr>
  1502. <tr>
  1503. <td id="L145" class="blob-num js-line-number" data-line-number="145"></td>
  1504. <td id="LC145" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Window length of bw filter (in rounds): <span class="pl-c">*/</span></span></td>
  1505. </tr>
  1506. <tr>
  1507. <td id="L146" class="blob-num js-line-number" data-line-number="146"></td>
  1508. <td id="LC146" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> according to the above define: &quot;#define CYCLE_LEN 8&quot;</span></td>
  1509. </tr>
  1510. <tr>
  1511. <td id="L147" class="blob-num js-line-number" data-line-number="147"></td>
  1512. <td id="LC147" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> default is &quot;+2&quot;</span></td>
  1513. </tr>
  1514. <tr>
  1515. <td id="L148" class="blob-num js-line-number" data-line-number="148"></td>
  1516. <td id="LC148" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> <span class="pl-k">int</span> bbr_bw_rtts = CYCLE_LEN + <span class="pl-c1">2</span>;</td>
  1517. </tr>
  1518. <tr>
  1519. <td id="L149" class="blob-num js-line-number" data-line-number="149"></td>
  1520. <td id="LC149" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Window length of min_rtt filter (in sec): <span class="pl-c">*/</span></span></td>
  1521. </tr>
  1522. <tr>
  1523. <td id="L150" class="blob-num js-line-number" data-line-number="150"></td>
  1524. <td id="LC150" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> minimum RTT</span></td>
  1525. </tr>
  1526. <tr>
  1527. <td id="L151" class="blob-num js-line-number" data-line-number="151"></td>
  1528. <td id="LC151" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> default is 10 seconds</span></td>
  1529. </tr>
  1530. <tr>
  1531. <td id="L152" class="blob-num js-line-number" data-line-number="152"></td>
  1532. <td id="LC152" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_min_rtt_win_sec = <span class="pl-c1">10</span>;</td>
  1533. </tr>
  1534. <tr>
  1535. <td id="L153" class="blob-num js-line-number" data-line-number="153"></td>
  1536. <td id="LC153" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Minimum time (in ms) spent at bbr_cwnd_min_target in BBR_PROBE_RTT mode: <span class="pl-c">*/</span></span></td>
  1537. </tr>
  1538. <tr>
  1539. <td id="L154" class="blob-num js-line-number" data-line-number="154"></td>
  1540. <td id="LC154" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> minimum time of keeping in BBR_DRAIN mode</span></td>
  1541. </tr>
  1542. <tr>
  1543. <td id="L155" class="blob-num js-line-number" data-line-number="155"></td>
  1544. <td id="LC155" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> default is 200 ms</span></td>
  1545. </tr>
  1546. <tr>
  1547. <td id="L156" class="blob-num js-line-number" data-line-number="156"></td>
  1548. <td id="LC156" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> i set it as 100 ms, decrease minimum drain&#39;s time to early switch to BBR_PROBE_BW mode</span></td>
  1549. </tr>
  1550. <tr>
  1551. <td id="L157" class="blob-num js-line-number" data-line-number="157"></td>
  1552. <td id="LC157" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_probe_rtt_mode_ms = <span class="pl-c1">100</span>;</td>
  1553. </tr>
  1554. <tr>
  1555. <td id="L158" class="blob-num js-line-number" data-line-number="158"></td>
  1556. <td id="LC158" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Skip TSO below the following bandwidth (bits/sec): <span class="pl-c">*/</span></span></td>
  1557. </tr>
  1558. <tr>
  1559. <td id="L159" class="blob-num js-line-number" data-line-number="159"></td>
  1560. <td id="LC159" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> <span class="pl-k">int</span> bbr_min_tso_rate = <span class="pl-c1">1200000</span>;</td>
  1561. </tr>
  1562. <tr>
  1563. <td id="L160" class="blob-num js-line-number" data-line-number="160"></td>
  1564. <td id="LC160" class="blob-code blob-code-inner js-file-line">
  1565. </td>
  1566. </tr>
  1567. <tr>
  1568. <td id="L161" class="blob-num js-line-number" data-line-number="161"></td>
  1569. <td id="LC161" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> We use a high_gain value of 2/ln(2) because it&#39;s the smallest pacing gain</span></td>
  1570. </tr>
  1571. <tr>
  1572. <td id="L162" class="blob-num js-line-number" data-line-number="162"></td>
  1573. <td id="LC162" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * that will allow a smoothly increasing pacing rate that will double each RTT</span></td>
  1574. </tr>
  1575. <tr>
  1576. <td id="L163" class="blob-num js-line-number" data-line-number="163"></td>
  1577. <td id="LC163" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * and send the same number of packets per RTT that an un-paced, slow-starting</span></td>
  1578. </tr>
  1579. <tr>
  1580. <td id="L164" class="blob-num js-line-number" data-line-number="164"></td>
  1581. <td id="LC164" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Reno or CUBIC flow would:</span></td>
  1582. </tr>
  1583. <tr>
  1584. <td id="L165" class="blob-num js-line-number" data-line-number="165"></td>
  1585. <td id="LC165" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  1586. </tr>
  1587. <tr>
  1588. <td id="L166" class="blob-num js-line-number" data-line-number="166"></td>
  1589. <td id="LC166" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> defaultlt use [2885/1000 + 1] to balance high gain pacing</span></td>
  1590. </tr>
  1591. <tr>
  1592. <td id="L167" class="blob-num js-line-number" data-line-number="167"></td>
  1593. <td id="LC167" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> i set it as [3 + 1]</span></td>
  1594. </tr>
  1595. <tr>
  1596. <td id="L168" class="blob-num js-line-number" data-line-number="168"></td>
  1597. <td id="LC168" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> <span class="pl-k">int</span> bbr_high_gain = BBR_UNIT * <span class="pl-c1">3000</span> / <span class="pl-c1">1000</span> + <span class="pl-c1">1</span>;</td>
  1598. </tr>
  1599. <tr>
  1600. <td id="L169" class="blob-num js-line-number" data-line-number="169"></td>
  1601. <td id="LC169" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> The pacing gain of 1/high_gain in BBR_DRAIN is calculated to typically drain</span></td>
  1602. </tr>
  1603. <tr>
  1604. <td id="L170" class="blob-num js-line-number" data-line-number="170"></td>
  1605. <td id="LC170" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * the queue created in BBR_STARTUP in a single round:</span></td>
  1606. </tr>
  1607. <tr>
  1608. <td id="L171" class="blob-num js-line-number" data-line-number="171"></td>
  1609. <td id="LC171" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  1610. </tr>
  1611. <tr>
  1612. <td id="L172" class="blob-num js-line-number" data-line-number="172"></td>
  1613. <td id="LC172" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> according to above, set this as [3 + 1]</span></td>
  1614. </tr>
  1615. <tr>
  1616. <td id="L173" class="blob-num js-line-number" data-line-number="173"></td>
  1617. <td id="LC173" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> <span class="pl-k">int</span> bbr_drain_gain = BBR_UNIT * <span class="pl-c1">1000</span> / <span class="pl-c1">3000</span>;</td>
  1618. </tr>
  1619. <tr>
  1620. <td id="L174" class="blob-num js-line-number" data-line-number="174"></td>
  1621. <td id="LC174" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> The gain for deriving steady-state cwnd tolerates delayed/stretched ACKs: <span class="pl-c">*/</span></span></td>
  1622. </tr>
  1623. <tr>
  1624. <td id="L175" class="blob-num js-line-number" data-line-number="175"></td>
  1625. <td id="LC175" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> BBR takes [the calculated BDP]*2 as congestion-window</span></td>
  1626. </tr>
  1627. <tr>
  1628. <td id="L176" class="blob-num js-line-number" data-line-number="176"></td>
  1629. <td id="LC176" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> when is in BBR_PROBE_BW mode, calculating pacing-rate-which-used-by-cwnd is not based on &quot;bbr_pacing_gain&quot; number-group, but unvariable [BBR_UNIT * 2]</span></td>
  1630. </tr>
  1631. <tr>
  1632. <td id="L177" class="blob-num js-line-number" data-line-number="177"></td>
  1633. <td id="LC177" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> <span class="pl-k">int</span> bbr_cwnd_gain = BBR_UNIT * <span class="pl-c1">2</span>;</td>
  1634. </tr>
  1635. <tr>
  1636. <td id="L178" class="blob-num js-line-number" data-line-number="178"></td>
  1637. <td id="LC178" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> The pacing_gain values for the PROBE_BW gain cycle, to discover/share bw: <span class="pl-c">*/</span></span></td>
  1638. </tr>
  1639. <tr>
  1640. <td id="L179" class="blob-num js-line-number" data-line-number="179"></td>
  1641. <td id="LC179" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> <span class="pl-k">int</span> bbr_pacing_gain[] = {</td>
  1642. </tr>
  1643. <tr>
  1644. <td id="L180" class="blob-num js-line-number" data-line-number="180"></td>
  1645. <td id="LC180" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> for the stable bbr mode &quot;BBR_PROBE_BW&quot; which makes the fastest speed mode.</span></td>
  1646. </tr>
  1647. <tr>
  1648. <td id="L181" class="blob-num js-line-number" data-line-number="181"></td>
  1649. <td id="LC181" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> there are 8 pacing rate</span></td>
  1650. </tr>
  1651. <tr>
  1652. <td id="L182" class="blob-num js-line-number" data-line-number="182"></td>
  1653. <td id="LC182" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> pacing for discover bandwidth released by other tcp status.</span></td>
  1654. </tr>
  1655. <tr>
  1656. <td id="L183" class="blob-num js-line-number" data-line-number="183"></td>
  1657. <td id="LC183" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> increase it to discover more available bw.</span></td>
  1658. </tr>
  1659. <tr>
  1660. <td id="L184" class="blob-num js-line-number" data-line-number="184"></td>
  1661. <td id="LC184" class="blob-code blob-code-inner js-file-line"> BBR_UNIT * <span class="pl-c1">6</span> / <span class="pl-c1">4</span>, <span class="pl-c"><span class="pl-c">/*</span> probe for more available bw <span class="pl-c">*/</span></span></td>
  1662. </tr>
  1663. <tr>
  1664. <td id="L185" class="blob-num js-line-number" data-line-number="185"></td>
  1665. <td id="LC185" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> need a drain when the queue is coming even heavy traffic conn.</span></td>
  1666. </tr>
  1667. <tr>
  1668. <td id="L186" class="blob-num js-line-number" data-line-number="186"></td>
  1669. <td id="LC186" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> the speeder set as 5/3, but the drainer set as 2/3(set it drain less). (all rate value is compare to 1)</span></td>
  1670. </tr>
  1671. <tr>
  1672. <td id="L187" class="blob-num js-line-number" data-line-number="187"></td>
  1673. <td id="LC187" class="blob-code blob-code-inner js-file-line"> BBR_UNIT * <span class="pl-c1">3</span> / <span class="pl-c1">4</span>, <span class="pl-c"><span class="pl-c">/*</span> drain queue and/or yield bw to other flows <span class="pl-c">*/</span></span></td>
  1674. </tr>
  1675. <tr>
  1676. <td id="L188" class="blob-num js-line-number" data-line-number="188"></td>
  1677. <td id="LC188" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> the following 6 pacing rate value, are used to decide that:</span></td>
  1678. </tr>
  1679. <tr>
  1680. <td id="L189" class="blob-num js-line-number" data-line-number="189"></td>
  1681. <td id="LC189" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> those 6 phenemonons are all take [the max bw and the min rtt discovered in 10 bbr period] as rate and cwnd.</span></td>
  1682. </tr>
  1683. <tr>
  1684. <td id="L190" class="blob-num js-line-number" data-line-number="190"></td>
  1685. <td id="LC190" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> increase it to calculate bigger target value.</span></td>
  1686. </tr>
  1687. <tr>
  1688. <td id="L191" class="blob-num js-line-number" data-line-number="191"></td>
  1689. <td id="LC191" class="blob-code blob-code-inner js-file-line"> BBR_UNIT * <span class="pl-c1">5</span> / <span class="pl-c1">4</span>, BBR_UNIT * <span class="pl-c1">5</span> / <span class="pl-c1">4</span>, BBR_UNIT * <span class="pl-c1">5</span> / <span class="pl-c1">4</span>, <span class="pl-c"><span class="pl-c">/*</span> cruise at 1.0*bw to utilize pipe, <span class="pl-c">*/</span></span></td>
  1690. </tr>
  1691. <tr>
  1692. <td id="L192" class="blob-num js-line-number" data-line-number="192"></td>
  1693. <td id="LC192" class="blob-code blob-code-inner js-file-line"> BBR_UNIT * <span class="pl-c1">6</span> / <span class="pl-c1">4</span>, BBR_UNIT * <span class="pl-c1">6</span> / <span class="pl-c1">4</span>, BBR_UNIT * <span class="pl-c1">6</span> / <span class="pl-c1">4</span> <span class="pl-c"><span class="pl-c">/*</span> without creating excess queue... <span class="pl-c">*/</span></span></td>
  1694. </tr>
  1695. <tr>
  1696. <td id="L193" class="blob-num js-line-number" data-line-number="193"></td>
  1697. <td id="LC193" class="blob-code blob-code-inner js-file-line">};</td>
  1698. </tr>
  1699. <tr>
  1700. <td id="L194" class="blob-num js-line-number" data-line-number="194"></td>
  1701. <td id="LC194" class="blob-code blob-code-inner js-file-line">
  1702. </td>
  1703. </tr>
  1704. <tr>
  1705. <td id="L195" class="blob-num js-line-number" data-line-number="195"></td>
  1706. <td id="LC195" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Randomize the starting gain cycling phase over N phases: <span class="pl-c">*/</span></span></td>
  1707. </tr>
  1708. <tr>
  1709. <td id="L196" class="blob-num js-line-number" data-line-number="196"></td>
  1710. <td id="LC196" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_cycle_rand = <span class="pl-c1">7</span>;</td>
  1711. </tr>
  1712. <tr>
  1713. <td id="L197" class="blob-num js-line-number" data-line-number="197"></td>
  1714. <td id="LC197" class="blob-code blob-code-inner js-file-line">
  1715. </td>
  1716. </tr>
  1717. <tr>
  1718. <td id="L198" class="blob-num js-line-number" data-line-number="198"></td>
  1719. <td id="LC198" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Try to keep at least this many packets in flight, if things go smoothly. For</span></td>
  1720. </tr>
  1721. <tr>
  1722. <td id="L199" class="blob-num js-line-number" data-line-number="199"></td>
  1723. <td id="LC199" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * smooth functioning, a sliding window protocol ACKing every other packet</span></td>
  1724. </tr>
  1725. <tr>
  1726. <td id="L200" class="blob-num js-line-number" data-line-number="200"></td>
  1727. <td id="LC200" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * needs at least 4 packets in flight:</span></td>
  1728. </tr>
  1729. <tr>
  1730. <td id="L201" class="blob-num js-line-number" data-line-number="201"></td>
  1731. <td id="LC201" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  1732. </tr>
  1733. <tr>
  1734. <td id="L202" class="blob-num js-line-number" data-line-number="202"></td>
  1735. <td id="LC202" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> minimumly keeps 4 package when discover minimum rtt</span></td>
  1736. </tr>
  1737. <tr>
  1738. <td id="L203" class="blob-num js-line-number" data-line-number="203"></td>
  1739. <td id="LC203" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> use 1 package to discover minimum rtt is less effective.</span></td>
  1740. </tr>
  1741. <tr>
  1742. <td id="L204" class="blob-num js-line-number" data-line-number="204"></td>
  1743. <td id="LC204" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> use 5 package to discover minimum rtt is more effective, but may makes a heavy package queue.</span></td>
  1744. </tr>
  1745. <tr>
  1746. <td id="L205" class="blob-num js-line-number" data-line-number="205"></td>
  1747. <td id="LC205" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> use 4 package to discover minimum rtt is just good.</span></td>
  1748. </tr>
  1749. <tr>
  1750. <td id="L206" class="blob-num js-line-number" data-line-number="206"></td>
  1751. <td id="LC206" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_cwnd_min_target = <span class="pl-c1">4</span>;</td>
  1752. </tr>
  1753. <tr>
  1754. <td id="L207" class="blob-num js-line-number" data-line-number="207"></td>
  1755. <td id="LC207" class="blob-code blob-code-inner js-file-line">
  1756. </td>
  1757. </tr>
  1758. <tr>
  1759. <td id="L208" class="blob-num js-line-number" data-line-number="208"></td>
  1760. <td id="LC208" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> To estimate if BBR_STARTUP mode (i.e. high_gain) has filled pipe... <span class="pl-c">*/</span></span></td>
  1761. </tr>
  1762. <tr>
  1763. <td id="L209" class="blob-num js-line-number" data-line-number="209"></td>
  1764. <td id="LC209" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> If bw has increased significantly (1.25x), there may be more bw available: <span class="pl-c">*/</span></span></td>
  1765. </tr>
  1766. <tr>
  1767. <td id="L210" class="blob-num js-line-number" data-line-number="210"></td>
  1768. <td id="LC210" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_full_bw_thresh = BBR_UNIT * <span class="pl-c1">5</span> / <span class="pl-c1">4</span>;</td>
  1769. </tr>
  1770. <tr>
  1771. <td id="L211" class="blob-num js-line-number" data-line-number="211"></td>
  1772. <td id="LC211" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> But after 3 rounds w/o significant bw growth, estimate pipe is full: <span class="pl-c">*/</span></span></td>
  1773. </tr>
  1774. <tr>
  1775. <td id="L212" class="blob-num js-line-number" data-line-number="212"></td>
  1776. <td id="LC212" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_full_bw_cnt = <span class="pl-c1">3</span>;</td>
  1777. </tr>
  1778. <tr>
  1779. <td id="L213" class="blob-num js-line-number" data-line-number="213"></td>
  1780. <td id="LC213" class="blob-code blob-code-inner js-file-line">
  1781. </td>
  1782. </tr>
  1783. <tr>
  1784. <td id="L214" class="blob-num js-line-number" data-line-number="214"></td>
  1785. <td id="LC214" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> &quot;long-term&quot; (&quot;LT&quot;) bandwidth estimator parameters... <span class="pl-c">*/</span></span></td>
  1786. </tr>
  1787. <tr>
  1788. <td id="L215" class="blob-num js-line-number" data-line-number="215"></td>
  1789. <td id="LC215" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> The minimum number of rounds in an LT bw sampling interval: <span class="pl-c">*/</span></span></td>
  1790. </tr>
  1791. <tr>
  1792. <td id="L216" class="blob-num js-line-number" data-line-number="216"></td>
  1793. <td id="LC216" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_lt_intvl_min_rtts = <span class="pl-c1">4</span>;</td>
  1794. </tr>
  1795. <tr>
  1796. <td id="L217" class="blob-num js-line-number" data-line-number="217"></td>
  1797. <td id="LC217" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> If lost/delivered ratio &gt; 20%, interval is &quot;lossy&quot; and we may be policed: <span class="pl-c">*/</span></span></td>
  1798. </tr>
  1799. <tr>
  1800. <td id="L218" class="blob-num js-line-number" data-line-number="218"></td>
  1801. <td id="LC218" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_lt_loss_thresh = <span class="pl-c1">50</span>;</td>
  1802. </tr>
  1803. <tr>
  1804. <td id="L219" class="blob-num js-line-number" data-line-number="219"></td>
  1805. <td id="LC219" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> If 2 intervals have a bw ratio &lt;= 1/8, their bw is &quot;consistent&quot;: <span class="pl-c">*/</span></span></td>
  1806. </tr>
  1807. <tr>
  1808. <td id="L220" class="blob-num js-line-number" data-line-number="220"></td>
  1809. <td id="LC220" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> i set its minimum limit as [1/4] ratio</span></td>
  1810. </tr>
  1811. <tr>
  1812. <td id="L221" class="blob-num js-line-number" data-line-number="221"></td>
  1813. <td id="LC221" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_lt_bw_ratio = BBR_UNIT / <span class="pl-c1">4</span>;</td>
  1814. </tr>
  1815. <tr>
  1816. <td id="L222" class="blob-num js-line-number" data-line-number="222"></td>
  1817. <td id="LC222" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> If 2 intervals have a bw diff &lt;= 4 Kbit/sec their bw is &quot;consistent&quot;: <span class="pl-c">*/</span></span></td>
  1818. </tr>
  1819. <tr>
  1820. <td id="L223" class="blob-num js-line-number" data-line-number="223"></td>
  1821. <td id="LC223" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">//</span> according to the above &quot;bbr_lt_bw_ratio = BBR_UNIT / 4&quot;, i set this as [4000/4]</span></td>
  1822. </tr>
  1823. <tr>
  1824. <td id="L224" class="blob-num js-line-number" data-line-number="224"></td>
  1825. <td id="LC224" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_lt_bw_diff = <span class="pl-c1">4000</span> / <span class="pl-c1">4</span>;</td>
  1826. </tr>
  1827. <tr>
  1828. <td id="L225" class="blob-num js-line-number" data-line-number="225"></td>
  1829. <td id="LC225" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> If we estimate we&#39;re policed, use lt_bw for this many round trips: <span class="pl-c">*/</span></span></td>
  1830. </tr>
  1831. <tr>
  1832. <td id="L226" class="blob-num js-line-number" data-line-number="226"></td>
  1833. <td id="LC226" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">const</span> u32 bbr_lt_bw_max_rtts = <span class="pl-c1">48</span>;</td>
  1834. </tr>
  1835. <tr>
  1836. <td id="L227" class="blob-num js-line-number" data-line-number="227"></td>
  1837. <td id="LC227" class="blob-code blob-code-inner js-file-line">
  1838. </td>
  1839. </tr>
  1840. <tr>
  1841. <td id="L228" class="blob-num js-line-number" data-line-number="228"></td>
  1842. <td id="LC228" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Do we estimate that STARTUP filled the pipe? <span class="pl-c">*/</span></span></td>
  1843. </tr>
  1844. <tr>
  1845. <td id="L229" class="blob-num js-line-number" data-line-number="229"></td>
  1846. <td id="LC229" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">bool</span> <span class="pl-en">bbr_full_bw_reached</span>(<span class="pl-k">const</span> <span class="pl-k">struct</span> sock *sk)</td>
  1847. </tr>
  1848. <tr>
  1849. <td id="L230" class="blob-num js-line-number" data-line-number="230"></td>
  1850. <td id="LC230" class="blob-code blob-code-inner js-file-line">{</td>
  1851. </tr>
  1852. <tr>
  1853. <td id="L231" class="blob-num js-line-number" data-line-number="231"></td>
  1854. <td id="LC231" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">const</span> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  1855. </tr>
  1856. <tr>
  1857. <td id="L232" class="blob-num js-line-number" data-line-number="232"></td>
  1858. <td id="LC232" class="blob-code blob-code-inner js-file-line">
  1859. </td>
  1860. </tr>
  1861. <tr>
  1862. <td id="L233" class="blob-num js-line-number" data-line-number="233"></td>
  1863. <td id="LC233" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> bbr-&gt;full_bw_cnt &gt;= bbr_full_bw_cnt;</td>
  1864. </tr>
  1865. <tr>
  1866. <td id="L234" class="blob-num js-line-number" data-line-number="234"></td>
  1867. <td id="LC234" class="blob-code blob-code-inner js-file-line">}</td>
  1868. </tr>
  1869. <tr>
  1870. <td id="L235" class="blob-num js-line-number" data-line-number="235"></td>
  1871. <td id="LC235" class="blob-code blob-code-inner js-file-line">
  1872. </td>
  1873. </tr>
  1874. <tr>
  1875. <td id="L236" class="blob-num js-line-number" data-line-number="236"></td>
  1876. <td id="LC236" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Return the windowed max recent bandwidth sample, in pkts/uS &lt;&lt; BW_SCALE. <span class="pl-c">*/</span></span></td>
  1877. </tr>
  1878. <tr>
  1879. <td id="L237" class="blob-num js-line-number" data-line-number="237"></td>
  1880. <td id="LC237" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u32 <span class="pl-en">bbr_max_bw</span>(<span class="pl-k">const</span> <span class="pl-k">struct</span> sock *sk)</td>
  1881. </tr>
  1882. <tr>
  1883. <td id="L238" class="blob-num js-line-number" data-line-number="238"></td>
  1884. <td id="LC238" class="blob-code blob-code-inner js-file-line">{</td>
  1885. </tr>
  1886. <tr>
  1887. <td id="L239" class="blob-num js-line-number" data-line-number="239"></td>
  1888. <td id="LC239" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  1889. </tr>
  1890. <tr>
  1891. <td id="L240" class="blob-num js-line-number" data-line-number="240"></td>
  1892. <td id="LC240" class="blob-code blob-code-inner js-file-line">
  1893. </td>
  1894. </tr>
  1895. <tr>
  1896. <td id="L241" class="blob-num js-line-number" data-line-number="241"></td>
  1897. <td id="LC241" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-c1">minmax_get</span>(&amp;bbr-&gt;bw);</td>
  1898. </tr>
  1899. <tr>
  1900. <td id="L242" class="blob-num js-line-number" data-line-number="242"></td>
  1901. <td id="LC242" class="blob-code blob-code-inner js-file-line">}</td>
  1902. </tr>
  1903. <tr>
  1904. <td id="L243" class="blob-num js-line-number" data-line-number="243"></td>
  1905. <td id="LC243" class="blob-code blob-code-inner js-file-line">
  1906. </td>
  1907. </tr>
  1908. <tr>
  1909. <td id="L244" class="blob-num js-line-number" data-line-number="244"></td>
  1910. <td id="LC244" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Return the estimated bandwidth of the path, in pkts/uS &lt;&lt; BW_SCALE. <span class="pl-c">*/</span></span></td>
  1911. </tr>
  1912. <tr>
  1913. <td id="L245" class="blob-num js-line-number" data-line-number="245"></td>
  1914. <td id="LC245" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u32 <span class="pl-en">bbr_bw</span>(<span class="pl-k">const</span> <span class="pl-k">struct</span> sock *sk)</td>
  1915. </tr>
  1916. <tr>
  1917. <td id="L246" class="blob-num js-line-number" data-line-number="246"></td>
  1918. <td id="LC246" class="blob-code blob-code-inner js-file-line">{</td>
  1919. </tr>
  1920. <tr>
  1921. <td id="L247" class="blob-num js-line-number" data-line-number="247"></td>
  1922. <td id="LC247" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  1923. </tr>
  1924. <tr>
  1925. <td id="L248" class="blob-num js-line-number" data-line-number="248"></td>
  1926. <td id="LC248" class="blob-code blob-code-inner js-file-line">
  1927. </td>
  1928. </tr>
  1929. <tr>
  1930. <td id="L249" class="blob-num js-line-number" data-line-number="249"></td>
  1931. <td id="LC249" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> bbr-&gt;lt_use_bw ? bbr-&gt;lt_bw : <span class="pl-c1">bbr_max_bw</span>(sk);</td>
  1932. </tr>
  1933. <tr>
  1934. <td id="L250" class="blob-num js-line-number" data-line-number="250"></td>
  1935. <td id="LC250" class="blob-code blob-code-inner js-file-line">}</td>
  1936. </tr>
  1937. <tr>
  1938. <td id="L251" class="blob-num js-line-number" data-line-number="251"></td>
  1939. <td id="LC251" class="blob-code blob-code-inner js-file-line">
  1940. </td>
  1941. </tr>
  1942. <tr>
  1943. <td id="L252" class="blob-num js-line-number" data-line-number="252"></td>
  1944. <td id="LC252" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Return rate in bytes per second, optionally with a gain.</span></td>
  1945. </tr>
  1946. <tr>
  1947. <td id="L253" class="blob-num js-line-number" data-line-number="253"></td>
  1948. <td id="LC253" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * The order here is chosen carefully to avoid overflow of u64. This should</span></td>
  1949. </tr>
  1950. <tr>
  1951. <td id="L254" class="blob-num js-line-number" data-line-number="254"></td>
  1952. <td id="LC254" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * work for input rates of up to 2.9Tbit/sec and gain of 2.89x.</span></td>
  1953. </tr>
  1954. <tr>
  1955. <td id="L255" class="blob-num js-line-number" data-line-number="255"></td>
  1956. <td id="LC255" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  1957. </tr>
  1958. <tr>
  1959. <td id="L256" class="blob-num js-line-number" data-line-number="256"></td>
  1960. <td id="LC256" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u64 <span class="pl-en">bbr_rate_bytes_per_sec</span>(<span class="pl-k">struct</span> sock *sk, u64 rate, <span class="pl-k">int</span> gain)</td>
  1961. </tr>
  1962. <tr>
  1963. <td id="L257" class="blob-num js-line-number" data-line-number="257"></td>
  1964. <td id="LC257" class="blob-code blob-code-inner js-file-line">{</td>
  1965. </tr>
  1966. <tr>
  1967. <td id="L258" class="blob-num js-line-number" data-line-number="258"></td>
  1968. <td id="LC258" class="blob-code blob-code-inner js-file-line"> rate *= <span class="pl-c1">tcp_mss_to_mtu</span>(sk, <span class="pl-c1">tcp_sk</span>(sk)-&gt;mss_cache);</td>
  1969. </tr>
  1970. <tr>
  1971. <td id="L259" class="blob-num js-line-number" data-line-number="259"></td>
  1972. <td id="LC259" class="blob-code blob-code-inner js-file-line"> rate *= gain;</td>
  1973. </tr>
  1974. <tr>
  1975. <td id="L260" class="blob-num js-line-number" data-line-number="260"></td>
  1976. <td id="LC260" class="blob-code blob-code-inner js-file-line"> rate &gt;&gt;= BBR_SCALE;</td>
  1977. </tr>
  1978. <tr>
  1979. <td id="L261" class="blob-num js-line-number" data-line-number="261"></td>
  1980. <td id="LC261" class="blob-code blob-code-inner js-file-line"> rate *= USEC_PER_SEC;</td>
  1981. </tr>
  1982. <tr>
  1983. <td id="L262" class="blob-num js-line-number" data-line-number="262"></td>
  1984. <td id="LC262" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> rate &gt;&gt; BW_SCALE;</td>
  1985. </tr>
  1986. <tr>
  1987. <td id="L263" class="blob-num js-line-number" data-line-number="263"></td>
  1988. <td id="LC263" class="blob-code blob-code-inner js-file-line">}</td>
  1989. </tr>
  1990. <tr>
  1991. <td id="L264" class="blob-num js-line-number" data-line-number="264"></td>
  1992. <td id="LC264" class="blob-code blob-code-inner js-file-line">
  1993. </td>
  1994. </tr>
  1995. <tr>
  1996. <td id="L265" class="blob-num js-line-number" data-line-number="265"></td>
  1997. <td id="LC265" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Pace using current bw estimate and a gain factor. In order to help drive the</span></td>
  1998. </tr>
  1999. <tr>
  2000. <td id="L266" class="blob-num js-line-number" data-line-number="266"></td>
  2001. <td id="LC266" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * network toward lower queues while maintaining high utilization and low</span></td>
  2002. </tr>
  2003. <tr>
  2004. <td id="L267" class="blob-num js-line-number" data-line-number="267"></td>
  2005. <td id="LC267" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * latency, the average pacing rate aims to be slightly (~1%) lower than the</span></td>
  2006. </tr>
  2007. <tr>
  2008. <td id="L268" class="blob-num js-line-number" data-line-number="268"></td>
  2009. <td id="LC268" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * estimated bandwidth. This is an important aspect of the design. In this</span></td>
  2010. </tr>
  2011. <tr>
  2012. <td id="L269" class="blob-num js-line-number" data-line-number="269"></td>
  2013. <td id="LC269" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * implementation this slightly lower pacing rate is achieved implicitly by not</span></td>
  2014. </tr>
  2015. <tr>
  2016. <td id="L270" class="blob-num js-line-number" data-line-number="270"></td>
  2017. <td id="LC270" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * including link-layer headers in the packet size used for the pacing rate.</span></td>
  2018. </tr>
  2019. <tr>
  2020. <td id="L271" class="blob-num js-line-number" data-line-number="271"></td>
  2021. <td id="LC271" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2022. </tr>
  2023. <tr>
  2024. <td id="L272" class="blob-num js-line-number" data-line-number="272"></td>
  2025. <td id="LC272" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_set_pacing_rate</span>(<span class="pl-k">struct</span> sock *sk, u32 bw, <span class="pl-k">int</span> gain)</td>
  2026. </tr>
  2027. <tr>
  2028. <td id="L273" class="blob-num js-line-number" data-line-number="273"></td>
  2029. <td id="LC273" class="blob-code blob-code-inner js-file-line">{</td>
  2030. </tr>
  2031. <tr>
  2032. <td id="L274" class="blob-num js-line-number" data-line-number="274"></td>
  2033. <td id="LC274" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2034. </tr>
  2035. <tr>
  2036. <td id="L275" class="blob-num js-line-number" data-line-number="275"></td>
  2037. <td id="LC275" class="blob-code blob-code-inner js-file-line"> u64 rate = bw;</td>
  2038. </tr>
  2039. <tr>
  2040. <td id="L276" class="blob-num js-line-number" data-line-number="276"></td>
  2041. <td id="LC276" class="blob-code blob-code-inner js-file-line">
  2042. </td>
  2043. </tr>
  2044. <tr>
  2045. <td id="L277" class="blob-num js-line-number" data-line-number="277"></td>
  2046. <td id="LC277" class="blob-code blob-code-inner js-file-line"> rate = <span class="pl-c1">bbr_rate_bytes_per_sec</span>(sk, rate, gain);</td>
  2047. </tr>
  2048. <tr>
  2049. <td id="L278" class="blob-num js-line-number" data-line-number="278"></td>
  2050. <td id="LC278" class="blob-code blob-code-inner js-file-line"> rate = <span class="pl-c1">min_t</span>(u64, rate, sk-&gt;sk_max_pacing_rate);</td>
  2051. </tr>
  2052. <tr>
  2053. <td id="L279" class="blob-num js-line-number" data-line-number="279"></td>
  2054. <td id="LC279" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;mode != BBR_STARTUP || rate &gt; sk-&gt;sk_pacing_rate)</td>
  2055. </tr>
  2056. <tr>
  2057. <td id="L280" class="blob-num js-line-number" data-line-number="280"></td>
  2058. <td id="LC280" class="blob-code blob-code-inner js-file-line"> sk-&gt;sk_pacing_rate = rate;</td>
  2059. </tr>
  2060. <tr>
  2061. <td id="L281" class="blob-num js-line-number" data-line-number="281"></td>
  2062. <td id="LC281" class="blob-code blob-code-inner js-file-line">}</td>
  2063. </tr>
  2064. <tr>
  2065. <td id="L282" class="blob-num js-line-number" data-line-number="282"></td>
  2066. <td id="LC282" class="blob-code blob-code-inner js-file-line">
  2067. </td>
  2068. </tr>
  2069. <tr>
  2070. <td id="L283" class="blob-num js-line-number" data-line-number="283"></td>
  2071. <td id="LC283" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Return count of segments we want in the skbs we send, or 0 for default. <span class="pl-c">*/</span></span></td>
  2072. </tr>
  2073. <tr>
  2074. <td id="L284" class="blob-num js-line-number" data-line-number="284"></td>
  2075. <td id="LC284" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u32 <span class="pl-en">bbr_tso_segs_goal</span>(<span class="pl-k">struct</span> sock *sk)</td>
  2076. </tr>
  2077. <tr>
  2078. <td id="L285" class="blob-num js-line-number" data-line-number="285"></td>
  2079. <td id="LC285" class="blob-code blob-code-inner js-file-line">{</td>
  2080. </tr>
  2081. <tr>
  2082. <td id="L286" class="blob-num js-line-number" data-line-number="286"></td>
  2083. <td id="LC286" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2084. </tr>
  2085. <tr>
  2086. <td id="L287" class="blob-num js-line-number" data-line-number="287"></td>
  2087. <td id="LC287" class="blob-code blob-code-inner js-file-line">
  2088. </td>
  2089. </tr>
  2090. <tr>
  2091. <td id="L288" class="blob-num js-line-number" data-line-number="288"></td>
  2092. <td id="LC288" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> bbr-&gt;tso_segs_goal;</td>
  2093. </tr>
  2094. <tr>
  2095. <td id="L289" class="blob-num js-line-number" data-line-number="289"></td>
  2096. <td id="LC289" class="blob-code blob-code-inner js-file-line">}</td>
  2097. </tr>
  2098. <tr>
  2099. <td id="L290" class="blob-num js-line-number" data-line-number="290"></td>
  2100. <td id="LC290" class="blob-code blob-code-inner js-file-line">
  2101. </td>
  2102. </tr>
  2103. <tr>
  2104. <td id="L291" class="blob-num js-line-number" data-line-number="291"></td>
  2105. <td id="LC291" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_set_tso_segs_goal</span>(<span class="pl-k">struct</span> sock *sk)</td>
  2106. </tr>
  2107. <tr>
  2108. <td id="L292" class="blob-num js-line-number" data-line-number="292"></td>
  2109. <td id="LC292" class="blob-code blob-code-inner js-file-line">{</td>
  2110. </tr>
  2111. <tr>
  2112. <td id="L293" class="blob-num js-line-number" data-line-number="293"></td>
  2113. <td id="LC293" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  2114. </tr>
  2115. <tr>
  2116. <td id="L294" class="blob-num js-line-number" data-line-number="294"></td>
  2117. <td id="LC294" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2118. </tr>
  2119. <tr>
  2120. <td id="L295" class="blob-num js-line-number" data-line-number="295"></td>
  2121. <td id="LC295" class="blob-code blob-code-inner js-file-line"> u32 min_segs;</td>
  2122. </tr>
  2123. <tr>
  2124. <td id="L296" class="blob-num js-line-number" data-line-number="296"></td>
  2125. <td id="LC296" class="blob-code blob-code-inner js-file-line">
  2126. </td>
  2127. </tr>
  2128. <tr>
  2129. <td id="L297" class="blob-num js-line-number" data-line-number="297"></td>
  2130. <td id="LC297" class="blob-code blob-code-inner js-file-line"> min_segs = sk-&gt;sk_pacing_rate &lt; (bbr_min_tso_rate &gt;&gt; <span class="pl-c1">3</span>) ? <span class="pl-c1">1</span> : <span class="pl-c1">2</span>;</td>
  2131. </tr>
  2132. <tr>
  2133. <td id="L298" class="blob-num js-line-number" data-line-number="298"></td>
  2134. <td id="LC298" class="blob-code blob-code-inner js-file-line"> bbr-&gt;tso_segs_goal = <span class="pl-c1">min</span>(<span class="pl-c1">tcp_tso_autosize</span>(sk, tp-&gt;mss_cache, min_segs),</td>
  2135. </tr>
  2136. <tr>
  2137. <td id="L299" class="blob-num js-line-number" data-line-number="299"></td>
  2138. <td id="LC299" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">0x7FU</span>);</td>
  2139. </tr>
  2140. <tr>
  2141. <td id="L300" class="blob-num js-line-number" data-line-number="300"></td>
  2142. <td id="LC300" class="blob-code blob-code-inner js-file-line">}</td>
  2143. </tr>
  2144. <tr>
  2145. <td id="L301" class="blob-num js-line-number" data-line-number="301"></td>
  2146. <td id="LC301" class="blob-code blob-code-inner js-file-line">
  2147. </td>
  2148. </tr>
  2149. <tr>
  2150. <td id="L302" class="blob-num js-line-number" data-line-number="302"></td>
  2151. <td id="LC302" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Save &quot;last known good&quot; cwnd so we can restore it after losses or PROBE_RTT <span class="pl-c">*/</span></span></td>
  2152. </tr>
  2153. <tr>
  2154. <td id="L303" class="blob-num js-line-number" data-line-number="303"></td>
  2155. <td id="LC303" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_save_cwnd</span>(<span class="pl-k">struct</span> sock *sk)</td>
  2156. </tr>
  2157. <tr>
  2158. <td id="L304" class="blob-num js-line-number" data-line-number="304"></td>
  2159. <td id="LC304" class="blob-code blob-code-inner js-file-line">{</td>
  2160. </tr>
  2161. <tr>
  2162. <td id="L305" class="blob-num js-line-number" data-line-number="305"></td>
  2163. <td id="LC305" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  2164. </tr>
  2165. <tr>
  2166. <td id="L306" class="blob-num js-line-number" data-line-number="306"></td>
  2167. <td id="LC306" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2168. </tr>
  2169. <tr>
  2170. <td id="L307" class="blob-num js-line-number" data-line-number="307"></td>
  2171. <td id="LC307" class="blob-code blob-code-inner js-file-line">
  2172. </td>
  2173. </tr>
  2174. <tr>
  2175. <td id="L308" class="blob-num js-line-number" data-line-number="308"></td>
  2176. <td id="LC308" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;prev_ca_state &lt; TCP_CA_Recovery &amp;&amp; bbr-&gt;mode != BBR_PROBE_RTT)</td>
  2177. </tr>
  2178. <tr>
  2179. <td id="L309" class="blob-num js-line-number" data-line-number="309"></td>
  2180. <td id="LC309" class="blob-code blob-code-inner js-file-line"> bbr-&gt;prior_cwnd = tp-&gt;snd_cwnd; <span class="pl-c"><span class="pl-c">/*</span> this cwnd is good enough <span class="pl-c">*/</span></span></td>
  2181. </tr>
  2182. <tr>
  2183. <td id="L310" class="blob-num js-line-number" data-line-number="310"></td>
  2184. <td id="LC310" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">else</span> <span class="pl-c"><span class="pl-c">/*</span> loss recovery or BBR_PROBE_RTT have temporarily cut cwnd <span class="pl-c">*/</span></span></td>
  2185. </tr>
  2186. <tr>
  2187. <td id="L311" class="blob-num js-line-number" data-line-number="311"></td>
  2188. <td id="LC311" class="blob-code blob-code-inner js-file-line"> bbr-&gt;prior_cwnd = <span class="pl-c1">max</span>(bbr-&gt;prior_cwnd, tp-&gt;snd_cwnd);</td>
  2189. </tr>
  2190. <tr>
  2191. <td id="L312" class="blob-num js-line-number" data-line-number="312"></td>
  2192. <td id="LC312" class="blob-code blob-code-inner js-file-line">}</td>
  2193. </tr>
  2194. <tr>
  2195. <td id="L313" class="blob-num js-line-number" data-line-number="313"></td>
  2196. <td id="LC313" class="blob-code blob-code-inner js-file-line">
  2197. </td>
  2198. </tr>
  2199. <tr>
  2200. <td id="L314" class="blob-num js-line-number" data-line-number="314"></td>
  2201. <td id="LC314" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_cwnd_event</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">enum</span> tcp_ca_event event)</td>
  2202. </tr>
  2203. <tr>
  2204. <td id="L315" class="blob-num js-line-number" data-line-number="315"></td>
  2205. <td id="LC315" class="blob-code blob-code-inner js-file-line">{</td>
  2206. </tr>
  2207. <tr>
  2208. <td id="L316" class="blob-num js-line-number" data-line-number="316"></td>
  2209. <td id="LC316" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  2210. </tr>
  2211. <tr>
  2212. <td id="L317" class="blob-num js-line-number" data-line-number="317"></td>
  2213. <td id="LC317" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2214. </tr>
  2215. <tr>
  2216. <td id="L318" class="blob-num js-line-number" data-line-number="318"></td>
  2217. <td id="LC318" class="blob-code blob-code-inner js-file-line">
  2218. </td>
  2219. </tr>
  2220. <tr>
  2221. <td id="L319" class="blob-num js-line-number" data-line-number="319"></td>
  2222. <td id="LC319" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (event == CA_EVENT_TX_START &amp;&amp; tp-&gt;app_limited) {</td>
  2223. </tr>
  2224. <tr>
  2225. <td id="L320" class="blob-num js-line-number" data-line-number="320"></td>
  2226. <td id="LC320" class="blob-code blob-code-inner js-file-line"> bbr-&gt;idle_restart = <span class="pl-c1">1</span>;</td>
  2227. </tr>
  2228. <tr>
  2229. <td id="L321" class="blob-num js-line-number" data-line-number="321"></td>
  2230. <td id="LC321" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Avoid pointless buffer overflows: pace at est. bw if we don&#39;t</span></td>
  2231. </tr>
  2232. <tr>
  2233. <td id="L322" class="blob-num js-line-number" data-line-number="322"></td>
  2234. <td id="LC322" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * need more speed (we&#39;re restarting from idle and app-limited).</span></td>
  2235. </tr>
  2236. <tr>
  2237. <td id="L323" class="blob-num js-line-number" data-line-number="323"></td>
  2238. <td id="LC323" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2239. </tr>
  2240. <tr>
  2241. <td id="L324" class="blob-num js-line-number" data-line-number="324"></td>
  2242. <td id="LC324" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;mode == BBR_PROBE_BW)</td>
  2243. </tr>
  2244. <tr>
  2245. <td id="L325" class="blob-num js-line-number" data-line-number="325"></td>
  2246. <td id="LC325" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_set_pacing_rate</span>(sk, <span class="pl-c1">bbr_bw</span>(sk), BBR_UNIT);</td>
  2247. </tr>
  2248. <tr>
  2249. <td id="L326" class="blob-num js-line-number" data-line-number="326"></td>
  2250. <td id="LC326" class="blob-code blob-code-inner js-file-line"> }</td>
  2251. </tr>
  2252. <tr>
  2253. <td id="L327" class="blob-num js-line-number" data-line-number="327"></td>
  2254. <td id="LC327" class="blob-code blob-code-inner js-file-line">}</td>
  2255. </tr>
  2256. <tr>
  2257. <td id="L328" class="blob-num js-line-number" data-line-number="328"></td>
  2258. <td id="LC328" class="blob-code blob-code-inner js-file-line">
  2259. </td>
  2260. </tr>
  2261. <tr>
  2262. <td id="L329" class="blob-num js-line-number" data-line-number="329"></td>
  2263. <td id="LC329" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Find target cwnd. Right-size the cwnd based on min RTT and the</span></td>
  2264. </tr>
  2265. <tr>
  2266. <td id="L330" class="blob-num js-line-number" data-line-number="330"></td>
  2267. <td id="LC330" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * estimated bottleneck bandwidth:</span></td>
  2268. </tr>
  2269. <tr>
  2270. <td id="L331" class="blob-num js-line-number" data-line-number="331"></td>
  2271. <td id="LC331" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  2272. </tr>
  2273. <tr>
  2274. <td id="L332" class="blob-num js-line-number" data-line-number="332"></td>
  2275. <td id="LC332" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * cwnd = bw * min_rtt * gain = BDP * gain</span></td>
  2276. </tr>
  2277. <tr>
  2278. <td id="L333" class="blob-num js-line-number" data-line-number="333"></td>
  2279. <td id="LC333" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  2280. </tr>
  2281. <tr>
  2282. <td id="L334" class="blob-num js-line-number" data-line-number="334"></td>
  2283. <td id="LC334" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * The key factor, gain, controls the amount of queue. While a small gain</span></td>
  2284. </tr>
  2285. <tr>
  2286. <td id="L335" class="blob-num js-line-number" data-line-number="335"></td>
  2287. <td id="LC335" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * builds a smaller queue, it becomes more vulnerable to noise in RTT</span></td>
  2288. </tr>
  2289. <tr>
  2290. <td id="L336" class="blob-num js-line-number" data-line-number="336"></td>
  2291. <td id="LC336" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * measurements (e.g., delayed ACKs or other ACK compression effects). This</span></td>
  2292. </tr>
  2293. <tr>
  2294. <td id="L337" class="blob-num js-line-number" data-line-number="337"></td>
  2295. <td id="LC337" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * noise may cause BBR to under-estimate the rate.</span></td>
  2296. </tr>
  2297. <tr>
  2298. <td id="L338" class="blob-num js-line-number" data-line-number="338"></td>
  2299. <td id="LC338" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  2300. </tr>
  2301. <tr>
  2302. <td id="L339" class="blob-num js-line-number" data-line-number="339"></td>
  2303. <td id="LC339" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * To achieve full performance in high-speed paths, we budget enough cwnd to</span></td>
  2304. </tr>
  2305. <tr>
  2306. <td id="L340" class="blob-num js-line-number" data-line-number="340"></td>
  2307. <td id="LC340" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * fit full-sized skbs in-flight on both end hosts to fully utilize the path:</span></td>
  2308. </tr>
  2309. <tr>
  2310. <td id="L341" class="blob-num js-line-number" data-line-number="341"></td>
  2311. <td id="LC341" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * - one skb in sending host Qdisc,</span></td>
  2312. </tr>
  2313. <tr>
  2314. <td id="L342" class="blob-num js-line-number" data-line-number="342"></td>
  2315. <td id="LC342" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * - one skb in sending host TSO/GSO engine</span></td>
  2316. </tr>
  2317. <tr>
  2318. <td id="L343" class="blob-num js-line-number" data-line-number="343"></td>
  2319. <td id="LC343" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * - one skb being received by receiver host LRO/GRO/delayed-ACK engine</span></td>
  2320. </tr>
  2321. <tr>
  2322. <td id="L344" class="blob-num js-line-number" data-line-number="344"></td>
  2323. <td id="LC344" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Don&#39;t worry, at low rates (bbr_min_tso_rate) this won&#39;t bloat cwnd because</span></td>
  2324. </tr>
  2325. <tr>
  2326. <td id="L345" class="blob-num js-line-number" data-line-number="345"></td>
  2327. <td id="LC345" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * in such cases tso_segs_goal is 1. The minimum cwnd is 4 packets,</span></td>
  2328. </tr>
  2329. <tr>
  2330. <td id="L346" class="blob-num js-line-number" data-line-number="346"></td>
  2331. <td id="LC346" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * which allows 2 outstanding 2-packet sequences, to try to keep pipe</span></td>
  2332. </tr>
  2333. <tr>
  2334. <td id="L347" class="blob-num js-line-number" data-line-number="347"></td>
  2335. <td id="LC347" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * full even with ACK-every-other-packet delayed ACKs.</span></td>
  2336. </tr>
  2337. <tr>
  2338. <td id="L348" class="blob-num js-line-number" data-line-number="348"></td>
  2339. <td id="LC348" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2340. </tr>
  2341. <tr>
  2342. <td id="L349" class="blob-num js-line-number" data-line-number="349"></td>
  2343. <td id="LC349" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u32 <span class="pl-en">bbr_target_cwnd</span>(<span class="pl-k">struct</span> sock *sk, u32 bw, <span class="pl-k">int</span> gain)</td>
  2344. </tr>
  2345. <tr>
  2346. <td id="L350" class="blob-num js-line-number" data-line-number="350"></td>
  2347. <td id="LC350" class="blob-code blob-code-inner js-file-line">{</td>
  2348. </tr>
  2349. <tr>
  2350. <td id="L351" class="blob-num js-line-number" data-line-number="351"></td>
  2351. <td id="LC351" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2352. </tr>
  2353. <tr>
  2354. <td id="L352" class="blob-num js-line-number" data-line-number="352"></td>
  2355. <td id="LC352" class="blob-code blob-code-inner js-file-line"> u32 cwnd;</td>
  2356. </tr>
  2357. <tr>
  2358. <td id="L353" class="blob-num js-line-number" data-line-number="353"></td>
  2359. <td id="LC353" class="blob-code blob-code-inner js-file-line"> u64 w;</td>
  2360. </tr>
  2361. <tr>
  2362. <td id="L354" class="blob-num js-line-number" data-line-number="354"></td>
  2363. <td id="LC354" class="blob-code blob-code-inner js-file-line">
  2364. </td>
  2365. </tr>
  2366. <tr>
  2367. <td id="L355" class="blob-num js-line-number" data-line-number="355"></td>
  2368. <td id="LC355" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> If we&#39;ve never had a valid RTT sample, cap cwnd at the initial</span></td>
  2369. </tr>
  2370. <tr>
  2371. <td id="L356" class="blob-num js-line-number" data-line-number="356"></td>
  2372. <td id="LC356" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * default. This should only happen when the connection is not using TCP</span></td>
  2373. </tr>
  2374. <tr>
  2375. <td id="L357" class="blob-num js-line-number" data-line-number="357"></td>
  2376. <td id="LC357" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * timestamps and has retransmitted all of the SYN/SYNACK/data packets</span></td>
  2377. </tr>
  2378. <tr>
  2379. <td id="L358" class="blob-num js-line-number" data-line-number="358"></td>
  2380. <td id="LC358" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * ACKed so far. In this case, an RTO can cut cwnd to 1, in which</span></td>
  2381. </tr>
  2382. <tr>
  2383. <td id="L359" class="blob-num js-line-number" data-line-number="359"></td>
  2384. <td id="LC359" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * case we need to slow-start up toward something safe: TCP_INIT_CWND.</span></td>
  2385. </tr>
  2386. <tr>
  2387. <td id="L360" class="blob-num js-line-number" data-line-number="360"></td>
  2388. <td id="LC360" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2389. </tr>
  2390. <tr>
  2391. <td id="L361" class="blob-num js-line-number" data-line-number="361"></td>
  2392. <td id="LC361" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (<span class="pl-c1">unlikely</span>(bbr-&gt;min_rtt_us == ~<span class="pl-c1">0U</span>)) <span class="pl-c"><span class="pl-c">/*</span> no valid RTT samples yet? <span class="pl-c">*/</span></span></td>
  2393. </tr>
  2394. <tr>
  2395. <td id="L362" class="blob-num js-line-number" data-line-number="362"></td>
  2396. <td id="LC362" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> TCP_INIT_CWND; <span class="pl-c"><span class="pl-c">/*</span> be safe: cap at default initial cwnd<span class="pl-c">*/</span></span></td>
  2397. </tr>
  2398. <tr>
  2399. <td id="L363" class="blob-num js-line-number" data-line-number="363"></td>
  2400. <td id="LC363" class="blob-code blob-code-inner js-file-line">
  2401. </td>
  2402. </tr>
  2403. <tr>
  2404. <td id="L364" class="blob-num js-line-number" data-line-number="364"></td>
  2405. <td id="LC364" class="blob-code blob-code-inner js-file-line"> w = (u64)bw * bbr-&gt;min_rtt_us;</td>
  2406. </tr>
  2407. <tr>
  2408. <td id="L365" class="blob-num js-line-number" data-line-number="365"></td>
  2409. <td id="LC365" class="blob-code blob-code-inner js-file-line">
  2410. </td>
  2411. </tr>
  2412. <tr>
  2413. <td id="L366" class="blob-num js-line-number" data-line-number="366"></td>
  2414. <td id="LC366" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Apply a gain to the given value, then remove the BW_SCALE shift. <span class="pl-c">*/</span></span></td>
  2415. </tr>
  2416. <tr>
  2417. <td id="L367" class="blob-num js-line-number" data-line-number="367"></td>
  2418. <td id="LC367" class="blob-code blob-code-inner js-file-line"> cwnd = (((w * gain) &gt;&gt; BBR_SCALE) + BW_UNIT - <span class="pl-c1">1</span>) / BW_UNIT;</td>
  2419. </tr>
  2420. <tr>
  2421. <td id="L368" class="blob-num js-line-number" data-line-number="368"></td>
  2422. <td id="LC368" class="blob-code blob-code-inner js-file-line">
  2423. </td>
  2424. </tr>
  2425. <tr>
  2426. <td id="L369" class="blob-num js-line-number" data-line-number="369"></td>
  2427. <td id="LC369" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Allow enough full-sized skbs in flight to utilize end systems. <span class="pl-c">*/</span></span></td>
  2428. </tr>
  2429. <tr>
  2430. <td id="L370" class="blob-num js-line-number" data-line-number="370"></td>
  2431. <td id="LC370" class="blob-code blob-code-inner js-file-line"> cwnd += <span class="pl-c1">3</span> * bbr-&gt;tso_segs_goal;</td>
  2432. </tr>
  2433. <tr>
  2434. <td id="L371" class="blob-num js-line-number" data-line-number="371"></td>
  2435. <td id="LC371" class="blob-code blob-code-inner js-file-line">
  2436. </td>
  2437. </tr>
  2438. <tr>
  2439. <td id="L372" class="blob-num js-line-number" data-line-number="372"></td>
  2440. <td id="LC372" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Reduce delayed ACKs by rounding up cwnd to the next even number. <span class="pl-c">*/</span></span></td>
  2441. </tr>
  2442. <tr>
  2443. <td id="L373" class="blob-num js-line-number" data-line-number="373"></td>
  2444. <td id="LC373" class="blob-code blob-code-inner js-file-line"> cwnd = (cwnd + <span class="pl-c1">1</span>) &amp; ~<span class="pl-c1">1U</span>;</td>
  2445. </tr>
  2446. <tr>
  2447. <td id="L374" class="blob-num js-line-number" data-line-number="374"></td>
  2448. <td id="LC374" class="blob-code blob-code-inner js-file-line">
  2449. </td>
  2450. </tr>
  2451. <tr>
  2452. <td id="L375" class="blob-num js-line-number" data-line-number="375"></td>
  2453. <td id="LC375" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> cwnd;</td>
  2454. </tr>
  2455. <tr>
  2456. <td id="L376" class="blob-num js-line-number" data-line-number="376"></td>
  2457. <td id="LC376" class="blob-code blob-code-inner js-file-line">}</td>
  2458. </tr>
  2459. <tr>
  2460. <td id="L377" class="blob-num js-line-number" data-line-number="377"></td>
  2461. <td id="LC377" class="blob-code blob-code-inner js-file-line">
  2462. </td>
  2463. </tr>
  2464. <tr>
  2465. <td id="L378" class="blob-num js-line-number" data-line-number="378"></td>
  2466. <td id="LC378" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> An optimization in BBR to reduce losses: On the first round of recovery, we</span></td>
  2467. </tr>
  2468. <tr>
  2469. <td id="L379" class="blob-num js-line-number" data-line-number="379"></td>
  2470. <td id="LC379" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * follow the packet conservation principle: send P packets per P packets acked.</span></td>
  2471. </tr>
  2472. <tr>
  2473. <td id="L380" class="blob-num js-line-number" data-line-number="380"></td>
  2474. <td id="LC380" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * After that, we slow-start and send at most 2*P packets per P packets acked.</span></td>
  2475. </tr>
  2476. <tr>
  2477. <td id="L381" class="blob-num js-line-number" data-line-number="381"></td>
  2478. <td id="LC381" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * After recovery finishes, or upon undo, we restore the cwnd we had when</span></td>
  2479. </tr>
  2480. <tr>
  2481. <td id="L382" class="blob-num js-line-number" data-line-number="382"></td>
  2482. <td id="LC382" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * recovery started (capped by the target cwnd based on estimated BDP).</span></td>
  2483. </tr>
  2484. <tr>
  2485. <td id="L383" class="blob-num js-line-number" data-line-number="383"></td>
  2486. <td id="LC383" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  2487. </tr>
  2488. <tr>
  2489. <td id="L384" class="blob-num js-line-number" data-line-number="384"></td>
  2490. <td id="LC384" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * TODO(ycheng/ncardwell): implement a rate-based approach.</span></td>
  2491. </tr>
  2492. <tr>
  2493. <td id="L385" class="blob-num js-line-number" data-line-number="385"></td>
  2494. <td id="LC385" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2495. </tr>
  2496. <tr>
  2497. <td id="L386" class="blob-num js-line-number" data-line-number="386"></td>
  2498. <td id="LC386" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">bool</span> <span class="pl-en">bbr_set_cwnd_to_recover_or_restore</span>(</td>
  2499. </tr>
  2500. <tr>
  2501. <td id="L387" class="blob-num js-line-number" data-line-number="387"></td>
  2502. <td id="LC387" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs, u32 acked, u32 *new_cwnd)</td>
  2503. </tr>
  2504. <tr>
  2505. <td id="L388" class="blob-num js-line-number" data-line-number="388"></td>
  2506. <td id="LC388" class="blob-code blob-code-inner js-file-line">{</td>
  2507. </tr>
  2508. <tr>
  2509. <td id="L389" class="blob-num js-line-number" data-line-number="389"></td>
  2510. <td id="LC389" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  2511. </tr>
  2512. <tr>
  2513. <td id="L390" class="blob-num js-line-number" data-line-number="390"></td>
  2514. <td id="LC390" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2515. </tr>
  2516. <tr>
  2517. <td id="L391" class="blob-num js-line-number" data-line-number="391"></td>
  2518. <td id="LC391" class="blob-code blob-code-inner js-file-line"> u8 prev_state = bbr-&gt;prev_ca_state, state = <span class="pl-c1">inet_csk</span>(sk)-&gt;icsk_ca_state;</td>
  2519. </tr>
  2520. <tr>
  2521. <td id="L392" class="blob-num js-line-number" data-line-number="392"></td>
  2522. <td id="LC392" class="blob-code blob-code-inner js-file-line"> u32 cwnd = tp-&gt;snd_cwnd;</td>
  2523. </tr>
  2524. <tr>
  2525. <td id="L393" class="blob-num js-line-number" data-line-number="393"></td>
  2526. <td id="LC393" class="blob-code blob-code-inner js-file-line">
  2527. </td>
  2528. </tr>
  2529. <tr>
  2530. <td id="L394" class="blob-num js-line-number" data-line-number="394"></td>
  2531. <td id="LC394" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> An ACK for P pkts should release at most 2*P packets. We do this</span></td>
  2532. </tr>
  2533. <tr>
  2534. <td id="L395" class="blob-num js-line-number" data-line-number="395"></td>
  2535. <td id="LC395" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * in two steps. First, here we deduct the number of lost packets.</span></td>
  2536. </tr>
  2537. <tr>
  2538. <td id="L396" class="blob-num js-line-number" data-line-number="396"></td>
  2539. <td id="LC396" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Then, in bbr_set_cwnd() we slow start up toward the target cwnd.</span></td>
  2540. </tr>
  2541. <tr>
  2542. <td id="L397" class="blob-num js-line-number" data-line-number="397"></td>
  2543. <td id="LC397" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2544. </tr>
  2545. <tr>
  2546. <td id="L398" class="blob-num js-line-number" data-line-number="398"></td>
  2547. <td id="LC398" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (rs-&gt;losses &gt; <span class="pl-c1">0</span>)</td>
  2548. </tr>
  2549. <tr>
  2550. <td id="L399" class="blob-num js-line-number" data-line-number="399"></td>
  2551. <td id="LC399" class="blob-code blob-code-inner js-file-line"> cwnd = <span class="pl-c1">max_t</span>(s32, cwnd - rs-&gt;losses, <span class="pl-c1">1</span>);</td>
  2552. </tr>
  2553. <tr>
  2554. <td id="L400" class="blob-num js-line-number" data-line-number="400"></td>
  2555. <td id="LC400" class="blob-code blob-code-inner js-file-line">
  2556. </td>
  2557. </tr>
  2558. <tr>
  2559. <td id="L401" class="blob-num js-line-number" data-line-number="401"></td>
  2560. <td id="LC401" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (state == TCP_CA_Recovery &amp;&amp; prev_state != TCP_CA_Recovery) {</td>
  2561. </tr>
  2562. <tr>
  2563. <td id="L402" class="blob-num js-line-number" data-line-number="402"></td>
  2564. <td id="LC402" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Starting 1st round of Recovery, so do packet conservation. <span class="pl-c">*/</span></span></td>
  2565. </tr>
  2566. <tr>
  2567. <td id="L403" class="blob-num js-line-number" data-line-number="403"></td>
  2568. <td id="LC403" class="blob-code blob-code-inner js-file-line"> bbr-&gt;packet_conservation = <span class="pl-c1">1</span>;</td>
  2569. </tr>
  2570. <tr>
  2571. <td id="L404" class="blob-num js-line-number" data-line-number="404"></td>
  2572. <td id="LC404" class="blob-code blob-code-inner js-file-line"> bbr-&gt;next_rtt_delivered = tp-&gt;delivered; <span class="pl-c"><span class="pl-c">/*</span> start round now <span class="pl-c">*/</span></span></td>
  2573. </tr>
  2574. <tr>
  2575. <td id="L405" class="blob-num js-line-number" data-line-number="405"></td>
  2576. <td id="LC405" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Cut unused cwnd from app behavior, TSQ, or TSO deferral: <span class="pl-c">*/</span></span></td>
  2577. </tr>
  2578. <tr>
  2579. <td id="L406" class="blob-num js-line-number" data-line-number="406"></td>
  2580. <td id="LC406" class="blob-code blob-code-inner js-file-line"> cwnd = <span class="pl-c1">tcp_packets_in_flight</span>(tp) + acked;</td>
  2581. </tr>
  2582. <tr>
  2583. <td id="L407" class="blob-num js-line-number" data-line-number="407"></td>
  2584. <td id="LC407" class="blob-code blob-code-inner js-file-line"> } <span class="pl-k">else</span> <span class="pl-k">if</span> (prev_state &gt;= TCP_CA_Recovery &amp;&amp; state &lt; TCP_CA_Recovery) {</td>
  2585. </tr>
  2586. <tr>
  2587. <td id="L408" class="blob-num js-line-number" data-line-number="408"></td>
  2588. <td id="LC408" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Exiting loss recovery; restore cwnd saved before recovery. <span class="pl-c">*/</span></span></td>
  2589. </tr>
  2590. <tr>
  2591. <td id="L409" class="blob-num js-line-number" data-line-number="409"></td>
  2592. <td id="LC409" class="blob-code blob-code-inner js-file-line"> bbr-&gt;restore_cwnd = <span class="pl-c1">1</span>;</td>
  2593. </tr>
  2594. <tr>
  2595. <td id="L410" class="blob-num js-line-number" data-line-number="410"></td>
  2596. <td id="LC410" class="blob-code blob-code-inner js-file-line"> bbr-&gt;packet_conservation = <span class="pl-c1">0</span>;</td>
  2597. </tr>
  2598. <tr>
  2599. <td id="L411" class="blob-num js-line-number" data-line-number="411"></td>
  2600. <td id="LC411" class="blob-code blob-code-inner js-file-line"> }</td>
  2601. </tr>
  2602. <tr>
  2603. <td id="L412" class="blob-num js-line-number" data-line-number="412"></td>
  2604. <td id="LC412" class="blob-code blob-code-inner js-file-line"> bbr-&gt;prev_ca_state = state;</td>
  2605. </tr>
  2606. <tr>
  2607. <td id="L413" class="blob-num js-line-number" data-line-number="413"></td>
  2608. <td id="LC413" class="blob-code blob-code-inner js-file-line">
  2609. </td>
  2610. </tr>
  2611. <tr>
  2612. <td id="L414" class="blob-num js-line-number" data-line-number="414"></td>
  2613. <td id="LC414" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;restore_cwnd) {</td>
  2614. </tr>
  2615. <tr>
  2616. <td id="L415" class="blob-num js-line-number" data-line-number="415"></td>
  2617. <td id="LC415" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Restore cwnd after exiting loss recovery or PROBE_RTT. <span class="pl-c">*/</span></span></td>
  2618. </tr>
  2619. <tr>
  2620. <td id="L416" class="blob-num js-line-number" data-line-number="416"></td>
  2621. <td id="LC416" class="blob-code blob-code-inner js-file-line"> cwnd = <span class="pl-c1">max</span>(cwnd, bbr-&gt;prior_cwnd);</td>
  2622. </tr>
  2623. <tr>
  2624. <td id="L417" class="blob-num js-line-number" data-line-number="417"></td>
  2625. <td id="LC417" class="blob-code blob-code-inner js-file-line"> bbr-&gt;restore_cwnd = <span class="pl-c1">0</span>;</td>
  2626. </tr>
  2627. <tr>
  2628. <td id="L418" class="blob-num js-line-number" data-line-number="418"></td>
  2629. <td id="LC418" class="blob-code blob-code-inner js-file-line"> }</td>
  2630. </tr>
  2631. <tr>
  2632. <td id="L419" class="blob-num js-line-number" data-line-number="419"></td>
  2633. <td id="LC419" class="blob-code blob-code-inner js-file-line">
  2634. </td>
  2635. </tr>
  2636. <tr>
  2637. <td id="L420" class="blob-num js-line-number" data-line-number="420"></td>
  2638. <td id="LC420" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;packet_conservation) {</td>
  2639. </tr>
  2640. <tr>
  2641. <td id="L421" class="blob-num js-line-number" data-line-number="421"></td>
  2642. <td id="LC421" class="blob-code blob-code-inner js-file-line"> *new_cwnd = <span class="pl-c1">max</span>(cwnd, <span class="pl-c1">tcp_packets_in_flight</span>(tp) + acked);</td>
  2643. </tr>
  2644. <tr>
  2645. <td id="L422" class="blob-num js-line-number" data-line-number="422"></td>
  2646. <td id="LC422" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-c1">true</span>; <span class="pl-c"><span class="pl-c">/*</span> yes, using packet conservation <span class="pl-c">*/</span></span></td>
  2647. </tr>
  2648. <tr>
  2649. <td id="L423" class="blob-num js-line-number" data-line-number="423"></td>
  2650. <td id="LC423" class="blob-code blob-code-inner js-file-line"> }</td>
  2651. </tr>
  2652. <tr>
  2653. <td id="L424" class="blob-num js-line-number" data-line-number="424"></td>
  2654. <td id="LC424" class="blob-code blob-code-inner js-file-line"> *new_cwnd = cwnd;</td>
  2655. </tr>
  2656. <tr>
  2657. <td id="L425" class="blob-num js-line-number" data-line-number="425"></td>
  2658. <td id="LC425" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-c1">false</span>;</td>
  2659. </tr>
  2660. <tr>
  2661. <td id="L426" class="blob-num js-line-number" data-line-number="426"></td>
  2662. <td id="LC426" class="blob-code blob-code-inner js-file-line">}</td>
  2663. </tr>
  2664. <tr>
  2665. <td id="L427" class="blob-num js-line-number" data-line-number="427"></td>
  2666. <td id="LC427" class="blob-code blob-code-inner js-file-line">
  2667. </td>
  2668. </tr>
  2669. <tr>
  2670. <td id="L428" class="blob-num js-line-number" data-line-number="428"></td>
  2671. <td id="LC428" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Slow-start up toward target cwnd (if bw estimate is growing, or packet loss</span></td>
  2672. </tr>
  2673. <tr>
  2674. <td id="L429" class="blob-num js-line-number" data-line-number="429"></td>
  2675. <td id="LC429" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * has drawn us down below target), or snap down to target if we&#39;re above it.</span></td>
  2676. </tr>
  2677. <tr>
  2678. <td id="L430" class="blob-num js-line-number" data-line-number="430"></td>
  2679. <td id="LC430" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2680. </tr>
  2681. <tr>
  2682. <td id="L431" class="blob-num js-line-number" data-line-number="431"></td>
  2683. <td id="LC431" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_set_cwnd</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs,</td>
  2684. </tr>
  2685. <tr>
  2686. <td id="L432" class="blob-num js-line-number" data-line-number="432"></td>
  2687. <td id="LC432" class="blob-code blob-code-inner js-file-line"> u32 acked, u32 bw, <span class="pl-k">int</span> gain)</td>
  2688. </tr>
  2689. <tr>
  2690. <td id="L433" class="blob-num js-line-number" data-line-number="433"></td>
  2691. <td id="LC433" class="blob-code blob-code-inner js-file-line">{</td>
  2692. </tr>
  2693. <tr>
  2694. <td id="L434" class="blob-num js-line-number" data-line-number="434"></td>
  2695. <td id="LC434" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  2696. </tr>
  2697. <tr>
  2698. <td id="L435" class="blob-num js-line-number" data-line-number="435"></td>
  2699. <td id="LC435" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2700. </tr>
  2701. <tr>
  2702. <td id="L436" class="blob-num js-line-number" data-line-number="436"></td>
  2703. <td id="LC436" class="blob-code blob-code-inner js-file-line"> u32 cwnd = <span class="pl-c1">0</span>, target_cwnd = <span class="pl-c1">0</span>;</td>
  2704. </tr>
  2705. <tr>
  2706. <td id="L437" class="blob-num js-line-number" data-line-number="437"></td>
  2707. <td id="LC437" class="blob-code blob-code-inner js-file-line">
  2708. </td>
  2709. </tr>
  2710. <tr>
  2711. <td id="L438" class="blob-num js-line-number" data-line-number="438"></td>
  2712. <td id="LC438" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!acked)</td>
  2713. </tr>
  2714. <tr>
  2715. <td id="L439" class="blob-num js-line-number" data-line-number="439"></td>
  2716. <td id="LC439" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  2717. </tr>
  2718. <tr>
  2719. <td id="L440" class="blob-num js-line-number" data-line-number="440"></td>
  2720. <td id="LC440" class="blob-code blob-code-inner js-file-line">
  2721. </td>
  2722. </tr>
  2723. <tr>
  2724. <td id="L441" class="blob-num js-line-number" data-line-number="441"></td>
  2725. <td id="LC441" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (<span class="pl-c1">bbr_set_cwnd_to_recover_or_restore</span>(sk, rs, acked, &amp;cwnd))</td>
  2726. </tr>
  2727. <tr>
  2728. <td id="L442" class="blob-num js-line-number" data-line-number="442"></td>
  2729. <td id="LC442" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">goto</span> done;</td>
  2730. </tr>
  2731. <tr>
  2732. <td id="L443" class="blob-num js-line-number" data-line-number="443"></td>
  2733. <td id="LC443" class="blob-code blob-code-inner js-file-line">
  2734. </td>
  2735. </tr>
  2736. <tr>
  2737. <td id="L444" class="blob-num js-line-number" data-line-number="444"></td>
  2738. <td id="LC444" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> If we&#39;re below target cwnd, slow start cwnd toward target cwnd. <span class="pl-c">*/</span></span></td>
  2739. </tr>
  2740. <tr>
  2741. <td id="L445" class="blob-num js-line-number" data-line-number="445"></td>
  2742. <td id="LC445" class="blob-code blob-code-inner js-file-line"> target_cwnd = <span class="pl-c1">bbr_target_cwnd</span>(sk, bw, gain);</td>
  2743. </tr>
  2744. <tr>
  2745. <td id="L446" class="blob-num js-line-number" data-line-number="446"></td>
  2746. <td id="LC446" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (<span class="pl-c1">bbr_full_bw_reached</span>(sk)) <span class="pl-c"><span class="pl-c">/*</span> only cut cwnd if we filled the pipe <span class="pl-c">*/</span></span></td>
  2747. </tr>
  2748. <tr>
  2749. <td id="L447" class="blob-num js-line-number" data-line-number="447"></td>
  2750. <td id="LC447" class="blob-code blob-code-inner js-file-line"> cwnd = <span class="pl-c1">min</span>(cwnd + acked, target_cwnd);</td>
  2751. </tr>
  2752. <tr>
  2753. <td id="L448" class="blob-num js-line-number" data-line-number="448"></td>
  2754. <td id="LC448" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">else</span> <span class="pl-k">if</span> (cwnd &lt; target_cwnd || tp-&gt;delivered &lt; TCP_INIT_CWND)</td>
  2755. </tr>
  2756. <tr>
  2757. <td id="L449" class="blob-num js-line-number" data-line-number="449"></td>
  2758. <td id="LC449" class="blob-code blob-code-inner js-file-line"> cwnd = cwnd + acked;</td>
  2759. </tr>
  2760. <tr>
  2761. <td id="L450" class="blob-num js-line-number" data-line-number="450"></td>
  2762. <td id="LC450" class="blob-code blob-code-inner js-file-line"> cwnd = <span class="pl-c1">max</span>(cwnd, bbr_cwnd_min_target);</td>
  2763. </tr>
  2764. <tr>
  2765. <td id="L451" class="blob-num js-line-number" data-line-number="451"></td>
  2766. <td id="LC451" class="blob-code blob-code-inner js-file-line">
  2767. </td>
  2768. </tr>
  2769. <tr>
  2770. <td id="L452" class="blob-num js-line-number" data-line-number="452"></td>
  2771. <td id="LC452" class="blob-code blob-code-inner js-file-line">done:</td>
  2772. </tr>
  2773. <tr>
  2774. <td id="L453" class="blob-num js-line-number" data-line-number="453"></td>
  2775. <td id="LC453" class="blob-code blob-code-inner js-file-line"> tp-&gt;snd_cwnd = <span class="pl-c1">min</span>(cwnd, tp-&gt;snd_cwnd_clamp); <span class="pl-c"><span class="pl-c">/*</span> apply global cap <span class="pl-c">*/</span></span></td>
  2776. </tr>
  2777. <tr>
  2778. <td id="L454" class="blob-num js-line-number" data-line-number="454"></td>
  2779. <td id="LC454" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;mode == BBR_PROBE_RTT) <span class="pl-c"><span class="pl-c">/*</span> drain queue, refresh min_rtt <span class="pl-c">*/</span></span></td>
  2780. </tr>
  2781. <tr>
  2782. <td id="L455" class="blob-num js-line-number" data-line-number="455"></td>
  2783. <td id="LC455" class="blob-code blob-code-inner js-file-line"> tp-&gt;snd_cwnd = <span class="pl-c1">max</span>(tp-&gt;snd_cwnd &gt;&gt; <span class="pl-c1">1</span>, bbr_cwnd_min_target);</td>
  2784. </tr>
  2785. <tr>
  2786. <td id="L456" class="blob-num js-line-number" data-line-number="456"></td>
  2787. <td id="LC456" class="blob-code blob-code-inner js-file-line">}</td>
  2788. </tr>
  2789. <tr>
  2790. <td id="L457" class="blob-num js-line-number" data-line-number="457"></td>
  2791. <td id="LC457" class="blob-code blob-code-inner js-file-line">
  2792. </td>
  2793. </tr>
  2794. <tr>
  2795. <td id="L458" class="blob-num js-line-number" data-line-number="458"></td>
  2796. <td id="LC458" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> End cycle phase if it&#39;s time and/or we hit the phase&#39;s in-flight target. <span class="pl-c">*/</span></span></td>
  2797. </tr>
  2798. <tr>
  2799. <td id="L459" class="blob-num js-line-number" data-line-number="459"></td>
  2800. <td id="LC459" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">bool</span> <span class="pl-en">bbr_is_next_cycle_phase</span>(<span class="pl-k">struct</span> sock *sk,</td>
  2801. </tr>
  2802. <tr>
  2803. <td id="L460" class="blob-num js-line-number" data-line-number="460"></td>
  2804. <td id="LC460" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  2805. </tr>
  2806. <tr>
  2807. <td id="L461" class="blob-num js-line-number" data-line-number="461"></td>
  2808. <td id="LC461" class="blob-code blob-code-inner js-file-line">{</td>
  2809. </tr>
  2810. <tr>
  2811. <td id="L462" class="blob-num js-line-number" data-line-number="462"></td>
  2812. <td id="LC462" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  2813. </tr>
  2814. <tr>
  2815. <td id="L463" class="blob-num js-line-number" data-line-number="463"></td>
  2816. <td id="LC463" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2817. </tr>
  2818. <tr>
  2819. <td id="L464" class="blob-num js-line-number" data-line-number="464"></td>
  2820. <td id="LC464" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">bool</span> is_full_length =</td>
  2821. </tr>
  2822. <tr>
  2823. <td id="L465" class="blob-num js-line-number" data-line-number="465"></td>
  2824. <td id="LC465" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">skb_mstamp_us_delta</span>(&amp;tp-&gt;delivered_mstamp, &amp;bbr-&gt;cycle_mstamp) &gt;</td>
  2825. </tr>
  2826. <tr>
  2827. <td id="L466" class="blob-num js-line-number" data-line-number="466"></td>
  2828. <td id="LC466" class="blob-code blob-code-inner js-file-line"> bbr-&gt;min_rtt_us;</td>
  2829. </tr>
  2830. <tr>
  2831. <td id="L467" class="blob-num js-line-number" data-line-number="467"></td>
  2832. <td id="LC467" class="blob-code blob-code-inner js-file-line"> u32 inflight, bw;</td>
  2833. </tr>
  2834. <tr>
  2835. <td id="L468" class="blob-num js-line-number" data-line-number="468"></td>
  2836. <td id="LC468" class="blob-code blob-code-inner js-file-line">
  2837. </td>
  2838. </tr>
  2839. <tr>
  2840. <td id="L469" class="blob-num js-line-number" data-line-number="469"></td>
  2841. <td id="LC469" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> The pacing_gain of 1.0 paces at the estimated bw to try to fully</span></td>
  2842. </tr>
  2843. <tr>
  2844. <td id="L470" class="blob-num js-line-number" data-line-number="470"></td>
  2845. <td id="LC470" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * use the pipe without increasing the queue.</span></td>
  2846. </tr>
  2847. <tr>
  2848. <td id="L471" class="blob-num js-line-number" data-line-number="471"></td>
  2849. <td id="LC471" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2850. </tr>
  2851. <tr>
  2852. <td id="L472" class="blob-num js-line-number" data-line-number="472"></td>
  2853. <td id="LC472" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;pacing_gain == BBR_UNIT)</td>
  2854. </tr>
  2855. <tr>
  2856. <td id="L473" class="blob-num js-line-number" data-line-number="473"></td>
  2857. <td id="LC473" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> is_full_length; <span class="pl-c"><span class="pl-c">/*</span> just use wall clock time <span class="pl-c">*/</span></span></td>
  2858. </tr>
  2859. <tr>
  2860. <td id="L474" class="blob-num js-line-number" data-line-number="474"></td>
  2861. <td id="LC474" class="blob-code blob-code-inner js-file-line">
  2862. </td>
  2863. </tr>
  2864. <tr>
  2865. <td id="L475" class="blob-num js-line-number" data-line-number="475"></td>
  2866. <td id="LC475" class="blob-code blob-code-inner js-file-line"> inflight = rs-&gt;prior_in_flight; <span class="pl-c"><span class="pl-c">/*</span> what was in-flight before ACK? <span class="pl-c">*/</span></span></td>
  2867. </tr>
  2868. <tr>
  2869. <td id="L476" class="blob-num js-line-number" data-line-number="476"></td>
  2870. <td id="LC476" class="blob-code blob-code-inner js-file-line"> bw = <span class="pl-c1">bbr_max_bw</span>(sk);</td>
  2871. </tr>
  2872. <tr>
  2873. <td id="L477" class="blob-num js-line-number" data-line-number="477"></td>
  2874. <td id="LC477" class="blob-code blob-code-inner js-file-line">
  2875. </td>
  2876. </tr>
  2877. <tr>
  2878. <td id="L478" class="blob-num js-line-number" data-line-number="478"></td>
  2879. <td id="LC478" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> A pacing_gain &gt; 1.0 probes for bw by trying to raise inflight to at</span></td>
  2880. </tr>
  2881. <tr>
  2882. <td id="L479" class="blob-num js-line-number" data-line-number="479"></td>
  2883. <td id="LC479" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * least pacing_gain*BDP; this may take more than min_rtt if min_rtt is</span></td>
  2884. </tr>
  2885. <tr>
  2886. <td id="L480" class="blob-num js-line-number" data-line-number="480"></td>
  2887. <td id="LC480" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * small (e.g. on a LAN). We do not persist if packets are lost, since</span></td>
  2888. </tr>
  2889. <tr>
  2890. <td id="L481" class="blob-num js-line-number" data-line-number="481"></td>
  2891. <td id="LC481" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * a path with small buffers may not hold that much.</span></td>
  2892. </tr>
  2893. <tr>
  2894. <td id="L482" class="blob-num js-line-number" data-line-number="482"></td>
  2895. <td id="LC482" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2896. </tr>
  2897. <tr>
  2898. <td id="L483" class="blob-num js-line-number" data-line-number="483"></td>
  2899. <td id="LC483" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;pacing_gain &gt; BBR_UNIT)</td>
  2900. </tr>
  2901. <tr>
  2902. <td id="L484" class="blob-num js-line-number" data-line-number="484"></td>
  2903. <td id="LC484" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> is_full_length &amp;&amp;</td>
  2904. </tr>
  2905. <tr>
  2906. <td id="L485" class="blob-num js-line-number" data-line-number="485"></td>
  2907. <td id="LC485" class="blob-code blob-code-inner js-file-line"> (rs-&gt;losses || <span class="pl-c"><span class="pl-c">/*</span> perhaps pacing_gain*BDP won&#39;t fit <span class="pl-c">*/</span></span></td>
  2908. </tr>
  2909. <tr>
  2910. <td id="L486" class="blob-num js-line-number" data-line-number="486"></td>
  2911. <td id="LC486" class="blob-code blob-code-inner js-file-line"> inflight &gt;= <span class="pl-c1">bbr_target_cwnd</span>(sk, bw, bbr-&gt;pacing_gain));</td>
  2912. </tr>
  2913. <tr>
  2914. <td id="L487" class="blob-num js-line-number" data-line-number="487"></td>
  2915. <td id="LC487" class="blob-code blob-code-inner js-file-line">
  2916. </td>
  2917. </tr>
  2918. <tr>
  2919. <td id="L488" class="blob-num js-line-number" data-line-number="488"></td>
  2920. <td id="LC488" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> A pacing_gain &lt; 1.0 tries to drain extra queue we added if bw</span></td>
  2921. </tr>
  2922. <tr>
  2923. <td id="L489" class="blob-num js-line-number" data-line-number="489"></td>
  2924. <td id="LC489" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * probing didn&#39;t find more bw. If inflight falls to match BDP then we</span></td>
  2925. </tr>
  2926. <tr>
  2927. <td id="L490" class="blob-num js-line-number" data-line-number="490"></td>
  2928. <td id="LC490" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * estimate queue is drained; persisting would underutilize the pipe.</span></td>
  2929. </tr>
  2930. <tr>
  2931. <td id="L491" class="blob-num js-line-number" data-line-number="491"></td>
  2932. <td id="LC491" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  2933. </tr>
  2934. <tr>
  2935. <td id="L492" class="blob-num js-line-number" data-line-number="492"></td>
  2936. <td id="LC492" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> is_full_length ||</td>
  2937. </tr>
  2938. <tr>
  2939. <td id="L493" class="blob-num js-line-number" data-line-number="493"></td>
  2940. <td id="LC493" class="blob-code blob-code-inner js-file-line"> inflight &lt;= <span class="pl-c1">bbr_target_cwnd</span>(sk, bw, BBR_UNIT);</td>
  2941. </tr>
  2942. <tr>
  2943. <td id="L494" class="blob-num js-line-number" data-line-number="494"></td>
  2944. <td id="LC494" class="blob-code blob-code-inner js-file-line">}</td>
  2945. </tr>
  2946. <tr>
  2947. <td id="L495" class="blob-num js-line-number" data-line-number="495"></td>
  2948. <td id="LC495" class="blob-code blob-code-inner js-file-line">
  2949. </td>
  2950. </tr>
  2951. <tr>
  2952. <td id="L496" class="blob-num js-line-number" data-line-number="496"></td>
  2953. <td id="LC496" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_advance_cycle_phase</span>(<span class="pl-k">struct</span> sock *sk)</td>
  2954. </tr>
  2955. <tr>
  2956. <td id="L497" class="blob-num js-line-number" data-line-number="497"></td>
  2957. <td id="LC497" class="blob-code blob-code-inner js-file-line">{</td>
  2958. </tr>
  2959. <tr>
  2960. <td id="L498" class="blob-num js-line-number" data-line-number="498"></td>
  2961. <td id="LC498" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  2962. </tr>
  2963. <tr>
  2964. <td id="L499" class="blob-num js-line-number" data-line-number="499"></td>
  2965. <td id="LC499" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  2966. </tr>
  2967. <tr>
  2968. <td id="L500" class="blob-num js-line-number" data-line-number="500"></td>
  2969. <td id="LC500" class="blob-code blob-code-inner js-file-line">
  2970. </td>
  2971. </tr>
  2972. <tr>
  2973. <td id="L501" class="blob-num js-line-number" data-line-number="501"></td>
  2974. <td id="LC501" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cycle_idx = (bbr-&gt;cycle_idx + <span class="pl-c1">1</span>) &amp; (CYCLE_LEN - <span class="pl-c1">1</span>);</td>
  2975. </tr>
  2976. <tr>
  2977. <td id="L502" class="blob-num js-line-number" data-line-number="502"></td>
  2978. <td id="LC502" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cycle_mstamp = tp-&gt;delivered_mstamp;</td>
  2979. </tr>
  2980. <tr>
  2981. <td id="L503" class="blob-num js-line-number" data-line-number="503"></td>
  2982. <td id="LC503" class="blob-code blob-code-inner js-file-line"> bbr-&gt;pacing_gain = bbr_pacing_gain[bbr-&gt;cycle_idx];</td>
  2983. </tr>
  2984. <tr>
  2985. <td id="L504" class="blob-num js-line-number" data-line-number="504"></td>
  2986. <td id="LC504" class="blob-code blob-code-inner js-file-line">}</td>
  2987. </tr>
  2988. <tr>
  2989. <td id="L505" class="blob-num js-line-number" data-line-number="505"></td>
  2990. <td id="LC505" class="blob-code blob-code-inner js-file-line">
  2991. </td>
  2992. </tr>
  2993. <tr>
  2994. <td id="L506" class="blob-num js-line-number" data-line-number="506"></td>
  2995. <td id="LC506" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Gain cycling: cycle pacing gain to converge to fair share of available bw. <span class="pl-c">*/</span></span></td>
  2996. </tr>
  2997. <tr>
  2998. <td id="L507" class="blob-num js-line-number" data-line-number="507"></td>
  2999. <td id="LC507" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_update_cycle_phase</span>(<span class="pl-k">struct</span> sock *sk,</td>
  3000. </tr>
  3001. <tr>
  3002. <td id="L508" class="blob-num js-line-number" data-line-number="508"></td>
  3003. <td id="LC508" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  3004. </tr>
  3005. <tr>
  3006. <td id="L509" class="blob-num js-line-number" data-line-number="509"></td>
  3007. <td id="LC509" class="blob-code blob-code-inner js-file-line">{</td>
  3008. </tr>
  3009. <tr>
  3010. <td id="L510" class="blob-num js-line-number" data-line-number="510"></td>
  3011. <td id="LC510" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3012. </tr>
  3013. <tr>
  3014. <td id="L511" class="blob-num js-line-number" data-line-number="511"></td>
  3015. <td id="LC511" class="blob-code blob-code-inner js-file-line">
  3016. </td>
  3017. </tr>
  3018. <tr>
  3019. <td id="L512" class="blob-num js-line-number" data-line-number="512"></td>
  3020. <td id="LC512" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> ((bbr-&gt;mode == BBR_PROBE_BW) &amp;&amp; !bbr-&gt;lt_use_bw &amp;&amp;</td>
  3021. </tr>
  3022. <tr>
  3023. <td id="L513" class="blob-num js-line-number" data-line-number="513"></td>
  3024. <td id="LC513" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_is_next_cycle_phase</span>(sk, rs))</td>
  3025. </tr>
  3026. <tr>
  3027. <td id="L514" class="blob-num js-line-number" data-line-number="514"></td>
  3028. <td id="LC514" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_advance_cycle_phase</span>(sk);</td>
  3029. </tr>
  3030. <tr>
  3031. <td id="L515" class="blob-num js-line-number" data-line-number="515"></td>
  3032. <td id="LC515" class="blob-code blob-code-inner js-file-line">}</td>
  3033. </tr>
  3034. <tr>
  3035. <td id="L516" class="blob-num js-line-number" data-line-number="516"></td>
  3036. <td id="LC516" class="blob-code blob-code-inner js-file-line">
  3037. </td>
  3038. </tr>
  3039. <tr>
  3040. <td id="L517" class="blob-num js-line-number" data-line-number="517"></td>
  3041. <td id="LC517" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_reset_startup_mode</span>(<span class="pl-k">struct</span> sock *sk)</td>
  3042. </tr>
  3043. <tr>
  3044. <td id="L518" class="blob-num js-line-number" data-line-number="518"></td>
  3045. <td id="LC518" class="blob-code blob-code-inner js-file-line">{</td>
  3046. </tr>
  3047. <tr>
  3048. <td id="L519" class="blob-num js-line-number" data-line-number="519"></td>
  3049. <td id="LC519" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3050. </tr>
  3051. <tr>
  3052. <td id="L520" class="blob-num js-line-number" data-line-number="520"></td>
  3053. <td id="LC520" class="blob-code blob-code-inner js-file-line">
  3054. </td>
  3055. </tr>
  3056. <tr>
  3057. <td id="L521" class="blob-num js-line-number" data-line-number="521"></td>
  3058. <td id="LC521" class="blob-code blob-code-inner js-file-line"> bbr-&gt;mode = BBR_STARTUP;</td>
  3059. </tr>
  3060. <tr>
  3061. <td id="L522" class="blob-num js-line-number" data-line-number="522"></td>
  3062. <td id="LC522" class="blob-code blob-code-inner js-file-line"> bbr-&gt;pacing_gain = bbr_high_gain;</td>
  3063. </tr>
  3064. <tr>
  3065. <td id="L523" class="blob-num js-line-number" data-line-number="523"></td>
  3066. <td id="LC523" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cwnd_gain = bbr_high_gain;</td>
  3067. </tr>
  3068. <tr>
  3069. <td id="L524" class="blob-num js-line-number" data-line-number="524"></td>
  3070. <td id="LC524" class="blob-code blob-code-inner js-file-line">}</td>
  3071. </tr>
  3072. <tr>
  3073. <td id="L525" class="blob-num js-line-number" data-line-number="525"></td>
  3074. <td id="LC525" class="blob-code blob-code-inner js-file-line">
  3075. </td>
  3076. </tr>
  3077. <tr>
  3078. <td id="L526" class="blob-num js-line-number" data-line-number="526"></td>
  3079. <td id="LC526" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_reset_probe_bw_mode</span>(<span class="pl-k">struct</span> sock *sk)</td>
  3080. </tr>
  3081. <tr>
  3082. <td id="L527" class="blob-num js-line-number" data-line-number="527"></td>
  3083. <td id="LC527" class="blob-code blob-code-inner js-file-line">{</td>
  3084. </tr>
  3085. <tr>
  3086. <td id="L528" class="blob-num js-line-number" data-line-number="528"></td>
  3087. <td id="LC528" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3088. </tr>
  3089. <tr>
  3090. <td id="L529" class="blob-num js-line-number" data-line-number="529"></td>
  3091. <td id="LC529" class="blob-code blob-code-inner js-file-line">
  3092. </td>
  3093. </tr>
  3094. <tr>
  3095. <td id="L530" class="blob-num js-line-number" data-line-number="530"></td>
  3096. <td id="LC530" class="blob-code blob-code-inner js-file-line"> bbr-&gt;mode = BBR_PROBE_BW;</td>
  3097. </tr>
  3098. <tr>
  3099. <td id="L531" class="blob-num js-line-number" data-line-number="531"></td>
  3100. <td id="LC531" class="blob-code blob-code-inner js-file-line"> bbr-&gt;pacing_gain = BBR_UNIT;</td>
  3101. </tr>
  3102. <tr>
  3103. <td id="L532" class="blob-num js-line-number" data-line-number="532"></td>
  3104. <td id="LC532" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cwnd_gain = bbr_cwnd_gain;</td>
  3105. </tr>
  3106. <tr>
  3107. <td id="L533" class="blob-num js-line-number" data-line-number="533"></td>
  3108. <td id="LC533" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cycle_idx = CYCLE_LEN - <span class="pl-c1">1</span> - <span class="pl-c1">prandom_u32_max</span>(bbr_cycle_rand);</td>
  3109. </tr>
  3110. <tr>
  3111. <td id="L534" class="blob-num js-line-number" data-line-number="534"></td>
  3112. <td id="LC534" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_advance_cycle_phase</span>(sk); <span class="pl-c"><span class="pl-c">/*</span> flip to next phase of gain cycle <span class="pl-c">*/</span></span></td>
  3113. </tr>
  3114. <tr>
  3115. <td id="L535" class="blob-num js-line-number" data-line-number="535"></td>
  3116. <td id="LC535" class="blob-code blob-code-inner js-file-line">}</td>
  3117. </tr>
  3118. <tr>
  3119. <td id="L536" class="blob-num js-line-number" data-line-number="536"></td>
  3120. <td id="LC536" class="blob-code blob-code-inner js-file-line">
  3121. </td>
  3122. </tr>
  3123. <tr>
  3124. <td id="L537" class="blob-num js-line-number" data-line-number="537"></td>
  3125. <td id="LC537" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_reset_mode</span>(<span class="pl-k">struct</span> sock *sk)</td>
  3126. </tr>
  3127. <tr>
  3128. <td id="L538" class="blob-num js-line-number" data-line-number="538"></td>
  3129. <td id="LC538" class="blob-code blob-code-inner js-file-line">{</td>
  3130. </tr>
  3131. <tr>
  3132. <td id="L539" class="blob-num js-line-number" data-line-number="539"></td>
  3133. <td id="LC539" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!<span class="pl-c1">bbr_full_bw_reached</span>(sk))</td>
  3134. </tr>
  3135. <tr>
  3136. <td id="L540" class="blob-num js-line-number" data-line-number="540"></td>
  3137. <td id="LC540" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_startup_mode</span>(sk);</td>
  3138. </tr>
  3139. <tr>
  3140. <td id="L541" class="blob-num js-line-number" data-line-number="541"></td>
  3141. <td id="LC541" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">else</span></td>
  3142. </tr>
  3143. <tr>
  3144. <td id="L542" class="blob-num js-line-number" data-line-number="542"></td>
  3145. <td id="LC542" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_probe_bw_mode</span>(sk);</td>
  3146. </tr>
  3147. <tr>
  3148. <td id="L543" class="blob-num js-line-number" data-line-number="543"></td>
  3149. <td id="LC543" class="blob-code blob-code-inner js-file-line">}</td>
  3150. </tr>
  3151. <tr>
  3152. <td id="L544" class="blob-num js-line-number" data-line-number="544"></td>
  3153. <td id="LC544" class="blob-code blob-code-inner js-file-line">
  3154. </td>
  3155. </tr>
  3156. <tr>
  3157. <td id="L545" class="blob-num js-line-number" data-line-number="545"></td>
  3158. <td id="LC545" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Start a new long-term sampling interval. <span class="pl-c">*/</span></span></td>
  3159. </tr>
  3160. <tr>
  3161. <td id="L546" class="blob-num js-line-number" data-line-number="546"></td>
  3162. <td id="LC546" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_reset_lt_bw_sampling_interval</span>(<span class="pl-k">struct</span> sock *sk)</td>
  3163. </tr>
  3164. <tr>
  3165. <td id="L547" class="blob-num js-line-number" data-line-number="547"></td>
  3166. <td id="LC547" class="blob-code blob-code-inner js-file-line">{</td>
  3167. </tr>
  3168. <tr>
  3169. <td id="L548" class="blob-num js-line-number" data-line-number="548"></td>
  3170. <td id="LC548" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  3171. </tr>
  3172. <tr>
  3173. <td id="L549" class="blob-num js-line-number" data-line-number="549"></td>
  3174. <td id="LC549" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3175. </tr>
  3176. <tr>
  3177. <td id="L550" class="blob-num js-line-number" data-line-number="550"></td>
  3178. <td id="LC550" class="blob-code blob-code-inner js-file-line">
  3179. </td>
  3180. </tr>
  3181. <tr>
  3182. <td id="L551" class="blob-num js-line-number" data-line-number="551"></td>
  3183. <td id="LC551" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_last_stamp = tp-&gt;delivered_mstamp.<span class="pl-smi">stamp_jiffies</span>;</td>
  3184. </tr>
  3185. <tr>
  3186. <td id="L552" class="blob-num js-line-number" data-line-number="552"></td>
  3187. <td id="LC552" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_last_delivered = tp-&gt;delivered;</td>
  3188. </tr>
  3189. <tr>
  3190. <td id="L553" class="blob-num js-line-number" data-line-number="553"></td>
  3191. <td id="LC553" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_last_lost = tp-&gt;lost;</td>
  3192. </tr>
  3193. <tr>
  3194. <td id="L554" class="blob-num js-line-number" data-line-number="554"></td>
  3195. <td id="LC554" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_rtt_cnt = <span class="pl-c1">0</span>;</td>
  3196. </tr>
  3197. <tr>
  3198. <td id="L555" class="blob-num js-line-number" data-line-number="555"></td>
  3199. <td id="LC555" class="blob-code blob-code-inner js-file-line">}</td>
  3200. </tr>
  3201. <tr>
  3202. <td id="L556" class="blob-num js-line-number" data-line-number="556"></td>
  3203. <td id="LC556" class="blob-code blob-code-inner js-file-line">
  3204. </td>
  3205. </tr>
  3206. <tr>
  3207. <td id="L557" class="blob-num js-line-number" data-line-number="557"></td>
  3208. <td id="LC557" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Completely reset long-term bandwidth sampling. <span class="pl-c">*/</span></span></td>
  3209. </tr>
  3210. <tr>
  3211. <td id="L558" class="blob-num js-line-number" data-line-number="558"></td>
  3212. <td id="LC558" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_reset_lt_bw_sampling</span>(<span class="pl-k">struct</span> sock *sk)</td>
  3213. </tr>
  3214. <tr>
  3215. <td id="L559" class="blob-num js-line-number" data-line-number="559"></td>
  3216. <td id="LC559" class="blob-code blob-code-inner js-file-line">{</td>
  3217. </tr>
  3218. <tr>
  3219. <td id="L560" class="blob-num js-line-number" data-line-number="560"></td>
  3220. <td id="LC560" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3221. </tr>
  3222. <tr>
  3223. <td id="L561" class="blob-num js-line-number" data-line-number="561"></td>
  3224. <td id="LC561" class="blob-code blob-code-inner js-file-line">
  3225. </td>
  3226. </tr>
  3227. <tr>
  3228. <td id="L562" class="blob-num js-line-number" data-line-number="562"></td>
  3229. <td id="LC562" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_bw = <span class="pl-c1">0</span>;</td>
  3230. </tr>
  3231. <tr>
  3232. <td id="L563" class="blob-num js-line-number" data-line-number="563"></td>
  3233. <td id="LC563" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_use_bw = <span class="pl-c1">0</span>;</td>
  3234. </tr>
  3235. <tr>
  3236. <td id="L564" class="blob-num js-line-number" data-line-number="564"></td>
  3237. <td id="LC564" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_is_sampling = <span class="pl-c1">false</span>;</td>
  3238. </tr>
  3239. <tr>
  3240. <td id="L565" class="blob-num js-line-number" data-line-number="565"></td>
  3241. <td id="LC565" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling_interval</span>(sk);</td>
  3242. </tr>
  3243. <tr>
  3244. <td id="L566" class="blob-num js-line-number" data-line-number="566"></td>
  3245. <td id="LC566" class="blob-code blob-code-inner js-file-line">}</td>
  3246. </tr>
  3247. <tr>
  3248. <td id="L567" class="blob-num js-line-number" data-line-number="567"></td>
  3249. <td id="LC567" class="blob-code blob-code-inner js-file-line">
  3250. </td>
  3251. </tr>
  3252. <tr>
  3253. <td id="L568" class="blob-num js-line-number" data-line-number="568"></td>
  3254. <td id="LC568" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Long-term bw sampling interval is done. Estimate whether we&#39;re policed. <span class="pl-c">*/</span></span></td>
  3255. </tr>
  3256. <tr>
  3257. <td id="L569" class="blob-num js-line-number" data-line-number="569"></td>
  3258. <td id="LC569" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_lt_bw_interval_done</span>(<span class="pl-k">struct</span> sock *sk, u32 bw)</td>
  3259. </tr>
  3260. <tr>
  3261. <td id="L570" class="blob-num js-line-number" data-line-number="570"></td>
  3262. <td id="LC570" class="blob-code blob-code-inner js-file-line">{</td>
  3263. </tr>
  3264. <tr>
  3265. <td id="L571" class="blob-num js-line-number" data-line-number="571"></td>
  3266. <td id="LC571" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3267. </tr>
  3268. <tr>
  3269. <td id="L572" class="blob-num js-line-number" data-line-number="572"></td>
  3270. <td id="LC572" class="blob-code blob-code-inner js-file-line"> u32 diff;</td>
  3271. </tr>
  3272. <tr>
  3273. <td id="L573" class="blob-num js-line-number" data-line-number="573"></td>
  3274. <td id="LC573" class="blob-code blob-code-inner js-file-line">
  3275. </td>
  3276. </tr>
  3277. <tr>
  3278. <td id="L574" class="blob-num js-line-number" data-line-number="574"></td>
  3279. <td id="LC574" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;lt_bw) { <span class="pl-c"><span class="pl-c">/*</span> do we have bw from a previous interval? <span class="pl-c">*/</span></span></td>
  3280. </tr>
  3281. <tr>
  3282. <td id="L575" class="blob-num js-line-number" data-line-number="575"></td>
  3283. <td id="LC575" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Is new bw close to the lt_bw from the previous interval? <span class="pl-c">*/</span></span></td>
  3284. </tr>
  3285. <tr>
  3286. <td id="L576" class="blob-num js-line-number" data-line-number="576"></td>
  3287. <td id="LC576" class="blob-code blob-code-inner js-file-line"> diff = <span class="pl-c1">abs</span>(bw - bbr-&gt;lt_bw);</td>
  3288. </tr>
  3289. <tr>
  3290. <td id="L577" class="blob-num js-line-number" data-line-number="577"></td>
  3291. <td id="LC577" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> ((diff * BBR_UNIT &lt;= bbr_lt_bw_ratio * bbr-&gt;lt_bw) ||</td>
  3292. </tr>
  3293. <tr>
  3294. <td id="L578" class="blob-num js-line-number" data-line-number="578"></td>
  3295. <td id="LC578" class="blob-code blob-code-inner js-file-line"> (<span class="pl-c1">bbr_rate_bytes_per_sec</span>(sk, diff, BBR_UNIT) &lt;=</td>
  3296. </tr>
  3297. <tr>
  3298. <td id="L579" class="blob-num js-line-number" data-line-number="579"></td>
  3299. <td id="LC579" class="blob-code blob-code-inner js-file-line"> bbr_lt_bw_diff)) {</td>
  3300. </tr>
  3301. <tr>
  3302. <td id="L580" class="blob-num js-line-number" data-line-number="580"></td>
  3303. <td id="LC580" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> All criteria are met; estimate we&#39;re policed. <span class="pl-c">*/</span></span></td>
  3304. </tr>
  3305. <tr>
  3306. <td id="L581" class="blob-num js-line-number" data-line-number="581"></td>
  3307. <td id="LC581" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_bw = (bw + bbr-&gt;lt_bw) &gt;&gt; <span class="pl-c1">1</span>; <span class="pl-c"><span class="pl-c">/*</span> avg 2 intvls <span class="pl-c">*/</span></span></td>
  3308. </tr>
  3309. <tr>
  3310. <td id="L582" class="blob-num js-line-number" data-line-number="582"></td>
  3311. <td id="LC582" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_use_bw = <span class="pl-c1">1</span>;</td>
  3312. </tr>
  3313. <tr>
  3314. <td id="L583" class="blob-num js-line-number" data-line-number="583"></td>
  3315. <td id="LC583" class="blob-code blob-code-inner js-file-line"> bbr-&gt;pacing_gain = BBR_UNIT; <span class="pl-c"><span class="pl-c">/*</span> try to avoid drops <span class="pl-c">*/</span></span></td>
  3316. </tr>
  3317. <tr>
  3318. <td id="L584" class="blob-num js-line-number" data-line-number="584"></td>
  3319. <td id="LC584" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_rtt_cnt = <span class="pl-c1">0</span>;</td>
  3320. </tr>
  3321. <tr>
  3322. <td id="L585" class="blob-num js-line-number" data-line-number="585"></td>
  3323. <td id="LC585" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3324. </tr>
  3325. <tr>
  3326. <td id="L586" class="blob-num js-line-number" data-line-number="586"></td>
  3327. <td id="LC586" class="blob-code blob-code-inner js-file-line"> }</td>
  3328. </tr>
  3329. <tr>
  3330. <td id="L587" class="blob-num js-line-number" data-line-number="587"></td>
  3331. <td id="LC587" class="blob-code blob-code-inner js-file-line"> }</td>
  3332. </tr>
  3333. <tr>
  3334. <td id="L588" class="blob-num js-line-number" data-line-number="588"></td>
  3335. <td id="LC588" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_bw = bw;</td>
  3336. </tr>
  3337. <tr>
  3338. <td id="L589" class="blob-num js-line-number" data-line-number="589"></td>
  3339. <td id="LC589" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling_interval</span>(sk);</td>
  3340. </tr>
  3341. <tr>
  3342. <td id="L590" class="blob-num js-line-number" data-line-number="590"></td>
  3343. <td id="LC590" class="blob-code blob-code-inner js-file-line">}</td>
  3344. </tr>
  3345. <tr>
  3346. <td id="L591" class="blob-num js-line-number" data-line-number="591"></td>
  3347. <td id="LC591" class="blob-code blob-code-inner js-file-line">
  3348. </td>
  3349. </tr>
  3350. <tr>
  3351. <td id="L592" class="blob-num js-line-number" data-line-number="592"></td>
  3352. <td id="LC592" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Token-bucket traffic policers are common (see &quot;An Internet-Wide Analysis of</span></td>
  3353. </tr>
  3354. <tr>
  3355. <td id="L593" class="blob-num js-line-number" data-line-number="593"></td>
  3356. <td id="LC593" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Traffic Policing&quot;, SIGCOMM 2016). BBR detects token-bucket policers and</span></td>
  3357. </tr>
  3358. <tr>
  3359. <td id="L594" class="blob-num js-line-number" data-line-number="594"></td>
  3360. <td id="LC594" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * explicitly models their policed rate, to reduce unnecessary losses. We</span></td>
  3361. </tr>
  3362. <tr>
  3363. <td id="L595" class="blob-num js-line-number" data-line-number="595"></td>
  3364. <td id="LC595" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * estimate that we&#39;re policed if we see 2 consecutive sampling intervals with</span></td>
  3365. </tr>
  3366. <tr>
  3367. <td id="L596" class="blob-num js-line-number" data-line-number="596"></td>
  3368. <td id="LC596" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * consistent throughput and high packet loss. If we think we&#39;re being policed,</span></td>
  3369. </tr>
  3370. <tr>
  3371. <td id="L597" class="blob-num js-line-number" data-line-number="597"></td>
  3372. <td id="LC597" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * set lt_bw to the &quot;long-term&quot; average delivery rate from those 2 intervals.</span></td>
  3373. </tr>
  3374. <tr>
  3375. <td id="L598" class="blob-num js-line-number" data-line-number="598"></td>
  3376. <td id="LC598" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  3377. </tr>
  3378. <tr>
  3379. <td id="L599" class="blob-num js-line-number" data-line-number="599"></td>
  3380. <td id="LC599" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_lt_bw_sampling</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  3381. </tr>
  3382. <tr>
  3383. <td id="L600" class="blob-num js-line-number" data-line-number="600"></td>
  3384. <td id="LC600" class="blob-code blob-code-inner js-file-line">{</td>
  3385. </tr>
  3386. <tr>
  3387. <td id="L601" class="blob-num js-line-number" data-line-number="601"></td>
  3388. <td id="LC601" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  3389. </tr>
  3390. <tr>
  3391. <td id="L602" class="blob-num js-line-number" data-line-number="602"></td>
  3392. <td id="LC602" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3393. </tr>
  3394. <tr>
  3395. <td id="L603" class="blob-num js-line-number" data-line-number="603"></td>
  3396. <td id="LC603" class="blob-code blob-code-inner js-file-line"> u32 lost, delivered;</td>
  3397. </tr>
  3398. <tr>
  3399. <td id="L604" class="blob-num js-line-number" data-line-number="604"></td>
  3400. <td id="LC604" class="blob-code blob-code-inner js-file-line"> u64 bw;</td>
  3401. </tr>
  3402. <tr>
  3403. <td id="L605" class="blob-num js-line-number" data-line-number="605"></td>
  3404. <td id="LC605" class="blob-code blob-code-inner js-file-line"> s32 t;</td>
  3405. </tr>
  3406. <tr>
  3407. <td id="L606" class="blob-num js-line-number" data-line-number="606"></td>
  3408. <td id="LC606" class="blob-code blob-code-inner js-file-line">
  3409. </td>
  3410. </tr>
  3411. <tr>
  3412. <td id="L607" class="blob-num js-line-number" data-line-number="607"></td>
  3413. <td id="LC607" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;lt_use_bw) { <span class="pl-c"><span class="pl-c">/*</span> already using long-term rate, lt_bw? <span class="pl-c">*/</span></span></td>
  3414. </tr>
  3415. <tr>
  3416. <td id="L608" class="blob-num js-line-number" data-line-number="608"></td>
  3417. <td id="LC608" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;mode == BBR_PROBE_BW &amp;&amp; bbr-&gt;round_start &amp;&amp;</td>
  3418. </tr>
  3419. <tr>
  3420. <td id="L609" class="blob-num js-line-number" data-line-number="609"></td>
  3421. <td id="LC609" class="blob-code blob-code-inner js-file-line"> ++bbr-&gt;lt_rtt_cnt &gt;= bbr_lt_bw_max_rtts) {</td>
  3422. </tr>
  3423. <tr>
  3424. <td id="L610" class="blob-num js-line-number" data-line-number="610"></td>
  3425. <td id="LC610" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling</span>(sk); <span class="pl-c"><span class="pl-c">/*</span> stop using lt_bw <span class="pl-c">*/</span></span></td>
  3426. </tr>
  3427. <tr>
  3428. <td id="L611" class="blob-num js-line-number" data-line-number="611"></td>
  3429. <td id="LC611" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_probe_bw_mode</span>(sk); <span class="pl-c"><span class="pl-c">/*</span> restart gain cycling <span class="pl-c">*/</span></span></td>
  3430. </tr>
  3431. <tr>
  3432. <td id="L612" class="blob-num js-line-number" data-line-number="612"></td>
  3433. <td id="LC612" class="blob-code blob-code-inner js-file-line"> }</td>
  3434. </tr>
  3435. <tr>
  3436. <td id="L613" class="blob-num js-line-number" data-line-number="613"></td>
  3437. <td id="LC613" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3438. </tr>
  3439. <tr>
  3440. <td id="L614" class="blob-num js-line-number" data-line-number="614"></td>
  3441. <td id="LC614" class="blob-code blob-code-inner js-file-line"> }</td>
  3442. </tr>
  3443. <tr>
  3444. <td id="L615" class="blob-num js-line-number" data-line-number="615"></td>
  3445. <td id="LC615" class="blob-code blob-code-inner js-file-line">
  3446. </td>
  3447. </tr>
  3448. <tr>
  3449. <td id="L616" class="blob-num js-line-number" data-line-number="616"></td>
  3450. <td id="LC616" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Wait for the first loss before sampling, to let the policer exhaust</span></td>
  3451. </tr>
  3452. <tr>
  3453. <td id="L617" class="blob-num js-line-number" data-line-number="617"></td>
  3454. <td id="LC617" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * its tokens and estimate the steady-state rate allowed by the policer.</span></td>
  3455. </tr>
  3456. <tr>
  3457. <td id="L618" class="blob-num js-line-number" data-line-number="618"></td>
  3458. <td id="LC618" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Starting samples earlier includes bursts that over-estimate the bw.</span></td>
  3459. </tr>
  3460. <tr>
  3461. <td id="L619" class="blob-num js-line-number" data-line-number="619"></td>
  3462. <td id="LC619" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  3463. </tr>
  3464. <tr>
  3465. <td id="L620" class="blob-num js-line-number" data-line-number="620"></td>
  3466. <td id="LC620" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!bbr-&gt;lt_is_sampling) {</td>
  3467. </tr>
  3468. <tr>
  3469. <td id="L621" class="blob-num js-line-number" data-line-number="621"></td>
  3470. <td id="LC621" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!rs-&gt;losses)</td>
  3471. </tr>
  3472. <tr>
  3473. <td id="L622" class="blob-num js-line-number" data-line-number="622"></td>
  3474. <td id="LC622" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3475. </tr>
  3476. <tr>
  3477. <td id="L623" class="blob-num js-line-number" data-line-number="623"></td>
  3478. <td id="LC623" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling_interval</span>(sk);</td>
  3479. </tr>
  3480. <tr>
  3481. <td id="L624" class="blob-num js-line-number" data-line-number="624"></td>
  3482. <td id="LC624" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_is_sampling = <span class="pl-c1">true</span>;</td>
  3483. </tr>
  3484. <tr>
  3485. <td id="L625" class="blob-num js-line-number" data-line-number="625"></td>
  3486. <td id="LC625" class="blob-code blob-code-inner js-file-line"> }</td>
  3487. </tr>
  3488. <tr>
  3489. <td id="L626" class="blob-num js-line-number" data-line-number="626"></td>
  3490. <td id="LC626" class="blob-code blob-code-inner js-file-line">
  3491. </td>
  3492. </tr>
  3493. <tr>
  3494. <td id="L627" class="blob-num js-line-number" data-line-number="627"></td>
  3495. <td id="LC627" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> To avoid underestimates, reset sampling if we run out of data. <span class="pl-c">*/</span></span></td>
  3496. </tr>
  3497. <tr>
  3498. <td id="L628" class="blob-num js-line-number" data-line-number="628"></td>
  3499. <td id="LC628" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (rs-&gt;is_app_limited) {</td>
  3500. </tr>
  3501. <tr>
  3502. <td id="L629" class="blob-num js-line-number" data-line-number="629"></td>
  3503. <td id="LC629" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling</span>(sk);</td>
  3504. </tr>
  3505. <tr>
  3506. <td id="L630" class="blob-num js-line-number" data-line-number="630"></td>
  3507. <td id="LC630" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3508. </tr>
  3509. <tr>
  3510. <td id="L631" class="blob-num js-line-number" data-line-number="631"></td>
  3511. <td id="LC631" class="blob-code blob-code-inner js-file-line"> }</td>
  3512. </tr>
  3513. <tr>
  3514. <td id="L632" class="blob-num js-line-number" data-line-number="632"></td>
  3515. <td id="LC632" class="blob-code blob-code-inner js-file-line">
  3516. </td>
  3517. </tr>
  3518. <tr>
  3519. <td id="L633" class="blob-num js-line-number" data-line-number="633"></td>
  3520. <td id="LC633" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;round_start)</td>
  3521. </tr>
  3522. <tr>
  3523. <td id="L634" class="blob-num js-line-number" data-line-number="634"></td>
  3524. <td id="LC634" class="blob-code blob-code-inner js-file-line"> bbr-&gt;lt_rtt_cnt++; <span class="pl-c"><span class="pl-c">/*</span> count round trips in this interval <span class="pl-c">*/</span></span></td>
  3525. </tr>
  3526. <tr>
  3527. <td id="L635" class="blob-num js-line-number" data-line-number="635"></td>
  3528. <td id="LC635" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;lt_rtt_cnt &lt; bbr_lt_intvl_min_rtts)</td>
  3529. </tr>
  3530. <tr>
  3531. <td id="L636" class="blob-num js-line-number" data-line-number="636"></td>
  3532. <td id="LC636" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>; <span class="pl-c"><span class="pl-c">/*</span> sampling interval needs to be longer <span class="pl-c">*/</span></span></td>
  3533. </tr>
  3534. <tr>
  3535. <td id="L637" class="blob-num js-line-number" data-line-number="637"></td>
  3536. <td id="LC637" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;lt_rtt_cnt &gt; <span class="pl-c1">4</span> * bbr_lt_intvl_min_rtts) {</td>
  3537. </tr>
  3538. <tr>
  3539. <td id="L638" class="blob-num js-line-number" data-line-number="638"></td>
  3540. <td id="LC638" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling</span>(sk); <span class="pl-c"><span class="pl-c">/*</span> interval is too long <span class="pl-c">*/</span></span></td>
  3541. </tr>
  3542. <tr>
  3543. <td id="L639" class="blob-num js-line-number" data-line-number="639"></td>
  3544. <td id="LC639" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3545. </tr>
  3546. <tr>
  3547. <td id="L640" class="blob-num js-line-number" data-line-number="640"></td>
  3548. <td id="LC640" class="blob-code blob-code-inner js-file-line"> }</td>
  3549. </tr>
  3550. <tr>
  3551. <td id="L641" class="blob-num js-line-number" data-line-number="641"></td>
  3552. <td id="LC641" class="blob-code blob-code-inner js-file-line">
  3553. </td>
  3554. </tr>
  3555. <tr>
  3556. <td id="L642" class="blob-num js-line-number" data-line-number="642"></td>
  3557. <td id="LC642" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> End sampling interval when a packet is lost, so we estimate the</span></td>
  3558. </tr>
  3559. <tr>
  3560. <td id="L643" class="blob-num js-line-number" data-line-number="643"></td>
  3561. <td id="LC643" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * policer tokens were exhausted. Stopping the sampling before the</span></td>
  3562. </tr>
  3563. <tr>
  3564. <td id="L644" class="blob-num js-line-number" data-line-number="644"></td>
  3565. <td id="LC644" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * tokens are exhausted under-estimates the policed rate.</span></td>
  3566. </tr>
  3567. <tr>
  3568. <td id="L645" class="blob-num js-line-number" data-line-number="645"></td>
  3569. <td id="LC645" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  3570. </tr>
  3571. <tr>
  3572. <td id="L646" class="blob-num js-line-number" data-line-number="646"></td>
  3573. <td id="LC646" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!rs-&gt;losses)</td>
  3574. </tr>
  3575. <tr>
  3576. <td id="L647" class="blob-num js-line-number" data-line-number="647"></td>
  3577. <td id="LC647" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3578. </tr>
  3579. <tr>
  3580. <td id="L648" class="blob-num js-line-number" data-line-number="648"></td>
  3581. <td id="LC648" class="blob-code blob-code-inner js-file-line">
  3582. </td>
  3583. </tr>
  3584. <tr>
  3585. <td id="L649" class="blob-num js-line-number" data-line-number="649"></td>
  3586. <td id="LC649" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Calculate packets lost and delivered in sampling interval. <span class="pl-c">*/</span></span></td>
  3587. </tr>
  3588. <tr>
  3589. <td id="L650" class="blob-num js-line-number" data-line-number="650"></td>
  3590. <td id="LC650" class="blob-code blob-code-inner js-file-line"> lost = tp-&gt;lost - bbr-&gt;lt_last_lost;</td>
  3591. </tr>
  3592. <tr>
  3593. <td id="L651" class="blob-num js-line-number" data-line-number="651"></td>
  3594. <td id="LC651" class="blob-code blob-code-inner js-file-line"> delivered = tp-&gt;delivered - bbr-&gt;lt_last_delivered;</td>
  3595. </tr>
  3596. <tr>
  3597. <td id="L652" class="blob-num js-line-number" data-line-number="652"></td>
  3598. <td id="LC652" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Is loss rate (lost/delivered) &gt;= lt_loss_thresh? If not, wait. <span class="pl-c">*/</span></span></td>
  3599. </tr>
  3600. <tr>
  3601. <td id="L653" class="blob-num js-line-number" data-line-number="653"></td>
  3602. <td id="LC653" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!delivered || (lost &lt;&lt; BBR_SCALE) &lt; bbr_lt_loss_thresh * delivered)</td>
  3603. </tr>
  3604. <tr>
  3605. <td id="L654" class="blob-num js-line-number" data-line-number="654"></td>
  3606. <td id="LC654" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3607. </tr>
  3608. <tr>
  3609. <td id="L655" class="blob-num js-line-number" data-line-number="655"></td>
  3610. <td id="LC655" class="blob-code blob-code-inner js-file-line">
  3611. </td>
  3612. </tr>
  3613. <tr>
  3614. <td id="L656" class="blob-num js-line-number" data-line-number="656"></td>
  3615. <td id="LC656" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Find average delivery rate in this sampling interval. <span class="pl-c">*/</span></span></td>
  3616. </tr>
  3617. <tr>
  3618. <td id="L657" class="blob-num js-line-number" data-line-number="657"></td>
  3619. <td id="LC657" class="blob-code blob-code-inner js-file-line"> t = (s32)(tp-&gt;delivered_mstamp.<span class="pl-smi">stamp_jiffies</span> - bbr-&gt;lt_last_stamp);</td>
  3620. </tr>
  3621. <tr>
  3622. <td id="L658" class="blob-num js-line-number" data-line-number="658"></td>
  3623. <td id="LC658" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (t &lt; <span class="pl-c1">1</span>)</td>
  3624. </tr>
  3625. <tr>
  3626. <td id="L659" class="blob-num js-line-number" data-line-number="659"></td>
  3627. <td id="LC659" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>; <span class="pl-c"><span class="pl-c">/*</span> interval is less than one jiffy, so wait <span class="pl-c">*/</span></span></td>
  3628. </tr>
  3629. <tr>
  3630. <td id="L660" class="blob-num js-line-number" data-line-number="660"></td>
  3631. <td id="LC660" class="blob-code blob-code-inner js-file-line"> t = <span class="pl-c1">jiffies_to_usecs</span>(t);</td>
  3632. </tr>
  3633. <tr>
  3634. <td id="L661" class="blob-num js-line-number" data-line-number="661"></td>
  3635. <td id="LC661" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Interval long enough for jiffies_to_usecs() to return a bogus 0? <span class="pl-c">*/</span></span></td>
  3636. </tr>
  3637. <tr>
  3638. <td id="L662" class="blob-num js-line-number" data-line-number="662"></td>
  3639. <td id="LC662" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (t &lt; <span class="pl-c1">1</span>) {</td>
  3640. </tr>
  3641. <tr>
  3642. <td id="L663" class="blob-num js-line-number" data-line-number="663"></td>
  3643. <td id="LC663" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling</span>(sk); <span class="pl-c"><span class="pl-c">/*</span> interval too long; reset <span class="pl-c">*/</span></span></td>
  3644. </tr>
  3645. <tr>
  3646. <td id="L664" class="blob-num js-line-number" data-line-number="664"></td>
  3647. <td id="LC664" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3648. </tr>
  3649. <tr>
  3650. <td id="L665" class="blob-num js-line-number" data-line-number="665"></td>
  3651. <td id="LC665" class="blob-code blob-code-inner js-file-line"> }</td>
  3652. </tr>
  3653. <tr>
  3654. <td id="L666" class="blob-num js-line-number" data-line-number="666"></td>
  3655. <td id="LC666" class="blob-code blob-code-inner js-file-line"> bw = (u64)delivered * BW_UNIT;</td>
  3656. </tr>
  3657. <tr>
  3658. <td id="L667" class="blob-num js-line-number" data-line-number="667"></td>
  3659. <td id="LC667" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">do_div</span>(bw, t);</td>
  3660. </tr>
  3661. <tr>
  3662. <td id="L668" class="blob-num js-line-number" data-line-number="668"></td>
  3663. <td id="LC668" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_lt_bw_interval_done</span>(sk, bw);</td>
  3664. </tr>
  3665. <tr>
  3666. <td id="L669" class="blob-num js-line-number" data-line-number="669"></td>
  3667. <td id="LC669" class="blob-code blob-code-inner js-file-line">}</td>
  3668. </tr>
  3669. <tr>
  3670. <td id="L670" class="blob-num js-line-number" data-line-number="670"></td>
  3671. <td id="LC670" class="blob-code blob-code-inner js-file-line">
  3672. </td>
  3673. </tr>
  3674. <tr>
  3675. <td id="L671" class="blob-num js-line-number" data-line-number="671"></td>
  3676. <td id="LC671" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Estimate the bandwidth based on how fast packets are delivered <span class="pl-c">*/</span></span></td>
  3677. </tr>
  3678. <tr>
  3679. <td id="L672" class="blob-num js-line-number" data-line-number="672"></td>
  3680. <td id="LC672" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_update_bw</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  3681. </tr>
  3682. <tr>
  3683. <td id="L673" class="blob-num js-line-number" data-line-number="673"></td>
  3684. <td id="LC673" class="blob-code blob-code-inner js-file-line">{</td>
  3685. </tr>
  3686. <tr>
  3687. <td id="L674" class="blob-num js-line-number" data-line-number="674"></td>
  3688. <td id="LC674" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  3689. </tr>
  3690. <tr>
  3691. <td id="L675" class="blob-num js-line-number" data-line-number="675"></td>
  3692. <td id="LC675" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3693. </tr>
  3694. <tr>
  3695. <td id="L676" class="blob-num js-line-number" data-line-number="676"></td>
  3696. <td id="LC676" class="blob-code blob-code-inner js-file-line"> u64 bw;</td>
  3697. </tr>
  3698. <tr>
  3699. <td id="L677" class="blob-num js-line-number" data-line-number="677"></td>
  3700. <td id="LC677" class="blob-code blob-code-inner js-file-line">
  3701. </td>
  3702. </tr>
  3703. <tr>
  3704. <td id="L678" class="blob-num js-line-number" data-line-number="678"></td>
  3705. <td id="LC678" class="blob-code blob-code-inner js-file-line"> bbr-&gt;round_start = <span class="pl-c1">0</span>;</td>
  3706. </tr>
  3707. <tr>
  3708. <td id="L679" class="blob-num js-line-number" data-line-number="679"></td>
  3709. <td id="LC679" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (rs-&gt;delivered &lt; <span class="pl-c1">0</span> || rs-&gt;interval_us &lt;= <span class="pl-c1">0</span>)</td>
  3710. </tr>
  3711. <tr>
  3712. <td id="L680" class="blob-num js-line-number" data-line-number="680"></td>
  3713. <td id="LC680" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>; <span class="pl-c"><span class="pl-c">/*</span> Not a valid observation <span class="pl-c">*/</span></span></td>
  3714. </tr>
  3715. <tr>
  3716. <td id="L681" class="blob-num js-line-number" data-line-number="681"></td>
  3717. <td id="LC681" class="blob-code blob-code-inner js-file-line">
  3718. </td>
  3719. </tr>
  3720. <tr>
  3721. <td id="L682" class="blob-num js-line-number" data-line-number="682"></td>
  3722. <td id="LC682" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> See if we&#39;ve reached the next RTT <span class="pl-c">*/</span></span></td>
  3723. </tr>
  3724. <tr>
  3725. <td id="L683" class="blob-num js-line-number" data-line-number="683"></td>
  3726. <td id="LC683" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!<span class="pl-c1">before</span>(rs-&gt;prior_delivered, bbr-&gt;next_rtt_delivered)) {</td>
  3727. </tr>
  3728. <tr>
  3729. <td id="L684" class="blob-num js-line-number" data-line-number="684"></td>
  3730. <td id="LC684" class="blob-code blob-code-inner js-file-line"> bbr-&gt;next_rtt_delivered = tp-&gt;delivered;</td>
  3731. </tr>
  3732. <tr>
  3733. <td id="L685" class="blob-num js-line-number" data-line-number="685"></td>
  3734. <td id="LC685" class="blob-code blob-code-inner js-file-line"> bbr-&gt;rtt_cnt++;</td>
  3735. </tr>
  3736. <tr>
  3737. <td id="L686" class="blob-num js-line-number" data-line-number="686"></td>
  3738. <td id="LC686" class="blob-code blob-code-inner js-file-line"> bbr-&gt;round_start = <span class="pl-c1">1</span>;</td>
  3739. </tr>
  3740. <tr>
  3741. <td id="L687" class="blob-num js-line-number" data-line-number="687"></td>
  3742. <td id="LC687" class="blob-code blob-code-inner js-file-line"> bbr-&gt;packet_conservation = <span class="pl-c1">0</span>;</td>
  3743. </tr>
  3744. <tr>
  3745. <td id="L688" class="blob-num js-line-number" data-line-number="688"></td>
  3746. <td id="LC688" class="blob-code blob-code-inner js-file-line"> }</td>
  3747. </tr>
  3748. <tr>
  3749. <td id="L689" class="blob-num js-line-number" data-line-number="689"></td>
  3750. <td id="LC689" class="blob-code blob-code-inner js-file-line">
  3751. </td>
  3752. </tr>
  3753. <tr>
  3754. <td id="L690" class="blob-num js-line-number" data-line-number="690"></td>
  3755. <td id="LC690" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_lt_bw_sampling</span>(sk, rs);</td>
  3756. </tr>
  3757. <tr>
  3758. <td id="L691" class="blob-num js-line-number" data-line-number="691"></td>
  3759. <td id="LC691" class="blob-code blob-code-inner js-file-line">
  3760. </td>
  3761. </tr>
  3762. <tr>
  3763. <td id="L692" class="blob-num js-line-number" data-line-number="692"></td>
  3764. <td id="LC692" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Divide delivered by the interval to find a (lower bound) bottleneck</span></td>
  3765. </tr>
  3766. <tr>
  3767. <td id="L693" class="blob-num js-line-number" data-line-number="693"></td>
  3768. <td id="LC693" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * bandwidth sample. Delivered is in packets and interval_us in uS and</span></td>
  3769. </tr>
  3770. <tr>
  3771. <td id="L694" class="blob-num js-line-number" data-line-number="694"></td>
  3772. <td id="LC694" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * ratio will be &lt;&lt;1 for most connections. So delivered is first scaled.</span></td>
  3773. </tr>
  3774. <tr>
  3775. <td id="L695" class="blob-num js-line-number" data-line-number="695"></td>
  3776. <td id="LC695" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  3777. </tr>
  3778. <tr>
  3779. <td id="L696" class="blob-num js-line-number" data-line-number="696"></td>
  3780. <td id="LC696" class="blob-code blob-code-inner js-file-line"> bw = (u64)rs-&gt;delivered * BW_UNIT;</td>
  3781. </tr>
  3782. <tr>
  3783. <td id="L697" class="blob-num js-line-number" data-line-number="697"></td>
  3784. <td id="LC697" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">do_div</span>(bw, rs-&gt;interval_us);</td>
  3785. </tr>
  3786. <tr>
  3787. <td id="L698" class="blob-num js-line-number" data-line-number="698"></td>
  3788. <td id="LC698" class="blob-code blob-code-inner js-file-line">
  3789. </td>
  3790. </tr>
  3791. <tr>
  3792. <td id="L699" class="blob-num js-line-number" data-line-number="699"></td>
  3793. <td id="LC699" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> If this sample is application-limited, it is likely to have a very</span></td>
  3794. </tr>
  3795. <tr>
  3796. <td id="L700" class="blob-num js-line-number" data-line-number="700"></td>
  3797. <td id="LC700" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * low delivered count that represents application behavior rather than</span></td>
  3798. </tr>
  3799. <tr>
  3800. <td id="L701" class="blob-num js-line-number" data-line-number="701"></td>
  3801. <td id="LC701" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * the available network rate. Such a sample could drag down estimated</span></td>
  3802. </tr>
  3803. <tr>
  3804. <td id="L702" class="blob-num js-line-number" data-line-number="702"></td>
  3805. <td id="LC702" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * bw, causing needless slow-down. Thus, to continue to send at the</span></td>
  3806. </tr>
  3807. <tr>
  3808. <td id="L703" class="blob-num js-line-number" data-line-number="703"></td>
  3809. <td id="LC703" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * last measured network rate, we filter out app-limited samples unless</span></td>
  3810. </tr>
  3811. <tr>
  3812. <td id="L704" class="blob-num js-line-number" data-line-number="704"></td>
  3813. <td id="LC704" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * they describe the path bw at least as well as our bw model.</span></td>
  3814. </tr>
  3815. <tr>
  3816. <td id="L705" class="blob-num js-line-number" data-line-number="705"></td>
  3817. <td id="LC705" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  3818. </tr>
  3819. <tr>
  3820. <td id="L706" class="blob-num js-line-number" data-line-number="706"></td>
  3821. <td id="LC706" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * So the goal during app-limited phase is to proceed with the best</span></td>
  3822. </tr>
  3823. <tr>
  3824. <td id="L707" class="blob-num js-line-number" data-line-number="707"></td>
  3825. <td id="LC707" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * network rate no matter how long. We automatically leave this</span></td>
  3826. </tr>
  3827. <tr>
  3828. <td id="L708" class="blob-num js-line-number" data-line-number="708"></td>
  3829. <td id="LC708" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * phase when app writes faster than the network can deliver :)</span></td>
  3830. </tr>
  3831. <tr>
  3832. <td id="L709" class="blob-num js-line-number" data-line-number="709"></td>
  3833. <td id="LC709" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  3834. </tr>
  3835. <tr>
  3836. <td id="L710" class="blob-num js-line-number" data-line-number="710"></td>
  3837. <td id="LC710" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!rs-&gt;is_app_limited || bw &gt;= <span class="pl-c1">bbr_max_bw</span>(sk)) {</td>
  3838. </tr>
  3839. <tr>
  3840. <td id="L711" class="blob-num js-line-number" data-line-number="711"></td>
  3841. <td id="LC711" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Incorporate new sample into our max bw filter. <span class="pl-c">*/</span></span></td>
  3842. </tr>
  3843. <tr>
  3844. <td id="L712" class="blob-num js-line-number" data-line-number="712"></td>
  3845. <td id="LC712" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">minmax_running_max</span>(&amp;bbr-&gt;bw, bbr_bw_rtts, bbr-&gt;rtt_cnt, bw);</td>
  3846. </tr>
  3847. <tr>
  3848. <td id="L713" class="blob-num js-line-number" data-line-number="713"></td>
  3849. <td id="LC713" class="blob-code blob-code-inner js-file-line"> }</td>
  3850. </tr>
  3851. <tr>
  3852. <td id="L714" class="blob-num js-line-number" data-line-number="714"></td>
  3853. <td id="LC714" class="blob-code blob-code-inner js-file-line">}</td>
  3854. </tr>
  3855. <tr>
  3856. <td id="L715" class="blob-num js-line-number" data-line-number="715"></td>
  3857. <td id="LC715" class="blob-code blob-code-inner js-file-line">
  3858. </td>
  3859. </tr>
  3860. <tr>
  3861. <td id="L716" class="blob-num js-line-number" data-line-number="716"></td>
  3862. <td id="LC716" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Estimate when the pipe is full, using the change in delivery rate: BBR</span></td>
  3863. </tr>
  3864. <tr>
  3865. <td id="L717" class="blob-num js-line-number" data-line-number="717"></td>
  3866. <td id="LC717" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * estimates that STARTUP filled the pipe if the estimated bw hasn&#39;t changed by</span></td>
  3867. </tr>
  3868. <tr>
  3869. <td id="L718" class="blob-num js-line-number" data-line-number="718"></td>
  3870. <td id="LC718" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * at least bbr_full_bw_thresh (25%) after bbr_full_bw_cnt (3) non-app-limited</span></td>
  3871. </tr>
  3872. <tr>
  3873. <td id="L719" class="blob-num js-line-number" data-line-number="719"></td>
  3874. <td id="LC719" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * rounds. Why 3 rounds: 1: rwin autotuning grows the rwin, 2: we fill the</span></td>
  3875. </tr>
  3876. <tr>
  3877. <td id="L720" class="blob-num js-line-number" data-line-number="720"></td>
  3878. <td id="LC720" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * higher rwin, 3: we get higher delivery rate samples. Or transient</span></td>
  3879. </tr>
  3880. <tr>
  3881. <td id="L721" class="blob-num js-line-number" data-line-number="721"></td>
  3882. <td id="LC721" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * cross-traffic or radio noise can go away. CUBIC Hystart shares a similar</span></td>
  3883. </tr>
  3884. <tr>
  3885. <td id="L722" class="blob-num js-line-number" data-line-number="722"></td>
  3886. <td id="LC722" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * design goal, but uses delay and inter-ACK spacing instead of bandwidth.</span></td>
  3887. </tr>
  3888. <tr>
  3889. <td id="L723" class="blob-num js-line-number" data-line-number="723"></td>
  3890. <td id="LC723" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  3891. </tr>
  3892. <tr>
  3893. <td id="L724" class="blob-num js-line-number" data-line-number="724"></td>
  3894. <td id="LC724" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_check_full_bw_reached</span>(<span class="pl-k">struct</span> sock *sk,</td>
  3895. </tr>
  3896. <tr>
  3897. <td id="L725" class="blob-num js-line-number" data-line-number="725"></td>
  3898. <td id="LC725" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  3899. </tr>
  3900. <tr>
  3901. <td id="L726" class="blob-num js-line-number" data-line-number="726"></td>
  3902. <td id="LC726" class="blob-code blob-code-inner js-file-line">{</td>
  3903. </tr>
  3904. <tr>
  3905. <td id="L727" class="blob-num js-line-number" data-line-number="727"></td>
  3906. <td id="LC727" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3907. </tr>
  3908. <tr>
  3909. <td id="L728" class="blob-num js-line-number" data-line-number="728"></td>
  3910. <td id="LC728" class="blob-code blob-code-inner js-file-line"> u32 bw_thresh;</td>
  3911. </tr>
  3912. <tr>
  3913. <td id="L729" class="blob-num js-line-number" data-line-number="729"></td>
  3914. <td id="LC729" class="blob-code blob-code-inner js-file-line">
  3915. </td>
  3916. </tr>
  3917. <tr>
  3918. <td id="L730" class="blob-num js-line-number" data-line-number="730"></td>
  3919. <td id="LC730" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (<span class="pl-c1">bbr_full_bw_reached</span>(sk) || !bbr-&gt;round_start || rs-&gt;is_app_limited)</td>
  3920. </tr>
  3921. <tr>
  3922. <td id="L731" class="blob-num js-line-number" data-line-number="731"></td>
  3923. <td id="LC731" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3924. </tr>
  3925. <tr>
  3926. <td id="L732" class="blob-num js-line-number" data-line-number="732"></td>
  3927. <td id="LC732" class="blob-code blob-code-inner js-file-line">
  3928. </td>
  3929. </tr>
  3930. <tr>
  3931. <td id="L733" class="blob-num js-line-number" data-line-number="733"></td>
  3932. <td id="LC733" class="blob-code blob-code-inner js-file-line"> bw_thresh = (u64)bbr-&gt;full_bw * bbr_full_bw_thresh &gt;&gt; BBR_SCALE;</td>
  3933. </tr>
  3934. <tr>
  3935. <td id="L734" class="blob-num js-line-number" data-line-number="734"></td>
  3936. <td id="LC734" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (<span class="pl-c1">bbr_max_bw</span>(sk) &gt;= bw_thresh) {</td>
  3937. </tr>
  3938. <tr>
  3939. <td id="L735" class="blob-num js-line-number" data-line-number="735"></td>
  3940. <td id="LC735" class="blob-code blob-code-inner js-file-line"> bbr-&gt;full_bw = <span class="pl-c1">bbr_max_bw</span>(sk);</td>
  3941. </tr>
  3942. <tr>
  3943. <td id="L736" class="blob-num js-line-number" data-line-number="736"></td>
  3944. <td id="LC736" class="blob-code blob-code-inner js-file-line"> bbr-&gt;full_bw_cnt = <span class="pl-c1">0</span>;</td>
  3945. </tr>
  3946. <tr>
  3947. <td id="L737" class="blob-num js-line-number" data-line-number="737"></td>
  3948. <td id="LC737" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span>;</td>
  3949. </tr>
  3950. <tr>
  3951. <td id="L738" class="blob-num js-line-number" data-line-number="738"></td>
  3952. <td id="LC738" class="blob-code blob-code-inner js-file-line"> }</td>
  3953. </tr>
  3954. <tr>
  3955. <td id="L739" class="blob-num js-line-number" data-line-number="739"></td>
  3956. <td id="LC739" class="blob-code blob-code-inner js-file-line"> ++bbr-&gt;full_bw_cnt;</td>
  3957. </tr>
  3958. <tr>
  3959. <td id="L740" class="blob-num js-line-number" data-line-number="740"></td>
  3960. <td id="LC740" class="blob-code blob-code-inner js-file-line">}</td>
  3961. </tr>
  3962. <tr>
  3963. <td id="L741" class="blob-num js-line-number" data-line-number="741"></td>
  3964. <td id="LC741" class="blob-code blob-code-inner js-file-line">
  3965. </td>
  3966. </tr>
  3967. <tr>
  3968. <td id="L742" class="blob-num js-line-number" data-line-number="742"></td>
  3969. <td id="LC742" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> If pipe is probably full, drain the queue and then enter steady-state. <span class="pl-c">*/</span></span></td>
  3970. </tr>
  3971. <tr>
  3972. <td id="L743" class="blob-num js-line-number" data-line-number="743"></td>
  3973. <td id="LC743" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_check_drain</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  3974. </tr>
  3975. <tr>
  3976. <td id="L744" class="blob-num js-line-number" data-line-number="744"></td>
  3977. <td id="LC744" class="blob-code blob-code-inner js-file-line">{</td>
  3978. </tr>
  3979. <tr>
  3980. <td id="L745" class="blob-num js-line-number" data-line-number="745"></td>
  3981. <td id="LC745" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  3982. </tr>
  3983. <tr>
  3984. <td id="L746" class="blob-num js-line-number" data-line-number="746"></td>
  3985. <td id="LC746" class="blob-code blob-code-inner js-file-line">
  3986. </td>
  3987. </tr>
  3988. <tr>
  3989. <td id="L747" class="blob-num js-line-number" data-line-number="747"></td>
  3990. <td id="LC747" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;mode == BBR_STARTUP &amp;&amp; <span class="pl-c1">bbr_full_bw_reached</span>(sk)) {</td>
  3991. </tr>
  3992. <tr>
  3993. <td id="L748" class="blob-num js-line-number" data-line-number="748"></td>
  3994. <td id="LC748" class="blob-code blob-code-inner js-file-line"> bbr-&gt;mode = BBR_DRAIN; <span class="pl-c"><span class="pl-c">/*</span> drain queue we created <span class="pl-c">*/</span></span></td>
  3995. </tr>
  3996. <tr>
  3997. <td id="L749" class="blob-num js-line-number" data-line-number="749"></td>
  3998. <td id="LC749" class="blob-code blob-code-inner js-file-line"> bbr-&gt;pacing_gain = bbr_drain_gain; <span class="pl-c"><span class="pl-c">/*</span> pace slow to drain <span class="pl-c">*/</span></span></td>
  3999. </tr>
  4000. <tr>
  4001. <td id="L750" class="blob-num js-line-number" data-line-number="750"></td>
  4002. <td id="LC750" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cwnd_gain = bbr_high_gain; <span class="pl-c"><span class="pl-c">/*</span> maintain cwnd <span class="pl-c">*/</span></span></td>
  4003. </tr>
  4004. <tr>
  4005. <td id="L751" class="blob-num js-line-number" data-line-number="751"></td>
  4006. <td id="LC751" class="blob-code blob-code-inner js-file-line"> } <span class="pl-c"><span class="pl-c">/*</span> fall through to check if in-flight is already small: <span class="pl-c">*/</span></span></td>
  4007. </tr>
  4008. <tr>
  4009. <td id="L752" class="blob-num js-line-number" data-line-number="752"></td>
  4010. <td id="LC752" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;mode == BBR_DRAIN &amp;&amp;</td>
  4011. </tr>
  4012. <tr>
  4013. <td id="L753" class="blob-num js-line-number" data-line-number="753"></td>
  4014. <td id="LC753" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">tcp_packets_in_flight</span>(<span class="pl-c1">tcp_sk</span>(sk)) &lt;=</td>
  4015. </tr>
  4016. <tr>
  4017. <td id="L754" class="blob-num js-line-number" data-line-number="754"></td>
  4018. <td id="LC754" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_target_cwnd</span>(sk, <span class="pl-c1">bbr_max_bw</span>(sk), BBR_UNIT))</td>
  4019. </tr>
  4020. <tr>
  4021. <td id="L755" class="blob-num js-line-number" data-line-number="755"></td>
  4022. <td id="LC755" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_probe_bw_mode</span>(sk); <span class="pl-c"><span class="pl-c">/*</span> we estimate queue is drained <span class="pl-c">*/</span></span></td>
  4023. </tr>
  4024. <tr>
  4025. <td id="L756" class="blob-num js-line-number" data-line-number="756"></td>
  4026. <td id="LC756" class="blob-code blob-code-inner js-file-line">}</td>
  4027. </tr>
  4028. <tr>
  4029. <td id="L757" class="blob-num js-line-number" data-line-number="757"></td>
  4030. <td id="LC757" class="blob-code blob-code-inner js-file-line">
  4031. </td>
  4032. </tr>
  4033. <tr>
  4034. <td id="L758" class="blob-num js-line-number" data-line-number="758"></td>
  4035. <td id="LC758" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> The goal of PROBE_RTT mode is to have BBR flows cooperatively and</span></td>
  4036. </tr>
  4037. <tr>
  4038. <td id="L759" class="blob-num js-line-number" data-line-number="759"></td>
  4039. <td id="LC759" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * periodically drain the bottleneck queue, to converge to measure the true</span></td>
  4040. </tr>
  4041. <tr>
  4042. <td id="L760" class="blob-num js-line-number" data-line-number="760"></td>
  4043. <td id="LC760" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * min_rtt (unloaded propagation delay). This allows the flows to keep queues</span></td>
  4044. </tr>
  4045. <tr>
  4046. <td id="L761" class="blob-num js-line-number" data-line-number="761"></td>
  4047. <td id="LC761" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * small (reducing queuing delay and packet loss) and achieve fairness among</span></td>
  4048. </tr>
  4049. <tr>
  4050. <td id="L762" class="blob-num js-line-number" data-line-number="762"></td>
  4051. <td id="LC762" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * BBR flows.</span></td>
  4052. </tr>
  4053. <tr>
  4054. <td id="L763" class="blob-num js-line-number" data-line-number="763"></td>
  4055. <td id="LC763" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  4056. </tr>
  4057. <tr>
  4058. <td id="L764" class="blob-num js-line-number" data-line-number="764"></td>
  4059. <td id="LC764" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * The min_rtt filter window is 10 seconds. When the min_rtt estimate expires,</span></td>
  4060. </tr>
  4061. <tr>
  4062. <td id="L765" class="blob-num js-line-number" data-line-number="765"></td>
  4063. <td id="LC765" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * we enter PROBE_RTT mode and cap the cwnd at bbr_cwnd_min_target=4 packets.</span></td>
  4064. </tr>
  4065. <tr>
  4066. <td id="L766" class="blob-num js-line-number" data-line-number="766"></td>
  4067. <td id="LC766" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * After at least bbr_probe_rtt_mode_ms=200ms and at least one packet-timed</span></td>
  4068. </tr>
  4069. <tr>
  4070. <td id="L767" class="blob-num js-line-number" data-line-number="767"></td>
  4071. <td id="LC767" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * round trip elapsed with that flight size &lt;= 4, we leave PROBE_RTT mode and</span></td>
  4072. </tr>
  4073. <tr>
  4074. <td id="L768" class="blob-num js-line-number" data-line-number="768"></td>
  4075. <td id="LC768" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * re-enter the previous mode. BBR uses 200ms to approximately bound the</span></td>
  4076. </tr>
  4077. <tr>
  4078. <td id="L769" class="blob-num js-line-number" data-line-number="769"></td>
  4079. <td id="LC769" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * performance penalty of PROBE_RTT&#39;s cwnd capping to roughly 2% (200ms/10s).</span></td>
  4080. </tr>
  4081. <tr>
  4082. <td id="L770" class="blob-num js-line-number" data-line-number="770"></td>
  4083. <td id="LC770" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> *</span></td>
  4084. </tr>
  4085. <tr>
  4086. <td id="L771" class="blob-num js-line-number" data-line-number="771"></td>
  4087. <td id="LC771" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * Note that flows need only pay 2% if they are busy sending over the last 10</span></td>
  4088. </tr>
  4089. <tr>
  4090. <td id="L772" class="blob-num js-line-number" data-line-number="772"></td>
  4091. <td id="LC772" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * seconds. Interactive applications (e.g., Web, RPCs, video chunks) often have</span></td>
  4092. </tr>
  4093. <tr>
  4094. <td id="L773" class="blob-num js-line-number" data-line-number="773"></td>
  4095. <td id="LC773" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * natural silences or low-rate periods within 10 seconds where the rate is low</span></td>
  4096. </tr>
  4097. <tr>
  4098. <td id="L774" class="blob-num js-line-number" data-line-number="774"></td>
  4099. <td id="LC774" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * enough for long enough to drain its queue in the bottleneck. We pick up</span></td>
  4100. </tr>
  4101. <tr>
  4102. <td id="L775" class="blob-num js-line-number" data-line-number="775"></td>
  4103. <td id="LC775" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * these min RTT measurements opportunistically with our min_rtt filter. :-)</span></td>
  4104. </tr>
  4105. <tr>
  4106. <td id="L776" class="blob-num js-line-number" data-line-number="776"></td>
  4107. <td id="LC776" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  4108. </tr>
  4109. <tr>
  4110. <td id="L777" class="blob-num js-line-number" data-line-number="777"></td>
  4111. <td id="LC777" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_update_min_rtt</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  4112. </tr>
  4113. <tr>
  4114. <td id="L778" class="blob-num js-line-number" data-line-number="778"></td>
  4115. <td id="LC778" class="blob-code blob-code-inner js-file-line">{</td>
  4116. </tr>
  4117. <tr>
  4118. <td id="L779" class="blob-num js-line-number" data-line-number="779"></td>
  4119. <td id="LC779" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  4120. </tr>
  4121. <tr>
  4122. <td id="L780" class="blob-num js-line-number" data-line-number="780"></td>
  4123. <td id="LC780" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  4124. </tr>
  4125. <tr>
  4126. <td id="L781" class="blob-num js-line-number" data-line-number="781"></td>
  4127. <td id="LC781" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">bool</span> filter_expired;</td>
  4128. </tr>
  4129. <tr>
  4130. <td id="L782" class="blob-num js-line-number" data-line-number="782"></td>
  4131. <td id="LC782" class="blob-code blob-code-inner js-file-line">
  4132. </td>
  4133. </tr>
  4134. <tr>
  4135. <td id="L783" class="blob-num js-line-number" data-line-number="783"></td>
  4136. <td id="LC783" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Track min RTT seen in the min_rtt_win_sec filter window: <span class="pl-c">*/</span></span></td>
  4137. </tr>
  4138. <tr>
  4139. <td id="L784" class="blob-num js-line-number" data-line-number="784"></td>
  4140. <td id="LC784" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">//</span> as above BBR_Structure define: &quot;min_rtt_win_sec = 5 seconds&quot;</span></td>
  4141. </tr>
  4142. <tr>
  4143. <td id="L785" class="blob-num js-line-number" data-line-number="785"></td>
  4144. <td id="LC785" class="blob-code blob-code-inner js-file-line"> filter_expired = <span class="pl-c1">after</span>(tcp_time_stamp,</td>
  4145. </tr>
  4146. <tr>
  4147. <td id="L786" class="blob-num js-line-number" data-line-number="786"></td>
  4148. <td id="LC786" class="blob-code blob-code-inner js-file-line"> bbr-&gt;min_rtt_stamp + bbr_min_rtt_win_sec * HZ);</td>
  4149. </tr>
  4150. <tr>
  4151. <td id="L787" class="blob-num js-line-number" data-line-number="787"></td>
  4152. <td id="LC787" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (rs-&gt;rtt_us &gt;= <span class="pl-c1">0</span> &amp;&amp;</td>
  4153. </tr>
  4154. <tr>
  4155. <td id="L788" class="blob-num js-line-number" data-line-number="788"></td>
  4156. <td id="LC788" class="blob-code blob-code-inner js-file-line"> (rs-&gt;rtt_us &lt;= bbr-&gt;min_rtt_us || filter_expired)) {</td>
  4157. </tr>
  4158. <tr>
  4159. <td id="L789" class="blob-num js-line-number" data-line-number="789"></td>
  4160. <td id="LC789" class="blob-code blob-code-inner js-file-line"> bbr-&gt;min_rtt_us = rs-&gt;rtt_us;</td>
  4161. </tr>
  4162. <tr>
  4163. <td id="L790" class="blob-num js-line-number" data-line-number="790"></td>
  4164. <td id="LC790" class="blob-code blob-code-inner js-file-line"> bbr-&gt;min_rtt_stamp = tcp_time_stamp;</td>
  4165. </tr>
  4166. <tr>
  4167. <td id="L791" class="blob-num js-line-number" data-line-number="791"></td>
  4168. <td id="LC791" class="blob-code blob-code-inner js-file-line"> }</td>
  4169. </tr>
  4170. <tr>
  4171. <td id="L792" class="blob-num js-line-number" data-line-number="792"></td>
  4172. <td id="LC792" class="blob-code blob-code-inner js-file-line">
  4173. </td>
  4174. </tr>
  4175. <tr>
  4176. <td id="L793" class="blob-num js-line-number" data-line-number="793"></td>
  4177. <td id="LC793" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr_probe_rtt_mode_ms &gt; <span class="pl-c1">0</span> &amp;&amp; filter_expired &amp;&amp;</td>
  4178. </tr>
  4179. <tr>
  4180. <td id="L794" class="blob-num js-line-number" data-line-number="794"></td>
  4181. <td id="LC794" class="blob-code blob-code-inner js-file-line"> !bbr-&gt;idle_restart &amp;&amp; bbr-&gt;mode != BBR_PROBE_RTT) {</td>
  4182. </tr>
  4183. <tr>
  4184. <td id="L795" class="blob-num js-line-number" data-line-number="795"></td>
  4185. <td id="LC795" class="blob-code blob-code-inner js-file-line"> bbr-&gt;mode = BBR_PROBE_RTT; <span class="pl-c"><span class="pl-c">/*</span> dip, drain queue <span class="pl-c">*/</span></span></td>
  4186. </tr>
  4187. <tr>
  4188. <td id="L796" class="blob-num js-line-number" data-line-number="796"></td>
  4189. <td id="LC796" class="blob-code blob-code-inner js-file-line"> bbr-&gt;pacing_gain = BBR_UNIT;</td>
  4190. </tr>
  4191. <tr>
  4192. <td id="L797" class="blob-num js-line-number" data-line-number="797"></td>
  4193. <td id="LC797" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cwnd_gain = BBR_UNIT;</td>
  4194. </tr>
  4195. <tr>
  4196. <td id="L798" class="blob-num js-line-number" data-line-number="798"></td>
  4197. <td id="LC798" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_save_cwnd</span>(sk); <span class="pl-c"><span class="pl-c">/*</span> note cwnd so we can restore it <span class="pl-c">*/</span></span></td>
  4198. </tr>
  4199. <tr>
  4200. <td id="L799" class="blob-num js-line-number" data-line-number="799"></td>
  4201. <td id="LC799" class="blob-code blob-code-inner js-file-line"> bbr-&gt;probe_rtt_done_stamp = <span class="pl-c1">0</span>;</td>
  4202. </tr>
  4203. <tr>
  4204. <td id="L800" class="blob-num js-line-number" data-line-number="800"></td>
  4205. <td id="LC800" class="blob-code blob-code-inner js-file-line"> }</td>
  4206. </tr>
  4207. <tr>
  4208. <td id="L801" class="blob-num js-line-number" data-line-number="801"></td>
  4209. <td id="LC801" class="blob-code blob-code-inner js-file-line">
  4210. </td>
  4211. </tr>
  4212. <tr>
  4213. <td id="L802" class="blob-num js-line-number" data-line-number="802"></td>
  4214. <td id="LC802" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;mode == BBR_PROBE_RTT) {</td>
  4215. </tr>
  4216. <tr>
  4217. <td id="L803" class="blob-num js-line-number" data-line-number="803"></td>
  4218. <td id="LC803" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Ignore low rate samples during this mode. <span class="pl-c">*/</span></span></td>
  4219. </tr>
  4220. <tr>
  4221. <td id="L804" class="blob-num js-line-number" data-line-number="804"></td>
  4222. <td id="LC804" class="blob-code blob-code-inner js-file-line"> tp-&gt;app_limited =</td>
  4223. </tr>
  4224. <tr>
  4225. <td id="L805" class="blob-num js-line-number" data-line-number="805"></td>
  4226. <td id="LC805" class="blob-code blob-code-inner js-file-line"> (tp-&gt;delivered + <span class="pl-c1">tcp_packets_in_flight</span>(tp)) ? : <span class="pl-c1">1</span>;</td>
  4227. </tr>
  4228. <tr>
  4229. <td id="L806" class="blob-num js-line-number" data-line-number="806"></td>
  4230. <td id="LC806" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Maintain min packets in flight for max(200 ms, 1 round). <span class="pl-c">*/</span></span></td>
  4231. </tr>
  4232. <tr>
  4233. <td id="L807" class="blob-num js-line-number" data-line-number="807"></td>
  4234. <td id="LC807" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (!bbr-&gt;probe_rtt_done_stamp &amp;&amp;</td>
  4235. </tr>
  4236. <tr>
  4237. <td id="L808" class="blob-num js-line-number" data-line-number="808"></td>
  4238. <td id="LC808" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">tcp_packets_in_flight</span>(tp) &lt;= bbr_cwnd_min_target) {</td>
  4239. </tr>
  4240. <tr>
  4241. <td id="L809" class="blob-num js-line-number" data-line-number="809"></td>
  4242. <td id="LC809" class="blob-code blob-code-inner js-file-line"> bbr-&gt;probe_rtt_done_stamp = tcp_time_stamp +</td>
  4243. </tr>
  4244. <tr>
  4245. <td id="L810" class="blob-num js-line-number" data-line-number="810"></td>
  4246. <td id="LC810" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">msecs_to_jiffies</span>(bbr_probe_rtt_mode_ms &gt;&gt; <span class="pl-c1">1</span>);</td>
  4247. </tr>
  4248. <tr>
  4249. <td id="L811" class="blob-num js-line-number" data-line-number="811"></td>
  4250. <td id="LC811" class="blob-code blob-code-inner js-file-line"> bbr-&gt;probe_rtt_round_done = <span class="pl-c1">0</span>;</td>
  4251. </tr>
  4252. <tr>
  4253. <td id="L812" class="blob-num js-line-number" data-line-number="812"></td>
  4254. <td id="LC812" class="blob-code blob-code-inner js-file-line"> bbr-&gt;next_rtt_delivered = tp-&gt;delivered;</td>
  4255. </tr>
  4256. <tr>
  4257. <td id="L813" class="blob-num js-line-number" data-line-number="813"></td>
  4258. <td id="LC813" class="blob-code blob-code-inner js-file-line"> } <span class="pl-k">else</span> <span class="pl-k">if</span> (bbr-&gt;probe_rtt_done_stamp) {</td>
  4259. </tr>
  4260. <tr>
  4261. <td id="L814" class="blob-num js-line-number" data-line-number="814"></td>
  4262. <td id="LC814" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;round_start)</td>
  4263. </tr>
  4264. <tr>
  4265. <td id="L815" class="blob-num js-line-number" data-line-number="815"></td>
  4266. <td id="LC815" class="blob-code blob-code-inner js-file-line"> bbr-&gt;probe_rtt_round_done = <span class="pl-c1">1</span>;</td>
  4267. </tr>
  4268. <tr>
  4269. <td id="L816" class="blob-num js-line-number" data-line-number="816"></td>
  4270. <td id="LC816" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (bbr-&gt;probe_rtt_round_done &amp;&amp;</td>
  4271. </tr>
  4272. <tr>
  4273. <td id="L817" class="blob-num js-line-number" data-line-number="817"></td>
  4274. <td id="LC817" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">after</span>(tcp_time_stamp, bbr-&gt;probe_rtt_done_stamp)) {</td>
  4275. </tr>
  4276. <tr>
  4277. <td id="L818" class="blob-num js-line-number" data-line-number="818"></td>
  4278. <td id="LC818" class="blob-code blob-code-inner js-file-line"> bbr-&gt;min_rtt_stamp = tcp_time_stamp;</td>
  4279. </tr>
  4280. <tr>
  4281. <td id="L819" class="blob-num js-line-number" data-line-number="819"></td>
  4282. <td id="LC819" class="blob-code blob-code-inner js-file-line"> bbr-&gt;restore_cwnd = <span class="pl-c1">1</span>; <span class="pl-c"><span class="pl-c">/*</span> snap to prior_cwnd <span class="pl-c">*/</span></span></td>
  4283. </tr>
  4284. <tr>
  4285. <td id="L820" class="blob-num js-line-number" data-line-number="820"></td>
  4286. <td id="LC820" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_mode</span>(sk);</td>
  4287. </tr>
  4288. <tr>
  4289. <td id="L821" class="blob-num js-line-number" data-line-number="821"></td>
  4290. <td id="LC821" class="blob-code blob-code-inner js-file-line"> }</td>
  4291. </tr>
  4292. <tr>
  4293. <td id="L822" class="blob-num js-line-number" data-line-number="822"></td>
  4294. <td id="LC822" class="blob-code blob-code-inner js-file-line"> }</td>
  4295. </tr>
  4296. <tr>
  4297. <td id="L823" class="blob-num js-line-number" data-line-number="823"></td>
  4298. <td id="LC823" class="blob-code blob-code-inner js-file-line"> }</td>
  4299. </tr>
  4300. <tr>
  4301. <td id="L824" class="blob-num js-line-number" data-line-number="824"></td>
  4302. <td id="LC824" class="blob-code blob-code-inner js-file-line"> bbr-&gt;idle_restart = <span class="pl-c1">0</span>;</td>
  4303. </tr>
  4304. <tr>
  4305. <td id="L825" class="blob-num js-line-number" data-line-number="825"></td>
  4306. <td id="LC825" class="blob-code blob-code-inner js-file-line">}</td>
  4307. </tr>
  4308. <tr>
  4309. <td id="L826" class="blob-num js-line-number" data-line-number="826"></td>
  4310. <td id="LC826" class="blob-code blob-code-inner js-file-line">
  4311. </td>
  4312. </tr>
  4313. <tr>
  4314. <td id="L827" class="blob-num js-line-number" data-line-number="827"></td>
  4315. <td id="LC827" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_update_model</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  4316. </tr>
  4317. <tr>
  4318. <td id="L828" class="blob-num js-line-number" data-line-number="828"></td>
  4319. <td id="LC828" class="blob-code blob-code-inner js-file-line">{</td>
  4320. </tr>
  4321. <tr>
  4322. <td id="L829" class="blob-num js-line-number" data-line-number="829"></td>
  4323. <td id="LC829" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_update_bw</span>(sk, rs);</td>
  4324. </tr>
  4325. <tr>
  4326. <td id="L830" class="blob-num js-line-number" data-line-number="830"></td>
  4327. <td id="LC830" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_update_cycle_phase</span>(sk, rs);</td>
  4328. </tr>
  4329. <tr>
  4330. <td id="L831" class="blob-num js-line-number" data-line-number="831"></td>
  4331. <td id="LC831" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_check_full_bw_reached</span>(sk, rs);</td>
  4332. </tr>
  4333. <tr>
  4334. <td id="L832" class="blob-num js-line-number" data-line-number="832"></td>
  4335. <td id="LC832" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_check_drain</span>(sk, rs);</td>
  4336. </tr>
  4337. <tr>
  4338. <td id="L833" class="blob-num js-line-number" data-line-number="833"></td>
  4339. <td id="LC833" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_update_min_rtt</span>(sk, rs);</td>
  4340. </tr>
  4341. <tr>
  4342. <td id="L834" class="blob-num js-line-number" data-line-number="834"></td>
  4343. <td id="LC834" class="blob-code blob-code-inner js-file-line">}</td>
  4344. </tr>
  4345. <tr>
  4346. <td id="L835" class="blob-num js-line-number" data-line-number="835"></td>
  4347. <td id="LC835" class="blob-code blob-code-inner js-file-line">
  4348. </td>
  4349. </tr>
  4350. <tr>
  4351. <td id="L836" class="blob-num js-line-number" data-line-number="836"></td>
  4352. <td id="LC836" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_main</span>(<span class="pl-k">struct</span> sock *sk, <span class="pl-k">const</span> <span class="pl-k">struct</span> rate_sample *rs)</td>
  4353. </tr>
  4354. <tr>
  4355. <td id="L837" class="blob-num js-line-number" data-line-number="837"></td>
  4356. <td id="LC837" class="blob-code blob-code-inner js-file-line">{</td>
  4357. </tr>
  4358. <tr>
  4359. <td id="L838" class="blob-num js-line-number" data-line-number="838"></td>
  4360. <td id="LC838" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  4361. </tr>
  4362. <tr>
  4363. <td id="L839" class="blob-num js-line-number" data-line-number="839"></td>
  4364. <td id="LC839" class="blob-code blob-code-inner js-file-line"> u32 bw;</td>
  4365. </tr>
  4366. <tr>
  4367. <td id="L840" class="blob-num js-line-number" data-line-number="840"></td>
  4368. <td id="LC840" class="blob-code blob-code-inner js-file-line">
  4369. </td>
  4370. </tr>
  4371. <tr>
  4372. <td id="L841" class="blob-num js-line-number" data-line-number="841"></td>
  4373. <td id="LC841" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_update_model</span>(sk, rs);</td>
  4374. </tr>
  4375. <tr>
  4376. <td id="L842" class="blob-num js-line-number" data-line-number="842"></td>
  4377. <td id="LC842" class="blob-code blob-code-inner js-file-line">
  4378. </td>
  4379. </tr>
  4380. <tr>
  4381. <td id="L843" class="blob-num js-line-number" data-line-number="843"></td>
  4382. <td id="LC843" class="blob-code blob-code-inner js-file-line"> bw = <span class="pl-c1">bbr_bw</span>(sk);</td>
  4383. </tr>
  4384. <tr>
  4385. <td id="L844" class="blob-num js-line-number" data-line-number="844"></td>
  4386. <td id="LC844" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_set_pacing_rate</span>(sk, bw, bbr-&gt;pacing_gain);</td>
  4387. </tr>
  4388. <tr>
  4389. <td id="L845" class="blob-num js-line-number" data-line-number="845"></td>
  4390. <td id="LC845" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_set_tso_segs_goal</span>(sk);</td>
  4391. </tr>
  4392. <tr>
  4393. <td id="L846" class="blob-num js-line-number" data-line-number="846"></td>
  4394. <td id="LC846" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_set_cwnd</span>(sk, rs, rs-&gt;acked_sacked, bw, bbr-&gt;cwnd_gain);</td>
  4395. </tr>
  4396. <tr>
  4397. <td id="L847" class="blob-num js-line-number" data-line-number="847"></td>
  4398. <td id="LC847" class="blob-code blob-code-inner js-file-line">}</td>
  4399. </tr>
  4400. <tr>
  4401. <td id="L848" class="blob-num js-line-number" data-line-number="848"></td>
  4402. <td id="LC848" class="blob-code blob-code-inner js-file-line">
  4403. </td>
  4404. </tr>
  4405. <tr>
  4406. <td id="L849" class="blob-num js-line-number" data-line-number="849"></td>
  4407. <td id="LC849" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_init</span>(<span class="pl-k">struct</span> sock *sk)</td>
  4408. </tr>
  4409. <tr>
  4410. <td id="L850" class="blob-num js-line-number" data-line-number="850"></td>
  4411. <td id="LC850" class="blob-code blob-code-inner js-file-line">{</td>
  4412. </tr>
  4413. <tr>
  4414. <td id="L851" class="blob-num js-line-number" data-line-number="851"></td>
  4415. <td id="LC851" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  4416. </tr>
  4417. <tr>
  4418. <td id="L852" class="blob-num js-line-number" data-line-number="852"></td>
  4419. <td id="LC852" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  4420. </tr>
  4421. <tr>
  4422. <td id="L853" class="blob-num js-line-number" data-line-number="853"></td>
  4423. <td id="LC853" class="blob-code blob-code-inner js-file-line"> u64 bw;</td>
  4424. </tr>
  4425. <tr>
  4426. <td id="L854" class="blob-num js-line-number" data-line-number="854"></td>
  4427. <td id="LC854" class="blob-code blob-code-inner js-file-line">
  4428. </td>
  4429. </tr>
  4430. <tr>
  4431. <td id="L855" class="blob-num js-line-number" data-line-number="855"></td>
  4432. <td id="LC855" class="blob-code blob-code-inner js-file-line"> bbr-&gt;prior_cwnd = <span class="pl-c1">0</span>;</td>
  4433. </tr>
  4434. <tr>
  4435. <td id="L856" class="blob-num js-line-number" data-line-number="856"></td>
  4436. <td id="LC856" class="blob-code blob-code-inner js-file-line"> bbr-&gt;tso_segs_goal = <span class="pl-c1">0</span>; <span class="pl-c"><span class="pl-c">/*</span> default segs per skb until first ACK <span class="pl-c">*/</span></span></td>
  4437. </tr>
  4438. <tr>
  4439. <td id="L857" class="blob-num js-line-number" data-line-number="857"></td>
  4440. <td id="LC857" class="blob-code blob-code-inner js-file-line"> bbr-&gt;rtt_cnt = <span class="pl-c1">0</span>;</td>
  4441. </tr>
  4442. <tr>
  4443. <td id="L858" class="blob-num js-line-number" data-line-number="858"></td>
  4444. <td id="LC858" class="blob-code blob-code-inner js-file-line"> bbr-&gt;next_rtt_delivered = <span class="pl-c1">0</span>;</td>
  4445. </tr>
  4446. <tr>
  4447. <td id="L859" class="blob-num js-line-number" data-line-number="859"></td>
  4448. <td id="LC859" class="blob-code blob-code-inner js-file-line"> bbr-&gt;prev_ca_state = TCP_CA_Open;</td>
  4449. </tr>
  4450. <tr>
  4451. <td id="L860" class="blob-num js-line-number" data-line-number="860"></td>
  4452. <td id="LC860" class="blob-code blob-code-inner js-file-line"> bbr-&gt;packet_conservation = <span class="pl-c1">0</span>;</td>
  4453. </tr>
  4454. <tr>
  4455. <td id="L861" class="blob-num js-line-number" data-line-number="861"></td>
  4456. <td id="LC861" class="blob-code blob-code-inner js-file-line">
  4457. </td>
  4458. </tr>
  4459. <tr>
  4460. <td id="L862" class="blob-num js-line-number" data-line-number="862"></td>
  4461. <td id="LC862" class="blob-code blob-code-inner js-file-line"> bbr-&gt;probe_rtt_done_stamp = <span class="pl-c1">0</span>;</td>
  4462. </tr>
  4463. <tr>
  4464. <td id="L863" class="blob-num js-line-number" data-line-number="863"></td>
  4465. <td id="LC863" class="blob-code blob-code-inner js-file-line"> bbr-&gt;probe_rtt_round_done = <span class="pl-c1">0</span>;</td>
  4466. </tr>
  4467. <tr>
  4468. <td id="L864" class="blob-num js-line-number" data-line-number="864"></td>
  4469. <td id="LC864" class="blob-code blob-code-inner js-file-line"> bbr-&gt;min_rtt_us = <span class="pl-c1">tcp_min_rtt</span>(tp);</td>
  4470. </tr>
  4471. <tr>
  4472. <td id="L865" class="blob-num js-line-number" data-line-number="865"></td>
  4473. <td id="LC865" class="blob-code blob-code-inner js-file-line"> bbr-&gt;min_rtt_stamp = tcp_time_stamp;</td>
  4474. </tr>
  4475. <tr>
  4476. <td id="L866" class="blob-num js-line-number" data-line-number="866"></td>
  4477. <td id="LC866" class="blob-code blob-code-inner js-file-line">
  4478. </td>
  4479. </tr>
  4480. <tr>
  4481. <td id="L867" class="blob-num js-line-number" data-line-number="867"></td>
  4482. <td id="LC867" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">minmax_reset</span>(&amp;bbr-&gt;bw, bbr-&gt;rtt_cnt, <span class="pl-c1">0</span>); <span class="pl-c"><span class="pl-c">/*</span> init max bw to 0 <span class="pl-c">*/</span></span></td>
  4483. </tr>
  4484. <tr>
  4485. <td id="L868" class="blob-num js-line-number" data-line-number="868"></td>
  4486. <td id="LC868" class="blob-code blob-code-inner js-file-line">
  4487. </td>
  4488. </tr>
  4489. <tr>
  4490. <td id="L869" class="blob-num js-line-number" data-line-number="869"></td>
  4491. <td id="LC869" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Initialize pacing rate to: high_gain * init_cwnd / RTT. <span class="pl-c">*/</span></span></td>
  4492. </tr>
  4493. <tr>
  4494. <td id="L870" class="blob-num js-line-number" data-line-number="870"></td>
  4495. <td id="LC870" class="blob-code blob-code-inner js-file-line"> bw = (u64)tp-&gt;snd_cwnd * BW_UNIT;</td>
  4496. </tr>
  4497. <tr>
  4498. <td id="L871" class="blob-num js-line-number" data-line-number="871"></td>
  4499. <td id="LC871" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">do_div</span>(bw, (tp-&gt;srtt_us &gt;&gt; <span class="pl-c1">3</span>) ? : USEC_PER_MSEC);</td>
  4500. </tr>
  4501. <tr>
  4502. <td id="L872" class="blob-num js-line-number" data-line-number="872"></td>
  4503. <td id="LC872" class="blob-code blob-code-inner js-file-line"> sk-&gt;sk_pacing_rate = <span class="pl-c1">0</span>; <span class="pl-c"><span class="pl-c">/*</span> force an update of sk_pacing_rate <span class="pl-c">*/</span></span></td>
  4504. </tr>
  4505. <tr>
  4506. <td id="L873" class="blob-num js-line-number" data-line-number="873"></td>
  4507. <td id="LC873" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_set_pacing_rate</span>(sk, bw, bbr_high_gain);</td>
  4508. </tr>
  4509. <tr>
  4510. <td id="L874" class="blob-num js-line-number" data-line-number="874"></td>
  4511. <td id="LC874" class="blob-code blob-code-inner js-file-line">
  4512. </td>
  4513. </tr>
  4514. <tr>
  4515. <td id="L875" class="blob-num js-line-number" data-line-number="875"></td>
  4516. <td id="LC875" class="blob-code blob-code-inner js-file-line"> bbr-&gt;restore_cwnd = <span class="pl-c1">0</span>;</td>
  4517. </tr>
  4518. <tr>
  4519. <td id="L876" class="blob-num js-line-number" data-line-number="876"></td>
  4520. <td id="LC876" class="blob-code blob-code-inner js-file-line"> bbr-&gt;round_start = <span class="pl-c1">0</span>;</td>
  4521. </tr>
  4522. <tr>
  4523. <td id="L877" class="blob-num js-line-number" data-line-number="877"></td>
  4524. <td id="LC877" class="blob-code blob-code-inner js-file-line"> bbr-&gt;idle_restart = <span class="pl-c1">0</span>;</td>
  4525. </tr>
  4526. <tr>
  4527. <td id="L878" class="blob-num js-line-number" data-line-number="878"></td>
  4528. <td id="LC878" class="blob-code blob-code-inner js-file-line"> bbr-&gt;full_bw = <span class="pl-c1">0</span>;</td>
  4529. </tr>
  4530. <tr>
  4531. <td id="L879" class="blob-num js-line-number" data-line-number="879"></td>
  4532. <td id="LC879" class="blob-code blob-code-inner js-file-line"> bbr-&gt;full_bw_cnt = <span class="pl-c1">0</span>;</td>
  4533. </tr>
  4534. <tr>
  4535. <td id="L880" class="blob-num js-line-number" data-line-number="880"></td>
  4536. <td id="LC880" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cycle_mstamp.<span class="pl-smi">v64</span> = <span class="pl-c1">0</span>;</td>
  4537. </tr>
  4538. <tr>
  4539. <td id="L881" class="blob-num js-line-number" data-line-number="881"></td>
  4540. <td id="LC881" class="blob-code blob-code-inner js-file-line"> bbr-&gt;cycle_idx = <span class="pl-c1">0</span>;</td>
  4541. </tr>
  4542. <tr>
  4543. <td id="L882" class="blob-num js-line-number" data-line-number="882"></td>
  4544. <td id="LC882" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_lt_bw_sampling</span>(sk);</td>
  4545. </tr>
  4546. <tr>
  4547. <td id="L883" class="blob-num js-line-number" data-line-number="883"></td>
  4548. <td id="LC883" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_reset_startup_mode</span>(sk);</td>
  4549. </tr>
  4550. <tr>
  4551. <td id="L884" class="blob-num js-line-number" data-line-number="884"></td>
  4552. <td id="LC884" class="blob-code blob-code-inner js-file-line">}</td>
  4553. </tr>
  4554. <tr>
  4555. <td id="L885" class="blob-num js-line-number" data-line-number="885"></td>
  4556. <td id="LC885" class="blob-code blob-code-inner js-file-line">
  4557. </td>
  4558. </tr>
  4559. <tr>
  4560. <td id="L886" class="blob-num js-line-number" data-line-number="886"></td>
  4561. <td id="LC886" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u32 <span class="pl-en">bbr_sndbuf_expand</span>(<span class="pl-k">struct</span> sock *sk)</td>
  4562. </tr>
  4563. <tr>
  4564. <td id="L887" class="blob-num js-line-number" data-line-number="887"></td>
  4565. <td id="LC887" class="blob-code blob-code-inner js-file-line">{</td>
  4566. </tr>
  4567. <tr>
  4568. <td id="L888" class="blob-num js-line-number" data-line-number="888"></td>
  4569. <td id="LC888" class="blob-code blob-code-inner js-file-line"> <span class="pl-c"><span class="pl-c">/*</span> Provision 3 * cwnd since BBR may slow-start even during recovery. <span class="pl-c">*/</span></span></td>
  4570. </tr>
  4571. <tr>
  4572. <td id="L889" class="blob-num js-line-number" data-line-number="889"></td>
  4573. <td id="LC889" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-c1">3</span>;</td>
  4574. </tr>
  4575. <tr>
  4576. <td id="L890" class="blob-num js-line-number" data-line-number="890"></td>
  4577. <td id="LC890" class="blob-code blob-code-inner js-file-line">}</td>
  4578. </tr>
  4579. <tr>
  4580. <td id="L891" class="blob-num js-line-number" data-line-number="891"></td>
  4581. <td id="LC891" class="blob-code blob-code-inner js-file-line">
  4582. </td>
  4583. </tr>
  4584. <tr>
  4585. <td id="L892" class="blob-num js-line-number" data-line-number="892"></td>
  4586. <td id="LC892" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> In theory BBR does not need to undo the cwnd since it does not</span></td>
  4587. </tr>
  4588. <tr>
  4589. <td id="L893" class="blob-num js-line-number" data-line-number="893"></td>
  4590. <td id="LC893" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> * always reduce cwnd on losses (see bbr_main()). Keep it for now.</span></td>
  4591. </tr>
  4592. <tr>
  4593. <td id="L894" class="blob-num js-line-number" data-line-number="894"></td>
  4594. <td id="LC894" class="blob-code blob-code-inner js-file-line"><span class="pl-c"> <span class="pl-c">*/</span></span></td>
  4595. </tr>
  4596. <tr>
  4597. <td id="L895" class="blob-num js-line-number" data-line-number="895"></td>
  4598. <td id="LC895" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u32 <span class="pl-en">bbr_undo_cwnd</span>(<span class="pl-k">struct</span> sock *sk)</td>
  4599. </tr>
  4600. <tr>
  4601. <td id="L896" class="blob-num js-line-number" data-line-number="896"></td>
  4602. <td id="LC896" class="blob-code blob-code-inner js-file-line">{</td>
  4603. </tr>
  4604. <tr>
  4605. <td id="L897" class="blob-num js-line-number" data-line-number="897"></td>
  4606. <td id="LC897" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-c1">tcp_sk</span>(sk)-&gt;snd_cwnd;</td>
  4607. </tr>
  4608. <tr>
  4609. <td id="L898" class="blob-num js-line-number" data-line-number="898"></td>
  4610. <td id="LC898" class="blob-code blob-code-inner js-file-line">}</td>
  4611. </tr>
  4612. <tr>
  4613. <td id="L899" class="blob-num js-line-number" data-line-number="899"></td>
  4614. <td id="LC899" class="blob-code blob-code-inner js-file-line">
  4615. </td>
  4616. </tr>
  4617. <tr>
  4618. <td id="L900" class="blob-num js-line-number" data-line-number="900"></td>
  4619. <td id="LC900" class="blob-code blob-code-inner js-file-line"><span class="pl-c"><span class="pl-c">/*</span> Entering loss recovery, so save cwnd for when we exit or undo recovery. <span class="pl-c">*/</span></span></td>
  4620. </tr>
  4621. <tr>
  4622. <td id="L901" class="blob-num js-line-number" data-line-number="901"></td>
  4623. <td id="LC901" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> u32 <span class="pl-en">bbr_ssthresh</span>(<span class="pl-k">struct</span> sock *sk)</td>
  4624. </tr>
  4625. <tr>
  4626. <td id="L902" class="blob-num js-line-number" data-line-number="902"></td>
  4627. <td id="LC902" class="blob-code blob-code-inner js-file-line">{</td>
  4628. </tr>
  4629. <tr>
  4630. <td id="L903" class="blob-num js-line-number" data-line-number="903"></td>
  4631. <td id="LC903" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_save_cwnd</span>(sk);</td>
  4632. </tr>
  4633. <tr>
  4634. <td id="L904" class="blob-num js-line-number" data-line-number="904"></td>
  4635. <td id="LC904" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> TCP_INFINITE_SSTHRESH; <span class="pl-c"><span class="pl-c">/*</span> BBR does not use ssthresh <span class="pl-c">*/</span></span></td>
  4636. </tr>
  4637. <tr>
  4638. <td id="L905" class="blob-num js-line-number" data-line-number="905"></td>
  4639. <td id="LC905" class="blob-code blob-code-inner js-file-line">}</td>
  4640. </tr>
  4641. <tr>
  4642. <td id="L906" class="blob-num js-line-number" data-line-number="906"></td>
  4643. <td id="LC906" class="blob-code blob-code-inner js-file-line">
  4644. </td>
  4645. </tr>
  4646. <tr>
  4647. <td id="L907" class="blob-num js-line-number" data-line-number="907"></td>
  4648. <td id="LC907" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-c1">size_t</span> <span class="pl-en">bbr_get_info</span>(<span class="pl-k">struct</span> sock *sk, u32 ext, <span class="pl-k">int</span> *attr, <span class="pl-k">union</span> tcp_cc_info *info)</td>
  4649. </tr>
  4650. <tr>
  4651. <td id="L908" class="blob-num js-line-number" data-line-number="908"></td>
  4652. <td id="LC908" class="blob-code blob-code-inner js-file-line">{</td>
  4653. </tr>
  4654. <tr>
  4655. <td id="L909" class="blob-num js-line-number" data-line-number="909"></td>
  4656. <td id="LC909" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (ext &amp; (<span class="pl-c1">1</span> &lt;&lt; (INET_DIAG_BBRINFO - <span class="pl-c1">1</span>)) ||</td>
  4657. </tr>
  4658. <tr>
  4659. <td id="L910" class="blob-num js-line-number" data-line-number="910"></td>
  4660. <td id="LC910" class="blob-code blob-code-inner js-file-line"> ext &amp; (<span class="pl-c1">1</span> &lt;&lt; (INET_DIAG_VEGASINFO - <span class="pl-c1">1</span>))) {</td>
  4661. </tr>
  4662. <tr>
  4663. <td id="L911" class="blob-num js-line-number" data-line-number="911"></td>
  4664. <td id="LC911" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> tcp_sock *tp = <span class="pl-c1">tcp_sk</span>(sk);</td>
  4665. </tr>
  4666. <tr>
  4667. <td id="L912" class="blob-num js-line-number" data-line-number="912"></td>
  4668. <td id="LC912" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  4669. </tr>
  4670. <tr>
  4671. <td id="L913" class="blob-num js-line-number" data-line-number="913"></td>
  4672. <td id="LC913" class="blob-code blob-code-inner js-file-line"> u64 bw = <span class="pl-c1">bbr_bw</span>(sk);</td>
  4673. </tr>
  4674. <tr>
  4675. <td id="L914" class="blob-num js-line-number" data-line-number="914"></td>
  4676. <td id="LC914" class="blob-code blob-code-inner js-file-line"> bw = bw * tp-&gt;mss_cache * USEC_PER_SEC &gt;&gt; BW_SCALE;</td>
  4677. </tr>
  4678. <tr>
  4679. <td id="L915" class="blob-num js-line-number" data-line-number="915"></td>
  4680. <td id="LC915" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">memset</span>(&amp;info-&gt;bbr, <span class="pl-c1">0</span>, <span class="pl-k">sizeof</span>(info-&gt;bbr));</td>
  4681. </tr>
  4682. <tr>
  4683. <td id="L916" class="blob-num js-line-number" data-line-number="916"></td>
  4684. <td id="LC916" class="blob-code blob-code-inner js-file-line"> info-&gt;bbr.<span class="pl-smi">bbr_bw_lo</span> = (u32)bw;</td>
  4685. </tr>
  4686. <tr>
  4687. <td id="L917" class="blob-num js-line-number" data-line-number="917"></td>
  4688. <td id="LC917" class="blob-code blob-code-inner js-file-line"> info-&gt;bbr.<span class="pl-smi">bbr_bw_hi</span> = (u32)(bw &gt;&gt; <span class="pl-c1">32</span>);</td>
  4689. </tr>
  4690. <tr>
  4691. <td id="L918" class="blob-num js-line-number" data-line-number="918"></td>
  4692. <td id="LC918" class="blob-code blob-code-inner js-file-line"> info-&gt;bbr.<span class="pl-smi">bbr_min_rtt</span> = bbr-&gt;min_rtt_us;</td>
  4693. </tr>
  4694. <tr>
  4695. <td id="L919" class="blob-num js-line-number" data-line-number="919"></td>
  4696. <td id="LC919" class="blob-code blob-code-inner js-file-line"> info-&gt;bbr.<span class="pl-smi">bbr_pacing_gain</span> = bbr-&gt;pacing_gain;</td>
  4697. </tr>
  4698. <tr>
  4699. <td id="L920" class="blob-num js-line-number" data-line-number="920"></td>
  4700. <td id="LC920" class="blob-code blob-code-inner js-file-line"> info-&gt;bbr.<span class="pl-smi">bbr_cwnd_gain</span> = bbr-&gt;cwnd_gain;</td>
  4701. </tr>
  4702. <tr>
  4703. <td id="L921" class="blob-num js-line-number" data-line-number="921"></td>
  4704. <td id="LC921" class="blob-code blob-code-inner js-file-line"> *attr = INET_DIAG_BBRINFO;</td>
  4705. </tr>
  4706. <tr>
  4707. <td id="L922" class="blob-num js-line-number" data-line-number="922"></td>
  4708. <td id="LC922" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-k">sizeof</span>(info-&gt;bbr);</td>
  4709. </tr>
  4710. <tr>
  4711. <td id="L923" class="blob-num js-line-number" data-line-number="923"></td>
  4712. <td id="LC923" class="blob-code blob-code-inner js-file-line"> }</td>
  4713. </tr>
  4714. <tr>
  4715. <td id="L924" class="blob-num js-line-number" data-line-number="924"></td>
  4716. <td id="LC924" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-c1">0</span>;</td>
  4717. </tr>
  4718. <tr>
  4719. <td id="L925" class="blob-num js-line-number" data-line-number="925"></td>
  4720. <td id="LC925" class="blob-code blob-code-inner js-file-line">}</td>
  4721. </tr>
  4722. <tr>
  4723. <td id="L926" class="blob-num js-line-number" data-line-number="926"></td>
  4724. <td id="LC926" class="blob-code blob-code-inner js-file-line">
  4725. </td>
  4726. </tr>
  4727. <tr>
  4728. <td id="L927" class="blob-num js-line-number" data-line-number="927"></td>
  4729. <td id="LC927" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> <span class="pl-en">bbr_set_state</span>(<span class="pl-k">struct</span> sock *sk, u8 new_state)</td>
  4730. </tr>
  4731. <tr>
  4732. <td id="L928" class="blob-num js-line-number" data-line-number="928"></td>
  4733. <td id="LC928" class="blob-code blob-code-inner js-file-line">{</td>
  4734. </tr>
  4735. <tr>
  4736. <td id="L929" class="blob-num js-line-number" data-line-number="929"></td>
  4737. <td id="LC929" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> bbr *bbr = <span class="pl-c1">inet_csk_ca</span>(sk);</td>
  4738. </tr>
  4739. <tr>
  4740. <td id="L930" class="blob-num js-line-number" data-line-number="930"></td>
  4741. <td id="LC930" class="blob-code blob-code-inner js-file-line">
  4742. </td>
  4743. </tr>
  4744. <tr>
  4745. <td id="L931" class="blob-num js-line-number" data-line-number="931"></td>
  4746. <td id="LC931" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">if</span> (new_state == TCP_CA_Loss) {</td>
  4747. </tr>
  4748. <tr>
  4749. <td id="L932" class="blob-num js-line-number" data-line-number="932"></td>
  4750. <td id="LC932" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">struct</span> rate_sample rs = { .<span class="pl-smi">losses</span> = <span class="pl-c1">1</span> };</td>
  4751. </tr>
  4752. <tr>
  4753. <td id="L933" class="blob-num js-line-number" data-line-number="933"></td>
  4754. <td id="LC933" class="blob-code blob-code-inner js-file-line">
  4755. </td>
  4756. </tr>
  4757. <tr>
  4758. <td id="L934" class="blob-num js-line-number" data-line-number="934"></td>
  4759. <td id="LC934" class="blob-code blob-code-inner js-file-line"> bbr-&gt;prev_ca_state = TCP_CA_Loss;</td>
  4760. </tr>
  4761. <tr>
  4762. <td id="L935" class="blob-num js-line-number" data-line-number="935"></td>
  4763. <td id="LC935" class="blob-code blob-code-inner js-file-line"> bbr-&gt;full_bw = <span class="pl-c1">0</span>;</td>
  4764. </tr>
  4765. <tr>
  4766. <td id="L936" class="blob-num js-line-number" data-line-number="936"></td>
  4767. <td id="LC936" class="blob-code blob-code-inner js-file-line"> bbr-&gt;round_start = <span class="pl-c1">1</span>; <span class="pl-c"><span class="pl-c">/*</span> treat RTO like end of a round <span class="pl-c">*/</span></span></td>
  4768. </tr>
  4769. <tr>
  4770. <td id="L937" class="blob-num js-line-number" data-line-number="937"></td>
  4771. <td id="LC937" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">bbr_lt_bw_sampling</span>(sk, &amp;rs);</td>
  4772. </tr>
  4773. <tr>
  4774. <td id="L938" class="blob-num js-line-number" data-line-number="938"></td>
  4775. <td id="LC938" class="blob-code blob-code-inner js-file-line"> }</td>
  4776. </tr>
  4777. <tr>
  4778. <td id="L939" class="blob-num js-line-number" data-line-number="939"></td>
  4779. <td id="LC939" class="blob-code blob-code-inner js-file-line">}</td>
  4780. </tr>
  4781. <tr>
  4782. <td id="L940" class="blob-num js-line-number" data-line-number="940"></td>
  4783. <td id="LC940" class="blob-code blob-code-inner js-file-line">
  4784. </td>
  4785. </tr>
  4786. <tr>
  4787. <td id="L941" class="blob-num js-line-number" data-line-number="941"></td>
  4788. <td id="LC941" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">struct</span> tcp_congestion_ops tcp_bbr_cong_ops __read_mostly = {</td>
  4789. </tr>
  4790. <tr>
  4791. <td id="L942" class="blob-num js-line-number" data-line-number="942"></td>
  4792. <td id="LC942" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">flags</span> = TCP_CONG_NON_RESTRICTED,</td>
  4793. </tr>
  4794. <tr>
  4795. <td id="L943" class="blob-num js-line-number" data-line-number="943"></td>
  4796. <td id="LC943" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">name</span> = <span class="pl-s"><span class="pl-pds">&quot;</span>nanqinlang<span class="pl-pds">&quot;</span></span>,</td>
  4797. </tr>
  4798. <tr>
  4799. <td id="L944" class="blob-num js-line-number" data-line-number="944"></td>
  4800. <td id="LC944" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">owner</span> = THIS_MODULE,</td>
  4801. </tr>
  4802. <tr>
  4803. <td id="L945" class="blob-num js-line-number" data-line-number="945"></td>
  4804. <td id="LC945" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">init</span> = bbr_init,</td>
  4805. </tr>
  4806. <tr>
  4807. <td id="L946" class="blob-num js-line-number" data-line-number="946"></td>
  4808. <td id="LC946" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">cong_control</span> = bbr_main,</td>
  4809. </tr>
  4810. <tr>
  4811. <td id="L947" class="blob-num js-line-number" data-line-number="947"></td>
  4812. <td id="LC947" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">sndbuf_expand</span> = bbr_sndbuf_expand,</td>
  4813. </tr>
  4814. <tr>
  4815. <td id="L948" class="blob-num js-line-number" data-line-number="948"></td>
  4816. <td id="LC948" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">undo_cwnd</span> = bbr_undo_cwnd,</td>
  4817. </tr>
  4818. <tr>
  4819. <td id="L949" class="blob-num js-line-number" data-line-number="949"></td>
  4820. <td id="LC949" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">cwnd_event</span> = bbr_cwnd_event,</td>
  4821. </tr>
  4822. <tr>
  4823. <td id="L950" class="blob-num js-line-number" data-line-number="950"></td>
  4824. <td id="LC950" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">ssthresh</span> = bbr_ssthresh,</td>
  4825. </tr>
  4826. <tr>
  4827. <td id="L951" class="blob-num js-line-number" data-line-number="951"></td>
  4828. <td id="LC951" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">tso_segs_goal</span> = bbr_tso_segs_goal,</td>
  4829. </tr>
  4830. <tr>
  4831. <td id="L952" class="blob-num js-line-number" data-line-number="952"></td>
  4832. <td id="LC952" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">get_info</span> = bbr_get_info,</td>
  4833. </tr>
  4834. <tr>
  4835. <td id="L953" class="blob-num js-line-number" data-line-number="953"></td>
  4836. <td id="LC953" class="blob-code blob-code-inner js-file-line"> .<span class="pl-smi">set_state</span> = bbr_set_state,</td>
  4837. </tr>
  4838. <tr>
  4839. <td id="L954" class="blob-num js-line-number" data-line-number="954"></td>
  4840. <td id="LC954" class="blob-code blob-code-inner js-file-line">};</td>
  4841. </tr>
  4842. <tr>
  4843. <td id="L955" class="blob-num js-line-number" data-line-number="955"></td>
  4844. <td id="LC955" class="blob-code blob-code-inner js-file-line">
  4845. </td>
  4846. </tr>
  4847. <tr>
  4848. <td id="L956" class="blob-num js-line-number" data-line-number="956"></td>
  4849. <td id="LC956" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">int</span> __init <span class="pl-en">bbr_register</span>(<span class="pl-k">void</span>)</td>
  4850. </tr>
  4851. <tr>
  4852. <td id="L957" class="blob-num js-line-number" data-line-number="957"></td>
  4853. <td id="LC957" class="blob-code blob-code-inner js-file-line">{</td>
  4854. </tr>
  4855. <tr>
  4856. <td id="L958" class="blob-num js-line-number" data-line-number="958"></td>
  4857. <td id="LC958" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">BUILD_BUG_ON</span>(<span class="pl-k">sizeof</span>(<span class="pl-k">struct</span> bbr) &gt; ICSK_CA_PRIV_SIZE);</td>
  4858. </tr>
  4859. <tr>
  4860. <td id="L959" class="blob-num js-line-number" data-line-number="959"></td>
  4861. <td id="LC959" class="blob-code blob-code-inner js-file-line"> <span class="pl-k">return</span> <span class="pl-c1">tcp_register_congestion_control</span>(&amp;tcp_bbr_cong_ops);</td>
  4862. </tr>
  4863. <tr>
  4864. <td id="L960" class="blob-num js-line-number" data-line-number="960"></td>
  4865. <td id="LC960" class="blob-code blob-code-inner js-file-line">}</td>
  4866. </tr>
  4867. <tr>
  4868. <td id="L961" class="blob-num js-line-number" data-line-number="961"></td>
  4869. <td id="LC961" class="blob-code blob-code-inner js-file-line">
  4870. </td>
  4871. </tr>
  4872. <tr>
  4873. <td id="L962" class="blob-num js-line-number" data-line-number="962"></td>
  4874. <td id="LC962" class="blob-code blob-code-inner js-file-line"><span class="pl-k">static</span> <span class="pl-k">void</span> __exit <span class="pl-en">bbr_unregister</span>(<span class="pl-k">void</span>)</td>
  4875. </tr>
  4876. <tr>
  4877. <td id="L963" class="blob-num js-line-number" data-line-number="963"></td>
  4878. <td id="LC963" class="blob-code blob-code-inner js-file-line">{</td>
  4879. </tr>
  4880. <tr>
  4881. <td id="L964" class="blob-num js-line-number" data-line-number="964"></td>
  4882. <td id="LC964" class="blob-code blob-code-inner js-file-line"> <span class="pl-c1">tcp_unregister_congestion_control</span>(&amp;tcp_bbr_cong_ops);</td>
  4883. </tr>
  4884. <tr>
  4885. <td id="L965" class="blob-num js-line-number" data-line-number="965"></td>
  4886. <td id="LC965" class="blob-code blob-code-inner js-file-line">}</td>
  4887. </tr>
  4888. <tr>
  4889. <td id="L966" class="blob-num js-line-number" data-line-number="966"></td>
  4890. <td id="LC966" class="blob-code blob-code-inner js-file-line">
  4891. </td>
  4892. </tr>
  4893. <tr>
  4894. <td id="L967" class="blob-num js-line-number" data-line-number="967"></td>
  4895. <td id="LC967" class="blob-code blob-code-inner js-file-line"><span class="pl-en">module_init</span>(bbr_register);</td>
  4896. </tr>
  4897. <tr>
  4898. <td id="L968" class="blob-num js-line-number" data-line-number="968"></td>
  4899. <td id="LC968" class="blob-code blob-code-inner js-file-line"><span class="pl-en">module_exit</span>(bbr_unregister);</td>
  4900. </tr>
  4901. <tr>
  4902. <td id="L969" class="blob-num js-line-number" data-line-number="969"></td>
  4903. <td id="LC969" class="blob-code blob-code-inner js-file-line">
  4904. </td>
  4905. </tr>
  4906. <tr>
  4907. <td id="L970" class="blob-num js-line-number" data-line-number="970"></td>
  4908. <td id="LC970" class="blob-code blob-code-inner js-file-line"><span class="pl-en">MODULE_AUTHOR</span>(<span class="pl-s"><span class="pl-pds">&quot;</span>Van Jacobson &lt;[email protected]&gt;<span class="pl-pds">&quot;</span></span>);</td>
  4909. </tr>
  4910. <tr>
  4911. <td id="L971" class="blob-num js-line-number" data-line-number="971"></td>
  4912. <td id="LC971" class="blob-code blob-code-inner js-file-line"><span class="pl-en">MODULE_AUTHOR</span>(<span class="pl-s"><span class="pl-pds">&quot;</span>Neal Cardwell &lt;[email protected]&gt;<span class="pl-pds">&quot;</span></span>);</td>
  4913. </tr>
  4914. <tr>
  4915. <td id="L972" class="blob-num js-line-number" data-line-number="972"></td>
  4916. <td id="LC972" class="blob-code blob-code-inner js-file-line"><span class="pl-en">MODULE_AUTHOR</span>(<span class="pl-s"><span class="pl-pds">&quot;</span>Yuchung Cheng &lt;[email protected]&gt;<span class="pl-pds">&quot;</span></span>);</td>
  4917. </tr>
  4918. <tr>
  4919. <td id="L973" class="blob-num js-line-number" data-line-number="973"></td>
  4920. <td id="LC973" class="blob-code blob-code-inner js-file-line"><span class="pl-en">MODULE_AUTHOR</span>(<span class="pl-s"><span class="pl-pds">&quot;</span>Soheil Hassas Yeganeh &lt;[email protected]&gt;<span class="pl-pds">&quot;</span></span>);</td>
  4921. </tr>
  4922. <tr>
  4923. <td id="L974" class="blob-num js-line-number" data-line-number="974"></td>
  4924. <td id="LC974" class="blob-code blob-code-inner js-file-line"><span class="pl-en">MODULE_LICENSE</span>(<span class="pl-s"><span class="pl-pds">&quot;</span>Dual BSD/GPL<span class="pl-pds">&quot;</span></span>);</td>
  4925. </tr>
  4926. <tr>
  4927. <td id="L975" class="blob-num js-line-number" data-line-number="975"></td>
  4928. <td id="LC975" class="blob-code blob-code-inner js-file-line"><span class="pl-en">MODULE_DESCRIPTION</span>(<span class="pl-s"><span class="pl-pds">&quot;</span>TCP BBR (Bottleneck Bandwidth and RTT)<span class="pl-pds">&quot;</span></span>);</td>
  4929. </tr>
  4930. <tr>
  4931. <td id="L976" class="blob-num js-line-number" data-line-number="976"></td>
  4932. <td id="LC976" class="blob-code blob-code-inner js-file-line"><span class="pl-en">MODULE_AUTHOR</span>(<span class="pl-s"><span class="pl-pds">&quot;</span>Nanqinlang &lt;https://sometimesnaive.org&gt;<span class="pl-pds">&quot;</span></span>);</td>
  4933. </tr>
  4934. </table>
  4935. <div class="BlobToolbar position-absolute js-file-line-actions dropdown js-menu-container js-select-menu d-none" aria-hidden="true">
  4936. <button class="btn-octicon ml-0 px-2 p-0 bg-white border border-gray-dark rounded-1 dropdown-toggle js-menu-target" type="button" aria-expanded="false" aria-haspopup="true" aria-label="Inline file action toolbar" aria-controls="inline-file-actions">
  4937. <svg class="octicon octicon-kebab-horizontal" viewBox="0 0 13 16" version="1.1" width="13" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M1.5 9a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z"/></svg>
  4938. </button>
  4939. <div class="dropdown-menu-content js-menu-content" id="inline-file-actions">
  4940. <ul class="BlobToolbar-dropdown dropdown-menu dropdown-menu-se mt-2">
  4941. <li><clipboard-copy class="dropdown-item" id="js-copy-lines" style="cursor:pointer;" data-original-text="Copy lines">Copy lines</clipboard-copy></li>
  4942. <li><clipboard-copy class="dropdown-item" id="js-copy-permalink" style="cursor:pointer;" data-original-text="Copy permalink">Copy permalink</clipboard-copy></li>
  4943. <li><a class="dropdown-item js-update-url-with-hash" id="js-view-git-blame" href="/nanqinlang-tcp/tcp_nanqinlang/blame/b0a491158a2262641e4664c70ceaf70e53da9003/General/CentOS/source/tcp_nanqinlang.c">View git blame</a></li>
  4944. <li><a class="dropdown-item" id="js-new-issue" href="/nanqinlang-tcp/tcp_nanqinlang/issues/new">Open new issue</a></li>
  4945. </ul>
  4946. </div>
  4947. </div>
  4948. </div>
  4949. </div>
  4950. <button type="button" data-facebox="#jump-to-line" data-facebox-class="linejump" data-hotkey="l" class="d-none">Jump to Line</button>
  4951. <div id="jump-to-line" style="display:none">
  4952. <!-- '"` --><!-- </textarea></xmp> --></option></form><form class="js-jump-to-line-form" action="" accept-charset="UTF-8" method="get"><input name="utf8" type="hidden" value="&#x2713;" />
  4953. <input class="form-control linejump-input js-jump-to-line-field" type="text" placeholder="Jump to line&hellip;" aria-label="Jump to line" autofocus>
  4954. <button type="submit" class="btn">Go</button>
  4955. </form> </div>
  4956. </div>
  4957. <div class="modal-backdrop js-touch-events"></div>
  4958. </div>
  4959. </div>
  4960. </div>
  4961. </div>
  4962. <div class="footer container-lg px-3" role="contentinfo">
  4963. <div class="position-relative d-flex flex-justify-between pt-6 pb-2 mt-6 f6 text-gray border-top border-gray-light ">
  4964. <ul class="list-style-none d-flex flex-wrap ">
  4965. <li class="mr-3">&copy; 2018 <span title="0.36768s from unicorn-1759516498-56x3n">GitHub</span>, Inc.</li>
  4966. <li class="mr-3"><a data-ga-click="Footer, go to terms, text:terms" href="https://github.com/site/terms">Terms</a></li>
  4967. <li class="mr-3"><a data-ga-click="Footer, go to privacy, text:privacy" href="https://github.com/site/privacy">Privacy</a></li>
  4968. <li class="mr-3"><a href="https://help.github.com/articles/github-security/" data-ga-click="Footer, go to security, text:security">Security</a></li>
  4969. <li class="mr-3"><a href="https://status.github.com/" data-ga-click="Footer, go to status, text:status">Status</a></li>
  4970. <li><a data-ga-click="Footer, go to help, text:help" href="https://help.github.com">Help</a></li>
  4971. </ul>
  4972. <a aria-label="Homepage" title="GitHub" class="footer-octicon" href="https://github.com">
  4973. <svg height="24" class="octicon octicon-mark-github" viewBox="0 0 16 16" version="1.1" width="24" aria-hidden="true"><path fill-rule="evenodd" d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.013 8.013 0 0 0 16 8c0-4.42-3.58-8-8-8z"/></svg>
  4974. </a>
  4975. <ul class="list-style-none d-flex flex-wrap ">
  4976. <li class="mr-3"><a data-ga-click="Footer, go to contact, text:contact" href="https://github.com/contact">Contact GitHub</a></li>
  4977. <li class="mr-3"><a href="https://developer.github.com" data-ga-click="Footer, go to api, text:api">API</a></li>
  4978. <li class="mr-3"><a href="https://training.github.com" data-ga-click="Footer, go to training, text:training">Training</a></li>
  4979. <li class="mr-3"><a href="https://shop.github.com" data-ga-click="Footer, go to shop, text:shop">Shop</a></li>
  4980. <li class="mr-3"><a href="https://blog.github.com" data-ga-click="Footer, go to blog, text:blog">Blog</a></li>
  4981. <li><a data-ga-click="Footer, go to about, text:about" href="https://github.com/about">About</a></li>
  4982. </ul>
  4983. </div>
  4984. <div class="d-flex flex-justify-center pb-6">
  4985. <span class="f6 text-gray-light"></span>
  4986. </div>
  4987. </div>
  4988. <div id="ajax-error-message" class="ajax-error-message flash flash-error">
  4989. <svg class="octicon octicon-alert" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M8.865 1.52c-.18-.31-.51-.5-.87-.5s-.69.19-.87.5L.275 13.5c-.18.31-.18.69 0 1 .19.31.52.5.87.5h13.7c.36 0 .69-.19.86-.5.17-.31.18-.69.01-1L8.865 1.52zM8.995 13h-2v-2h2v2zm0-3h-2V6h2v4z"/></svg>
  4990. <button type="button" class="flash-close js-ajax-error-dismiss" aria-label="Dismiss error">
  4991. <svg class="octicon octicon-x" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M7.48 8l3.75 3.75-1.48 1.48L6 9.48l-3.75 3.75-1.48-1.48L4.52 8 .77 4.25l1.48-1.48L6 6.52l3.75-3.75 1.48 1.48z"/></svg>
  4992. </button>
  4993. You can’t perform that action at this time.
  4994. </div>
  4995. <script crossorigin="anonymous" integrity="sha512-YLTEICogXaxfaQDZUwqg/3a4NccBbSHhf09Ou0EicCGsUPw1DgA+lf7O42T+IuVhV00Z74YlU2TeBQE4qK5Nsw==" type="application/javascript" src="https://assets-cdn.github.com/assets/frameworks-9a6125048b93607a6410cfb641829177.js"></script>
  4996. <script crossorigin="anonymous" async="async" integrity="sha512-CIKOWHf7HIy+5i9exxokKEt3+mxAmeh0YINhAruS2MJfXj43lMM6ksHvhBW5sV2S8JAnbrd9NShZNXBu3uYH6w==" type="application/javascript" src="https://assets-cdn.github.com/assets/github-b1e9e262022e922ea69e1193b3d6a02c.js"></script>
  4997. <div class="js-stale-session-flash stale-session-flash flash flash-warn flash-banner d-none">
  4998. <svg class="octicon octicon-alert" viewBox="0 0 16 16" version="1.1" width="16" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M8.865 1.52c-.18-.31-.51-.5-.87-.5s-.69.19-.87.5L.275 13.5c-.18.31-.18.69 0 1 .19.31.52.5.87.5h13.7c.36 0 .69-.19.86-.5.17-.31.18-.69.01-1L8.865 1.52zM8.995 13h-2v-2h2v2zm0-3h-2V6h2v4z"/></svg>
  4999. <span class="signed-in-tab-flash">You signed in with another tab or window. <a href="">Reload</a> to refresh your session.</span>
  5000. <span class="signed-out-tab-flash">You signed out in another tab or window. <a href="">Reload</a> to refresh your session.</span>
  5001. </div>
  5002. <div class="facebox" id="facebox" style="display:none;">
  5003. <div class="facebox-popup">
  5004. <div class="facebox-content" role="dialog" aria-labelledby="facebox-header" aria-describedby="facebox-description">
  5005. </div>
  5006. <button type="button" class="facebox-close js-facebox-close" aria-label="Close modal">
  5007. <svg class="octicon octicon-x" viewBox="0 0 12 16" version="1.1" width="12" height="16" aria-hidden="true"><path fill-rule="evenodd" d="M7.48 8l3.75 3.75-1.48 1.48L6 9.48l-3.75 3.75-1.48-1.48L4.52 8 .77 4.25l1.48-1.48L6 6.52l3.75-3.75 1.48 1.48z"/></svg>
  5008. </button>
  5009. </div>
  5010. </div>
  5011. <div class="Popover js-hovercard-content position-absolute" style="display: none; outline: none;" tabindex="0">
  5012. <div class="Popover-message Popover-message--bottom-left Popover-message--large Box box-shadow-large" style="width:360px;">
  5013. </div>
  5014. </div>
  5015. <div id="hovercard-aria-description" class="sr-only">
  5016. Press h to open a hovercard with more details.
  5017. </div>
  5018. </body>
  5019. </html>