patch_realtek.c 628 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849985098519852985398549855985698579858985998609861986298639864986598669867986898699870987198729873987498759876987798789879988098819882988398849885988698879888988998909891989298939894989598969897989898999900990199029903990499059906990799089909991099119912991399149915991699179918991999209921992299239924992599269927992899299930993199329933993499359936993799389939994099419942994399449945994699479948994999509951995299539954995599569957995899599960996199629963996499659966996799689969997099719972997399749975997699779978997999809981998299839984998599869987998899899990999199929993999499959996999799989999100001000110002100031000410005100061000710008100091001010011100121001310014100151001610017100181001910020100211002210023100241002510026100271002810029100301003110032100331003410035100361003710038100391004010041100421004310044100451004610047100481004910050100511005210053100541005510056100571005810059100601006110062100631006410065100661006710068100691007010071100721007310074100751007610077100781007910080100811008210083100841008510086100871008810089100901009110092100931009410095100961009710098100991010010101101021010310104101051010610107101081010910110101111011210113101141011510116101171011810119101201012110122101231012410125101261012710128101291013010131101321013310134101351013610137101381013910140101411014210143101441014510146101471014810149101501015110152101531015410155101561015710158101591016010161101621016310164101651016610167101681016910170101711017210173101741017510176101771017810179101801018110182101831018410185101861018710188101891019010191101921019310194101951019610197101981019910200102011020210203102041020510206102071020810209102101021110212102131021410215102161021710218102191022010221102221022310224102251022610227102281022910230102311023210233102341023510236102371023810239102401024110242102431024410245102461024710248102491025010251102521025310254102551025610257102581025910260102611026210263102641026510266102671026810269102701027110272102731027410275102761027710278102791028010281102821028310284102851028610287102881028910290102911029210293102941029510296102971029810299103001030110302103031030410305103061030710308103091031010311103121031310314103151031610317103181031910320103211032210323103241032510326103271032810329103301033110332103331033410335103361033710338103391034010341103421034310344103451034610347103481034910350103511035210353103541035510356103571035810359103601036110362103631036410365103661036710368103691037010371103721037310374103751037610377103781037910380103811038210383103841038510386103871038810389103901039110392103931039410395103961039710398103991040010401104021040310404104051040610407104081040910410104111041210413104141041510416104171041810419104201042110422104231042410425104261042710428104291043010431104321043310434104351043610437104381043910440104411044210443104441044510446104471044810449104501045110452104531045410455104561045710458104591046010461104621046310464104651046610467104681046910470104711047210473104741047510476104771047810479104801048110482104831048410485104861048710488104891049010491104921049310494104951049610497104981049910500105011050210503105041050510506105071050810509105101051110512105131051410515105161051710518105191052010521105221052310524105251052610527105281052910530105311053210533105341053510536105371053810539105401054110542105431054410545105461054710548105491055010551105521055310554105551055610557105581055910560105611056210563105641056510566105671056810569105701057110572105731057410575105761057710578105791058010581105821058310584105851058610587105881058910590105911059210593105941059510596105971059810599106001060110602106031060410605106061060710608106091061010611106121061310614106151061610617106181061910620106211062210623106241062510626106271062810629106301063110632106331063410635106361063710638106391064010641106421064310644106451064610647106481064910650106511065210653106541065510656106571065810659106601066110662106631066410665106661066710668106691067010671106721067310674106751067610677106781067910680106811068210683106841068510686106871068810689106901069110692106931069410695106961069710698106991070010701107021070310704107051070610707107081070910710107111071210713107141071510716107171071810719107201072110722107231072410725107261072710728107291073010731107321073310734107351073610737107381073910740107411074210743107441074510746107471074810749107501075110752107531075410755107561075710758107591076010761107621076310764107651076610767107681076910770107711077210773107741077510776107771077810779107801078110782107831078410785107861078710788107891079010791107921079310794107951079610797107981079910800108011080210803108041080510806108071080810809108101081110812108131081410815108161081710818108191082010821108221082310824108251082610827108281082910830108311083210833108341083510836108371083810839108401084110842108431084410845108461084710848108491085010851108521085310854108551085610857108581085910860108611086210863108641086510866108671086810869108701087110872108731087410875108761087710878108791088010881108821088310884108851088610887108881088910890108911089210893108941089510896108971089810899109001090110902109031090410905109061090710908109091091010911109121091310914109151091610917109181091910920109211092210923109241092510926109271092810929109301093110932109331093410935109361093710938109391094010941109421094310944109451094610947109481094910950109511095210953109541095510956109571095810959109601096110962109631096410965109661096710968109691097010971109721097310974109751097610977109781097910980109811098210983109841098510986109871098810989109901099110992109931099410995109961099710998109991100011001110021100311004110051100611007110081100911010110111101211013110141101511016110171101811019110201102111022110231102411025110261102711028110291103011031110321103311034110351103611037110381103911040110411104211043110441104511046110471104811049110501105111052110531105411055110561105711058110591106011061110621106311064110651106611067110681106911070110711107211073110741107511076110771107811079110801108111082110831108411085110861108711088110891109011091110921109311094110951109611097110981109911100111011110211103111041110511106111071110811109111101111111112111131111411115111161111711118111191112011121111221112311124111251112611127111281112911130111311113211133111341113511136111371113811139111401114111142111431114411145111461114711148111491115011151111521115311154111551115611157111581115911160111611116211163111641116511166111671116811169111701117111172111731117411175111761117711178111791118011181111821118311184111851118611187111881118911190111911119211193111941119511196111971119811199112001120111202112031120411205112061120711208112091121011211112121121311214112151121611217112181121911220112211122211223112241122511226112271122811229112301123111232112331123411235112361123711238112391124011241112421124311244112451124611247112481124911250112511125211253112541125511256112571125811259112601126111262112631126411265112661126711268112691127011271112721127311274112751127611277112781127911280112811128211283112841128511286112871128811289112901129111292112931129411295112961129711298112991130011301113021130311304113051130611307113081130911310113111131211313113141131511316113171131811319113201132111322113231132411325113261132711328113291133011331113321133311334113351133611337113381133911340113411134211343113441134511346113471134811349113501135111352113531135411355113561135711358113591136011361113621136311364113651136611367113681136911370113711137211373113741137511376113771137811379113801138111382113831138411385113861138711388113891139011391113921139311394113951139611397113981139911400114011140211403114041140511406114071140811409114101141111412114131141411415114161141711418114191142011421114221142311424114251142611427114281142911430114311143211433114341143511436114371143811439114401144111442114431144411445114461144711448114491145011451114521145311454114551145611457114581145911460114611146211463114641146511466114671146811469114701147111472114731147411475114761147711478114791148011481114821148311484114851148611487114881148911490114911149211493114941149511496114971149811499115001150111502115031150411505115061150711508115091151011511115121151311514115151151611517115181151911520115211152211523115241152511526115271152811529115301153111532115331153411535115361153711538115391154011541115421154311544115451154611547115481154911550115511155211553115541155511556115571155811559115601156111562115631156411565115661156711568115691157011571115721157311574115751157611577115781157911580115811158211583115841158511586115871158811589115901159111592115931159411595115961159711598115991160011601116021160311604116051160611607116081160911610116111161211613116141161511616116171161811619116201162111622116231162411625116261162711628116291163011631116321163311634116351163611637116381163911640116411164211643116441164511646116471164811649116501165111652116531165411655116561165711658116591166011661116621166311664116651166611667116681166911670116711167211673116741167511676116771167811679116801168111682116831168411685116861168711688116891169011691116921169311694116951169611697116981169911700117011170211703117041170511706117071170811709117101171111712117131171411715117161171711718117191172011721117221172311724117251172611727117281172911730117311173211733117341173511736117371173811739117401174111742117431174411745117461174711748117491175011751117521175311754117551175611757117581175911760117611176211763117641176511766117671176811769117701177111772117731177411775117761177711778117791178011781117821178311784117851178611787117881178911790117911179211793117941179511796117971179811799118001180111802118031180411805118061180711808118091181011811118121181311814118151181611817118181181911820118211182211823118241182511826118271182811829118301183111832118331183411835118361183711838118391184011841118421184311844118451184611847118481184911850118511185211853118541185511856118571185811859118601186111862118631186411865118661186711868118691187011871118721187311874118751187611877118781187911880118811188211883118841188511886118871188811889118901189111892118931189411895118961189711898118991190011901119021190311904119051190611907119081190911910119111191211913119141191511916119171191811919119201192111922119231192411925119261192711928119291193011931119321193311934119351193611937119381193911940119411194211943119441194511946119471194811949119501195111952119531195411955119561195711958119591196011961119621196311964119651196611967119681196911970119711197211973119741197511976119771197811979119801198111982119831198411985119861198711988119891199011991119921199311994119951199611997119981199912000120011200212003120041200512006120071200812009120101201112012120131201412015120161201712018120191202012021120221202312024120251202612027120281202912030120311203212033120341203512036120371203812039120401204112042120431204412045120461204712048120491205012051120521205312054120551205612057120581205912060120611206212063120641206512066120671206812069120701207112072120731207412075120761207712078120791208012081120821208312084120851208612087120881208912090120911209212093120941209512096120971209812099121001210112102121031210412105121061210712108121091211012111121121211312114121151211612117121181211912120121211212212123121241212512126121271212812129121301213112132121331213412135121361213712138121391214012141121421214312144121451214612147121481214912150121511215212153121541215512156121571215812159121601216112162121631216412165121661216712168121691217012171121721217312174121751217612177121781217912180121811218212183121841218512186121871218812189121901219112192121931219412195121961219712198121991220012201122021220312204122051220612207122081220912210122111221212213122141221512216122171221812219122201222112222122231222412225122261222712228122291223012231122321223312234122351223612237122381223912240122411224212243122441224512246122471224812249122501225112252122531225412255122561225712258122591226012261122621226312264122651226612267122681226912270122711227212273122741227512276122771227812279122801228112282122831228412285122861228712288122891229012291122921229312294122951229612297122981229912300123011230212303123041230512306123071230812309123101231112312123131231412315123161231712318123191232012321123221232312324123251232612327123281232912330123311233212333123341233512336123371233812339123401234112342123431234412345123461234712348123491235012351123521235312354123551235612357123581235912360123611236212363123641236512366123671236812369123701237112372123731237412375123761237712378123791238012381123821238312384123851238612387123881238912390123911239212393123941239512396123971239812399124001240112402124031240412405124061240712408124091241012411124121241312414124151241612417124181241912420124211242212423124241242512426124271242812429124301243112432124331243412435124361243712438124391244012441124421244312444124451244612447124481244912450124511245212453124541245512456124571245812459124601246112462124631246412465124661246712468124691247012471124721247312474124751247612477124781247912480124811248212483124841248512486124871248812489124901249112492124931249412495124961249712498124991250012501125021250312504125051250612507125081250912510125111251212513125141251512516125171251812519125201252112522125231252412525125261252712528125291253012531125321253312534125351253612537125381253912540125411254212543125441254512546125471254812549125501255112552125531255412555125561255712558125591256012561125621256312564125651256612567125681256912570125711257212573125741257512576125771257812579125801258112582125831258412585125861258712588125891259012591125921259312594125951259612597125981259912600126011260212603126041260512606126071260812609126101261112612126131261412615126161261712618126191262012621126221262312624126251262612627126281262912630126311263212633126341263512636126371263812639126401264112642126431264412645126461264712648126491265012651126521265312654126551265612657126581265912660126611266212663126641266512666126671266812669126701267112672126731267412675126761267712678126791268012681126821268312684126851268612687126881268912690126911269212693126941269512696126971269812699127001270112702127031270412705127061270712708127091271012711127121271312714127151271612717127181271912720127211272212723127241272512726127271272812729127301273112732127331273412735127361273712738127391274012741127421274312744127451274612747127481274912750127511275212753127541275512756127571275812759127601276112762127631276412765127661276712768127691277012771127721277312774127751277612777127781277912780127811278212783127841278512786127871278812789127901279112792127931279412795127961279712798127991280012801128021280312804128051280612807128081280912810128111281212813128141281512816128171281812819128201282112822128231282412825128261282712828128291283012831128321283312834128351283612837128381283912840128411284212843128441284512846128471284812849128501285112852128531285412855128561285712858128591286012861128621286312864128651286612867128681286912870128711287212873128741287512876128771287812879128801288112882128831288412885128861288712888128891289012891128921289312894128951289612897128981289912900129011290212903129041290512906129071290812909129101291112912129131291412915129161291712918129191292012921129221292312924129251292612927129281292912930129311293212933129341293512936129371293812939129401294112942129431294412945129461294712948129491295012951129521295312954129551295612957129581295912960129611296212963129641296512966129671296812969129701297112972129731297412975129761297712978129791298012981129821298312984129851298612987129881298912990129911299212993129941299512996129971299812999130001300113002130031300413005130061300713008130091301013011130121301313014130151301613017130181301913020130211302213023130241302513026130271302813029130301303113032130331303413035130361303713038130391304013041130421304313044130451304613047130481304913050130511305213053130541305513056130571305813059130601306113062130631306413065130661306713068130691307013071130721307313074130751307613077130781307913080130811308213083130841308513086130871308813089130901309113092130931309413095130961309713098130991310013101131021310313104131051310613107131081310913110131111311213113131141311513116131171311813119131201312113122131231312413125131261312713128131291313013131131321313313134131351313613137131381313913140131411314213143131441314513146131471314813149131501315113152131531315413155131561315713158131591316013161131621316313164131651316613167131681316913170131711317213173131741317513176131771317813179131801318113182131831318413185131861318713188131891319013191131921319313194131951319613197131981319913200132011320213203132041320513206132071320813209132101321113212132131321413215132161321713218132191322013221132221322313224132251322613227132281322913230132311323213233132341323513236132371323813239132401324113242132431324413245132461324713248132491325013251132521325313254132551325613257132581325913260132611326213263132641326513266132671326813269132701327113272132731327413275132761327713278132791328013281132821328313284132851328613287132881328913290132911329213293132941329513296132971329813299133001330113302133031330413305133061330713308133091331013311133121331313314133151331613317133181331913320133211332213323133241332513326133271332813329133301333113332133331333413335133361333713338133391334013341133421334313344133451334613347133481334913350133511335213353133541335513356133571335813359133601336113362133631336413365133661336713368133691337013371133721337313374133751337613377133781337913380133811338213383133841338513386133871338813389133901339113392133931339413395133961339713398133991340013401134021340313404134051340613407134081340913410134111341213413134141341513416134171341813419134201342113422134231342413425134261342713428134291343013431134321343313434134351343613437134381343913440134411344213443134441344513446134471344813449134501345113452134531345413455134561345713458134591346013461134621346313464134651346613467134681346913470134711347213473134741347513476134771347813479134801348113482134831348413485134861348713488134891349013491134921349313494134951349613497134981349913500135011350213503135041350513506135071350813509135101351113512135131351413515135161351713518135191352013521135221352313524135251352613527135281352913530135311353213533135341353513536135371353813539135401354113542135431354413545135461354713548135491355013551135521355313554135551355613557135581355913560135611356213563135641356513566135671356813569135701357113572135731357413575135761357713578135791358013581135821358313584135851358613587135881358913590135911359213593135941359513596135971359813599136001360113602136031360413605136061360713608136091361013611136121361313614136151361613617136181361913620136211362213623136241362513626136271362813629136301363113632136331363413635136361363713638136391364013641136421364313644136451364613647136481364913650136511365213653136541365513656136571365813659136601366113662136631366413665136661366713668136691367013671136721367313674136751367613677136781367913680136811368213683136841368513686136871368813689136901369113692136931369413695136961369713698136991370013701137021370313704137051370613707137081370913710137111371213713137141371513716137171371813719137201372113722137231372413725137261372713728137291373013731137321373313734137351373613737137381373913740137411374213743137441374513746137471374813749137501375113752137531375413755137561375713758137591376013761137621376313764137651376613767137681376913770137711377213773137741377513776137771377813779137801378113782137831378413785137861378713788137891379013791137921379313794137951379613797137981379913800138011380213803138041380513806138071380813809138101381113812138131381413815138161381713818138191382013821138221382313824138251382613827138281382913830138311383213833138341383513836138371383813839138401384113842138431384413845138461384713848138491385013851138521385313854138551385613857138581385913860138611386213863138641386513866138671386813869138701387113872138731387413875138761387713878138791388013881138821388313884138851388613887138881388913890138911389213893138941389513896138971389813899139001390113902139031390413905139061390713908139091391013911139121391313914139151391613917139181391913920139211392213923139241392513926139271392813929139301393113932139331393413935139361393713938139391394013941139421394313944139451394613947139481394913950139511395213953139541395513956139571395813959139601396113962139631396413965139661396713968139691397013971139721397313974139751397613977139781397913980139811398213983139841398513986139871398813989139901399113992139931399413995139961399713998139991400014001140021400314004140051400614007140081400914010140111401214013140141401514016140171401814019140201402114022140231402414025140261402714028140291403014031140321403314034140351403614037140381403914040140411404214043140441404514046140471404814049140501405114052140531405414055140561405714058140591406014061140621406314064140651406614067140681406914070140711407214073140741407514076140771407814079140801408114082140831408414085140861408714088140891409014091140921409314094140951409614097140981409914100141011410214103141041410514106141071410814109141101411114112141131411414115141161411714118141191412014121141221412314124141251412614127141281412914130141311413214133141341413514136141371413814139141401414114142141431414414145141461414714148141491415014151141521415314154141551415614157141581415914160141611416214163141641416514166141671416814169141701417114172141731417414175141761417714178141791418014181141821418314184141851418614187141881418914190141911419214193141941419514196141971419814199142001420114202142031420414205142061420714208142091421014211142121421314214142151421614217142181421914220142211422214223142241422514226142271422814229142301423114232142331423414235142361423714238142391424014241142421424314244142451424614247142481424914250142511425214253142541425514256142571425814259142601426114262142631426414265142661426714268142691427014271142721427314274142751427614277142781427914280142811428214283142841428514286142871428814289142901429114292142931429414295142961429714298142991430014301143021430314304143051430614307143081430914310143111431214313143141431514316143171431814319143201432114322143231432414325143261432714328143291433014331143321433314334143351433614337143381433914340143411434214343143441434514346143471434814349143501435114352143531435414355143561435714358143591436014361143621436314364143651436614367143681436914370143711437214373143741437514376143771437814379143801438114382143831438414385143861438714388143891439014391143921439314394143951439614397143981439914400144011440214403144041440514406144071440814409144101441114412144131441414415144161441714418144191442014421144221442314424144251442614427144281442914430144311443214433144341443514436144371443814439144401444114442144431444414445144461444714448144491445014451144521445314454144551445614457144581445914460144611446214463144641446514466144671446814469144701447114472144731447414475144761447714478144791448014481144821448314484144851448614487144881448914490144911449214493144941449514496144971449814499145001450114502145031450414505145061450714508145091451014511145121451314514145151451614517145181451914520145211452214523145241452514526145271452814529145301453114532145331453414535145361453714538145391454014541145421454314544145451454614547145481454914550145511455214553145541455514556145571455814559145601456114562145631456414565145661456714568145691457014571145721457314574145751457614577145781457914580145811458214583145841458514586145871458814589145901459114592145931459414595145961459714598145991460014601146021460314604146051460614607146081460914610146111461214613146141461514616146171461814619146201462114622146231462414625146261462714628146291463014631146321463314634146351463614637146381463914640146411464214643146441464514646146471464814649146501465114652146531465414655146561465714658146591466014661146621466314664146651466614667146681466914670146711467214673146741467514676146771467814679146801468114682146831468414685146861468714688146891469014691146921469314694146951469614697146981469914700147011470214703147041470514706147071470814709147101471114712147131471414715147161471714718147191472014721147221472314724147251472614727147281472914730147311473214733147341473514736147371473814739147401474114742147431474414745147461474714748147491475014751147521475314754147551475614757147581475914760147611476214763147641476514766147671476814769147701477114772147731477414775147761477714778147791478014781147821478314784147851478614787147881478914790147911479214793147941479514796147971479814799148001480114802148031480414805148061480714808148091481014811148121481314814148151481614817148181481914820148211482214823148241482514826148271482814829148301483114832148331483414835148361483714838148391484014841148421484314844148451484614847148481484914850148511485214853148541485514856148571485814859148601486114862148631486414865148661486714868148691487014871148721487314874148751487614877148781487914880148811488214883148841488514886148871488814889148901489114892148931489414895148961489714898148991490014901149021490314904149051490614907149081490914910149111491214913149141491514916149171491814919149201492114922149231492414925149261492714928149291493014931149321493314934149351493614937149381493914940149411494214943149441494514946149471494814949149501495114952149531495414955149561495714958149591496014961149621496314964149651496614967149681496914970149711497214973149741497514976149771497814979149801498114982149831498414985149861498714988149891499014991149921499314994149951499614997149981499915000150011500215003150041500515006150071500815009150101501115012150131501415015150161501715018150191502015021150221502315024150251502615027150281502915030150311503215033150341503515036150371503815039150401504115042150431504415045150461504715048150491505015051150521505315054150551505615057150581505915060150611506215063150641506515066150671506815069150701507115072150731507415075150761507715078150791508015081150821508315084150851508615087150881508915090150911509215093150941509515096150971509815099151001510115102151031510415105151061510715108151091511015111151121511315114151151511615117151181511915120151211512215123151241512515126151271512815129151301513115132151331513415135151361513715138151391514015141151421514315144151451514615147151481514915150151511515215153151541515515156151571515815159151601516115162151631516415165151661516715168151691517015171151721517315174151751517615177151781517915180151811518215183151841518515186151871518815189151901519115192151931519415195151961519715198151991520015201152021520315204152051520615207152081520915210152111521215213152141521515216152171521815219152201522115222152231522415225152261522715228152291523015231152321523315234152351523615237152381523915240152411524215243152441524515246152471524815249152501525115252152531525415255152561525715258152591526015261152621526315264152651526615267152681526915270152711527215273152741527515276152771527815279152801528115282152831528415285152861528715288152891529015291152921529315294152951529615297152981529915300153011530215303153041530515306153071530815309153101531115312153131531415315153161531715318153191532015321153221532315324153251532615327153281532915330153311533215333153341533515336153371533815339153401534115342153431534415345153461534715348153491535015351153521535315354153551535615357153581535915360153611536215363153641536515366153671536815369153701537115372153731537415375153761537715378153791538015381153821538315384153851538615387153881538915390153911539215393153941539515396153971539815399154001540115402154031540415405154061540715408154091541015411154121541315414154151541615417154181541915420154211542215423154241542515426154271542815429154301543115432154331543415435154361543715438154391544015441154421544315444154451544615447154481544915450154511545215453154541545515456154571545815459154601546115462154631546415465154661546715468154691547015471154721547315474154751547615477154781547915480154811548215483154841548515486154871548815489154901549115492154931549415495154961549715498154991550015501155021550315504155051550615507155081550915510155111551215513155141551515516155171551815519155201552115522155231552415525155261552715528155291553015531155321553315534155351553615537155381553915540155411554215543155441554515546155471554815549155501555115552155531555415555155561555715558155591556015561155621556315564155651556615567155681556915570155711557215573155741557515576155771557815579155801558115582155831558415585155861558715588155891559015591155921559315594155951559615597155981559915600156011560215603156041560515606156071560815609156101561115612156131561415615156161561715618156191562015621156221562315624156251562615627156281562915630156311563215633156341563515636156371563815639156401564115642156431564415645156461564715648156491565015651156521565315654156551565615657156581565915660156611566215663156641566515666156671566815669156701567115672156731567415675156761567715678156791568015681156821568315684156851568615687156881568915690156911569215693156941569515696156971569815699157001570115702157031570415705157061570715708157091571015711157121571315714157151571615717157181571915720157211572215723157241572515726157271572815729157301573115732157331573415735157361573715738157391574015741157421574315744157451574615747157481574915750157511575215753157541575515756157571575815759157601576115762157631576415765157661576715768157691577015771157721577315774157751577615777157781577915780157811578215783157841578515786157871578815789157901579115792157931579415795157961579715798157991580015801158021580315804158051580615807158081580915810158111581215813158141581515816158171581815819158201582115822158231582415825158261582715828158291583015831158321583315834158351583615837158381583915840158411584215843158441584515846158471584815849158501585115852158531585415855158561585715858158591586015861158621586315864158651586615867158681586915870158711587215873158741587515876158771587815879158801588115882158831588415885158861588715888158891589015891158921589315894158951589615897158981589915900159011590215903159041590515906159071590815909159101591115912159131591415915159161591715918159191592015921159221592315924159251592615927159281592915930159311593215933159341593515936159371593815939159401594115942159431594415945159461594715948159491595015951159521595315954159551595615957159581595915960159611596215963159641596515966159671596815969159701597115972159731597415975159761597715978159791598015981159821598315984159851598615987159881598915990159911599215993159941599515996159971599815999160001600116002160031600416005160061600716008160091601016011160121601316014160151601616017160181601916020160211602216023160241602516026160271602816029160301603116032160331603416035160361603716038160391604016041160421604316044160451604616047160481604916050160511605216053160541605516056160571605816059160601606116062160631606416065160661606716068160691607016071160721607316074160751607616077160781607916080160811608216083160841608516086160871608816089160901609116092160931609416095160961609716098160991610016101161021610316104161051610616107161081610916110161111611216113161141611516116161171611816119161201612116122161231612416125161261612716128161291613016131161321613316134161351613616137161381613916140161411614216143161441614516146161471614816149161501615116152161531615416155161561615716158161591616016161161621616316164161651616616167161681616916170161711617216173161741617516176161771617816179161801618116182161831618416185161861618716188161891619016191161921619316194161951619616197161981619916200162011620216203162041620516206162071620816209162101621116212162131621416215162161621716218162191622016221162221622316224162251622616227162281622916230162311623216233162341623516236162371623816239162401624116242162431624416245162461624716248162491625016251162521625316254162551625616257162581625916260162611626216263162641626516266162671626816269162701627116272162731627416275162761627716278162791628016281162821628316284162851628616287162881628916290162911629216293162941629516296162971629816299163001630116302163031630416305163061630716308163091631016311163121631316314163151631616317163181631916320163211632216323163241632516326163271632816329163301633116332163331633416335163361633716338163391634016341163421634316344163451634616347163481634916350163511635216353163541635516356163571635816359163601636116362163631636416365163661636716368163691637016371163721637316374163751637616377163781637916380163811638216383163841638516386163871638816389163901639116392163931639416395163961639716398163991640016401164021640316404164051640616407164081640916410164111641216413164141641516416164171641816419164201642116422164231642416425164261642716428164291643016431164321643316434164351643616437164381643916440164411644216443164441644516446164471644816449164501645116452164531645416455164561645716458164591646016461164621646316464164651646616467164681646916470164711647216473164741647516476164771647816479164801648116482164831648416485164861648716488164891649016491164921649316494164951649616497164981649916500165011650216503165041650516506165071650816509165101651116512165131651416515165161651716518165191652016521165221652316524165251652616527165281652916530165311653216533165341653516536165371653816539165401654116542165431654416545165461654716548165491655016551165521655316554165551655616557165581655916560165611656216563165641656516566165671656816569165701657116572165731657416575165761657716578165791658016581165821658316584165851658616587165881658916590165911659216593165941659516596165971659816599166001660116602166031660416605166061660716608166091661016611166121661316614166151661616617166181661916620166211662216623166241662516626166271662816629166301663116632166331663416635166361663716638166391664016641166421664316644166451664616647166481664916650166511665216653166541665516656166571665816659166601666116662166631666416665166661666716668166691667016671166721667316674166751667616677166781667916680166811668216683166841668516686166871668816689166901669116692166931669416695166961669716698166991670016701167021670316704167051670616707167081670916710167111671216713167141671516716167171671816719167201672116722167231672416725167261672716728167291673016731167321673316734167351673616737167381673916740167411674216743167441674516746167471674816749167501675116752167531675416755167561675716758167591676016761167621676316764167651676616767167681676916770167711677216773167741677516776167771677816779167801678116782167831678416785167861678716788167891679016791167921679316794167951679616797167981679916800168011680216803168041680516806168071680816809168101681116812168131681416815168161681716818168191682016821168221682316824168251682616827168281682916830168311683216833168341683516836168371683816839168401684116842168431684416845168461684716848168491685016851168521685316854168551685616857168581685916860168611686216863168641686516866168671686816869168701687116872168731687416875168761687716878168791688016881168821688316884168851688616887168881688916890168911689216893168941689516896168971689816899169001690116902169031690416905169061690716908169091691016911169121691316914169151691616917169181691916920169211692216923169241692516926169271692816929169301693116932169331693416935169361693716938169391694016941169421694316944169451694616947169481694916950169511695216953169541695516956169571695816959169601696116962169631696416965169661696716968169691697016971169721697316974169751697616977169781697916980169811698216983169841698516986169871698816989169901699116992169931699416995169961699716998169991700017001170021700317004170051700617007170081700917010170111701217013170141701517016170171701817019170201702117022170231702417025170261702717028170291703017031170321703317034170351703617037170381703917040170411704217043170441704517046170471704817049170501705117052170531705417055170561705717058170591706017061170621706317064170651706617067170681706917070170711707217073170741707517076170771707817079170801708117082170831708417085170861708717088170891709017091170921709317094170951709617097170981709917100171011710217103171041710517106171071710817109171101711117112171131711417115171161711717118171191712017121171221712317124171251712617127171281712917130171311713217133171341713517136171371713817139171401714117142171431714417145171461714717148171491715017151171521715317154171551715617157171581715917160171611716217163171641716517166171671716817169171701717117172171731717417175171761717717178171791718017181171821718317184171851718617187171881718917190171911719217193171941719517196171971719817199172001720117202172031720417205172061720717208172091721017211172121721317214172151721617217172181721917220172211722217223172241722517226172271722817229172301723117232172331723417235172361723717238172391724017241172421724317244172451724617247172481724917250172511725217253172541725517256172571725817259172601726117262172631726417265172661726717268172691727017271172721727317274172751727617277172781727917280172811728217283172841728517286172871728817289172901729117292172931729417295172961729717298172991730017301173021730317304173051730617307173081730917310173111731217313173141731517316173171731817319173201732117322173231732417325173261732717328173291733017331173321733317334173351733617337173381733917340173411734217343173441734517346173471734817349173501735117352173531735417355173561735717358173591736017361173621736317364173651736617367173681736917370173711737217373173741737517376173771737817379173801738117382173831738417385173861738717388173891739017391173921739317394173951739617397173981739917400174011740217403174041740517406174071740817409174101741117412174131741417415174161741717418174191742017421174221742317424174251742617427174281742917430174311743217433174341743517436174371743817439174401744117442174431744417445174461744717448174491745017451174521745317454174551745617457174581745917460174611746217463174641746517466174671746817469174701747117472174731747417475174761747717478174791748017481174821748317484174851748617487174881748917490174911749217493174941749517496174971749817499175001750117502175031750417505175061750717508175091751017511175121751317514175151751617517175181751917520175211752217523175241752517526175271752817529175301753117532175331753417535175361753717538175391754017541175421754317544175451754617547175481754917550175511755217553175541755517556175571755817559175601756117562175631756417565175661756717568175691757017571175721757317574175751757617577175781757917580175811758217583175841758517586175871758817589175901759117592175931759417595175961759717598175991760017601176021760317604176051760617607176081760917610176111761217613176141761517616176171761817619176201762117622176231762417625176261762717628176291763017631176321763317634176351763617637176381763917640176411764217643176441764517646176471764817649176501765117652176531765417655176561765717658176591766017661176621766317664176651766617667176681766917670176711767217673176741767517676176771767817679176801768117682176831768417685176861768717688176891769017691176921769317694176951769617697176981769917700177011770217703177041770517706177071770817709177101771117712177131771417715177161771717718177191772017721177221772317724177251772617727177281772917730177311773217733177341773517736177371773817739177401774117742177431774417745177461774717748177491775017751177521775317754177551775617757177581775917760177611776217763177641776517766177671776817769177701777117772177731777417775177761777717778177791778017781177821778317784177851778617787177881778917790177911779217793177941779517796177971779817799178001780117802178031780417805178061780717808178091781017811178121781317814178151781617817178181781917820178211782217823178241782517826178271782817829178301783117832178331783417835178361783717838178391784017841178421784317844178451784617847178481784917850178511785217853178541785517856178571785817859178601786117862178631786417865178661786717868178691787017871178721787317874178751787617877178781787917880178811788217883178841788517886178871788817889178901789117892178931789417895178961789717898178991790017901179021790317904179051790617907179081790917910179111791217913179141791517916179171791817919179201792117922179231792417925179261792717928179291793017931179321793317934179351793617937179381793917940179411794217943179441794517946179471794817949179501795117952179531795417955179561795717958179591796017961179621796317964179651796617967179681796917970179711797217973179741797517976179771797817979179801798117982179831798417985179861798717988179891799017991179921799317994179951799617997179981799918000180011800218003180041800518006180071800818009180101801118012180131801418015180161801718018180191802018021180221802318024180251802618027180281802918030180311803218033180341803518036180371803818039180401804118042180431804418045180461804718048180491805018051180521805318054180551805618057180581805918060180611806218063180641806518066180671806818069180701807118072180731807418075180761807718078180791808018081180821808318084180851808618087180881808918090180911809218093180941809518096180971809818099181001810118102181031810418105181061810718108181091811018111181121811318114181151811618117181181811918120181211812218123181241812518126181271812818129181301813118132181331813418135181361813718138181391814018141181421814318144181451814618147181481814918150181511815218153181541815518156181571815818159181601816118162181631816418165181661816718168181691817018171181721817318174181751817618177181781817918180181811818218183181841818518186181871818818189181901819118192181931819418195181961819718198181991820018201182021820318204182051820618207182081820918210182111821218213182141821518216182171821818219182201822118222182231822418225182261822718228182291823018231182321823318234182351823618237182381823918240182411824218243182441824518246182471824818249182501825118252182531825418255182561825718258182591826018261182621826318264182651826618267182681826918270182711827218273182741827518276182771827818279182801828118282182831828418285182861828718288182891829018291182921829318294182951829618297182981829918300183011830218303183041830518306183071830818309183101831118312183131831418315183161831718318183191832018321183221832318324183251832618327183281832918330183311833218333183341833518336183371833818339183401834118342183431834418345183461834718348183491835018351183521835318354183551835618357183581835918360183611836218363183641836518366183671836818369183701837118372183731837418375183761837718378183791838018381183821838318384183851838618387183881838918390183911839218393183941839518396183971839818399184001840118402184031840418405184061840718408184091841018411184121841318414184151841618417184181841918420184211842218423184241842518426184271842818429184301843118432184331843418435184361843718438184391844018441184421844318444184451844618447184481844918450184511845218453184541845518456184571845818459184601846118462184631846418465184661846718468184691847018471184721847318474184751847618477184781847918480184811848218483184841848518486184871848818489184901849118492184931849418495184961849718498184991850018501185021850318504185051850618507185081850918510185111851218513185141851518516185171851818519185201852118522185231852418525185261852718528185291853018531185321853318534185351853618537185381853918540185411854218543185441854518546185471854818549185501855118552185531855418555185561855718558185591856018561185621856318564185651856618567185681856918570185711857218573185741857518576185771857818579185801858118582185831858418585185861858718588185891859018591185921859318594185951859618597185981859918600186011860218603186041860518606186071860818609186101861118612186131861418615186161861718618186191862018621186221862318624186251862618627186281862918630186311863218633186341863518636186371863818639186401864118642186431864418645186461864718648186491865018651186521865318654186551865618657186581865918660186611866218663186641866518666186671866818669186701867118672186731867418675186761867718678186791868018681186821868318684186851868618687186881868918690186911869218693186941869518696186971869818699187001870118702187031870418705187061870718708187091871018711187121871318714187151871618717187181871918720187211872218723187241872518726187271872818729187301873118732187331873418735187361873718738187391874018741187421874318744187451874618747187481874918750187511875218753187541875518756187571875818759187601876118762187631876418765187661876718768187691877018771187721877318774187751877618777187781877918780187811878218783187841878518786187871878818789187901879118792187931879418795187961879718798187991880018801188021880318804188051880618807188081880918810188111881218813188141881518816188171881818819188201882118822188231882418825188261882718828188291883018831188321883318834188351883618837188381883918840188411884218843188441884518846188471884818849188501885118852188531885418855188561885718858188591886018861188621886318864188651886618867188681886918870188711887218873188741887518876188771887818879188801888118882188831888418885188861888718888188891889018891188921889318894188951889618897188981889918900189011890218903189041890518906189071890818909189101891118912189131891418915189161891718918189191892018921189221892318924189251892618927189281892918930189311893218933189341893518936189371893818939189401894118942189431894418945189461894718948189491895018951189521895318954189551895618957189581895918960189611896218963189641896518966189671896818969189701897118972189731897418975189761897718978189791898018981189821898318984189851898618987189881898918990189911899218993189941899518996189971899818999190001900119002190031900419005190061900719008190091901019011190121901319014190151901619017190181901919020190211902219023190241902519026190271902819029190301903119032190331903419035190361903719038190391904019041190421904319044190451904619047190481904919050190511905219053190541905519056190571905819059190601906119062190631906419065190661906719068190691907019071190721907319074190751907619077190781907919080190811908219083190841908519086190871908819089190901909119092190931909419095190961909719098190991910019101191021910319104191051910619107191081910919110191111911219113191141911519116191171911819119191201912119122191231912419125191261912719128191291913019131191321913319134191351913619137191381913919140191411914219143191441914519146191471914819149191501915119152191531915419155191561915719158191591916019161191621916319164191651916619167191681916919170191711917219173191741917519176191771917819179191801918119182191831918419185191861918719188191891919019191191921919319194191951919619197191981919919200192011920219203192041920519206192071920819209192101921119212192131921419215192161921719218192191922019221192221922319224192251922619227192281922919230192311923219233192341923519236192371923819239192401924119242192431924419245192461924719248192491925019251192521925319254192551925619257192581925919260192611926219263192641926519266192671926819269192701927119272192731927419275192761927719278192791928019281192821928319284192851928619287192881928919290192911929219293192941929519296192971929819299193001930119302193031930419305193061930719308193091931019311193121931319314193151931619317193181931919320193211932219323193241932519326193271932819329193301933119332193331933419335193361933719338193391934019341193421934319344193451934619347193481934919350193511935219353193541935519356193571935819359193601936119362193631936419365193661936719368193691937019371193721937319374193751937619377193781937919380193811938219383193841938519386193871938819389193901939119392193931939419395193961939719398193991940019401194021940319404194051940619407194081940919410194111941219413194141941519416194171941819419194201942119422194231942419425194261942719428194291943019431194321943319434194351943619437194381943919440194411944219443194441944519446194471944819449194501945119452194531945419455194561945719458194591946019461194621946319464194651946619467194681946919470194711947219473194741947519476194771947819479194801948119482194831948419485194861948719488194891949019491194921949319494194951949619497194981949919500195011950219503195041950519506195071950819509195101951119512195131951419515195161951719518195191952019521195221952319524195251952619527195281952919530195311953219533195341953519536195371953819539195401954119542195431954419545195461954719548195491955019551195521955319554
  1. /*
  2. * Universal Interface for Intel High Definition Audio Codec
  3. *
  4. * HD audio interface patch for ALC 260/880/882 codecs
  5. *
  6. * Copyright (c) 2004 Kailang Yang <kailang@realtek.com.tw>
  7. * PeiSen Hou <pshou@realtek.com.tw>
  8. * Takashi Iwai <tiwai@suse.de>
  9. * Jonathan Woithe <jwoithe@physics.adelaide.edu.au>
  10. *
  11. * This driver is free software; you can redistribute it and/or modify
  12. * it under the terms of the GNU General Public License as published by
  13. * the Free Software Foundation; either version 2 of the License, or
  14. * (at your option) any later version.
  15. *
  16. * This driver is distributed in the hope that it will be useful,
  17. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  18. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  19. * GNU General Public License for more details.
  20. *
  21. * You should have received a copy of the GNU General Public License
  22. * along with this program; if not, write to the Free Software
  23. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  24. */
  25. #include <linux/init.h>
  26. #include <linux/delay.h>
  27. #include <linux/slab.h>
  28. #include <linux/pci.h>
  29. #include <sound/core.h>
  30. #include "hda_codec.h"
  31. #include "hda_local.h"
  32. #include "hda_beep.h"
  33. #define ALC880_FRONT_EVENT 0x01
  34. #define ALC880_DCVOL_EVENT 0x02
  35. #define ALC880_HP_EVENT 0x04
  36. #define ALC880_MIC_EVENT 0x08
  37. /* ALC880 board config type */
  38. enum {
  39. ALC880_3ST,
  40. ALC880_3ST_DIG,
  41. ALC880_5ST,
  42. ALC880_5ST_DIG,
  43. ALC880_W810,
  44. ALC880_Z71V,
  45. ALC880_6ST,
  46. ALC880_6ST_DIG,
  47. ALC880_F1734,
  48. ALC880_ASUS,
  49. ALC880_ASUS_DIG,
  50. ALC880_ASUS_W1V,
  51. ALC880_ASUS_DIG2,
  52. ALC880_FUJITSU,
  53. ALC880_UNIWILL_DIG,
  54. ALC880_UNIWILL,
  55. ALC880_UNIWILL_P53,
  56. ALC880_CLEVO,
  57. ALC880_TCL_S700,
  58. ALC880_LG,
  59. ALC880_LG_LW,
  60. ALC880_MEDION_RIM,
  61. #ifdef CONFIG_SND_DEBUG
  62. ALC880_TEST,
  63. #endif
  64. ALC880_AUTO,
  65. ALC880_MODEL_LAST /* last tag */
  66. };
  67. /* ALC260 models */
  68. enum {
  69. ALC260_BASIC,
  70. ALC260_HP,
  71. ALC260_HP_DC7600,
  72. ALC260_HP_3013,
  73. ALC260_FUJITSU_S702X,
  74. ALC260_ACER,
  75. ALC260_WILL,
  76. ALC260_REPLACER_672V,
  77. ALC260_FAVORIT100,
  78. #ifdef CONFIG_SND_DEBUG
  79. ALC260_TEST,
  80. #endif
  81. ALC260_AUTO,
  82. ALC260_MODEL_LAST /* last tag */
  83. };
  84. /* ALC262 models */
  85. enum {
  86. ALC262_BASIC,
  87. ALC262_HIPPO,
  88. ALC262_HIPPO_1,
  89. ALC262_FUJITSU,
  90. ALC262_HP_BPC,
  91. ALC262_HP_BPC_D7000_WL,
  92. ALC262_HP_BPC_D7000_WF,
  93. ALC262_HP_TC_T5735,
  94. ALC262_HP_RP5700,
  95. ALC262_BENQ_ED8,
  96. ALC262_SONY_ASSAMD,
  97. ALC262_BENQ_T31,
  98. ALC262_ULTRA,
  99. ALC262_LENOVO_3000,
  100. ALC262_NEC,
  101. ALC262_TOSHIBA_S06,
  102. ALC262_TOSHIBA_RX1,
  103. ALC262_TYAN,
  104. ALC262_AUTO,
  105. ALC262_MODEL_LAST /* last tag */
  106. };
  107. /* ALC268 models */
  108. enum {
  109. ALC267_QUANTA_IL1,
  110. ALC268_3ST,
  111. ALC268_TOSHIBA,
  112. ALC268_ACER,
  113. ALC268_ACER_DMIC,
  114. ALC268_ACER_ASPIRE_ONE,
  115. ALC268_DELL,
  116. ALC268_ZEPTO,
  117. #ifdef CONFIG_SND_DEBUG
  118. ALC268_TEST,
  119. #endif
  120. ALC268_AUTO,
  121. ALC268_MODEL_LAST /* last tag */
  122. };
  123. /* ALC269 models */
  124. enum {
  125. ALC269_BASIC,
  126. ALC269_QUANTA_FL1,
  127. ALC269_AMIC,
  128. ALC269_DMIC,
  129. ALC269VB_AMIC,
  130. ALC269VB_DMIC,
  131. ALC269_FUJITSU,
  132. ALC269_LIFEBOOK,
  133. ALC271_ACER,
  134. ALC269_AUTO,
  135. ALC269_MODEL_LAST /* last tag */
  136. };
  137. /* ALC861 models */
  138. enum {
  139. ALC861_3ST,
  140. ALC660_3ST,
  141. ALC861_3ST_DIG,
  142. ALC861_6ST_DIG,
  143. ALC861_UNIWILL_M31,
  144. ALC861_TOSHIBA,
  145. ALC861_ASUS,
  146. ALC861_ASUS_LAPTOP,
  147. ALC861_AUTO,
  148. ALC861_MODEL_LAST,
  149. };
  150. /* ALC861-VD models */
  151. enum {
  152. ALC660VD_3ST,
  153. ALC660VD_3ST_DIG,
  154. ALC660VD_ASUS_V1S,
  155. ALC861VD_3ST,
  156. ALC861VD_3ST_DIG,
  157. ALC861VD_6ST_DIG,
  158. ALC861VD_LENOVO,
  159. ALC861VD_DALLAS,
  160. ALC861VD_HP,
  161. ALC861VD_AUTO,
  162. ALC861VD_MODEL_LAST,
  163. };
  164. /* ALC662 models */
  165. enum {
  166. ALC662_3ST_2ch_DIG,
  167. ALC662_3ST_6ch_DIG,
  168. ALC662_3ST_6ch,
  169. ALC662_5ST_DIG,
  170. ALC662_LENOVO_101E,
  171. ALC662_ASUS_EEEPC_P701,
  172. ALC662_ASUS_EEEPC_EP20,
  173. ALC663_ASUS_M51VA,
  174. ALC663_ASUS_G71V,
  175. ALC663_ASUS_H13,
  176. ALC663_ASUS_G50V,
  177. ALC662_ECS,
  178. ALC663_ASUS_MODE1,
  179. ALC662_ASUS_MODE2,
  180. ALC663_ASUS_MODE3,
  181. ALC663_ASUS_MODE4,
  182. ALC663_ASUS_MODE5,
  183. ALC663_ASUS_MODE6,
  184. ALC663_ASUS_MODE7,
  185. ALC663_ASUS_MODE8,
  186. ALC272_DELL,
  187. ALC272_DELL_ZM1,
  188. ALC272_SAMSUNG_NC10,
  189. ALC662_AUTO,
  190. ALC662_MODEL_LAST,
  191. };
  192. /* ALC882 models */
  193. enum {
  194. ALC882_3ST_DIG,
  195. ALC882_6ST_DIG,
  196. ALC882_ARIMA,
  197. ALC882_W2JC,
  198. ALC882_TARGA,
  199. ALC882_ASUS_A7J,
  200. ALC882_ASUS_A7M,
  201. ALC885_MACPRO,
  202. ALC885_MBA21,
  203. ALC885_MBP3,
  204. ALC885_MB5,
  205. ALC885_MACMINI3,
  206. ALC885_IMAC24,
  207. ALC885_IMAC91,
  208. ALC883_3ST_2ch_DIG,
  209. ALC883_3ST_6ch_DIG,
  210. ALC883_3ST_6ch,
  211. ALC883_6ST_DIG,
  212. ALC883_TARGA_DIG,
  213. ALC883_TARGA_2ch_DIG,
  214. ALC883_TARGA_8ch_DIG,
  215. ALC883_ACER,
  216. ALC883_ACER_ASPIRE,
  217. ALC888_ACER_ASPIRE_4930G,
  218. ALC888_ACER_ASPIRE_6530G,
  219. ALC888_ACER_ASPIRE_8930G,
  220. ALC888_ACER_ASPIRE_7730G,
  221. ALC883_MEDION,
  222. ALC883_MEDION_MD2,
  223. ALC883_MEDION_WIM2160,
  224. ALC883_LAPTOP_EAPD,
  225. ALC883_LENOVO_101E_2ch,
  226. ALC883_LENOVO_NB0763,
  227. ALC888_LENOVO_MS7195_DIG,
  228. ALC888_LENOVO_SKY,
  229. ALC883_HAIER_W66,
  230. ALC888_3ST_HP,
  231. ALC888_6ST_DELL,
  232. ALC883_MITAC,
  233. ALC883_CLEVO_M540R,
  234. ALC883_CLEVO_M720,
  235. ALC883_FUJITSU_PI2515,
  236. ALC888_FUJITSU_XA3530,
  237. ALC883_3ST_6ch_INTEL,
  238. ALC889A_INTEL,
  239. ALC889_INTEL,
  240. ALC888_ASUS_M90V,
  241. ALC888_ASUS_EEE1601,
  242. ALC889A_MB31,
  243. ALC1200_ASUS_P5Q,
  244. ALC883_SONY_VAIO_TT,
  245. ALC882_AUTO,
  246. ALC882_MODEL_LAST,
  247. };
  248. /* ALC680 models */
  249. enum {
  250. ALC680_BASE,
  251. ALC680_AUTO,
  252. ALC680_MODEL_LAST,
  253. };
  254. /* for GPIO Poll */
  255. #define GPIO_MASK 0x03
  256. /* extra amp-initialization sequence types */
  257. enum {
  258. ALC_INIT_NONE,
  259. ALC_INIT_DEFAULT,
  260. ALC_INIT_GPIO1,
  261. ALC_INIT_GPIO2,
  262. ALC_INIT_GPIO3,
  263. };
  264. struct alc_mic_route {
  265. hda_nid_t pin;
  266. unsigned char mux_idx;
  267. unsigned char amix_idx;
  268. };
  269. #define MUX_IDX_UNDEF ((unsigned char)-1)
  270. struct alc_customize_define {
  271. unsigned int sku_cfg;
  272. unsigned char port_connectivity;
  273. unsigned char check_sum;
  274. unsigned char customization;
  275. unsigned char external_amp;
  276. unsigned int enable_pcbeep:1;
  277. unsigned int platform_type:1;
  278. unsigned int swap:1;
  279. unsigned int override:1;
  280. };
  281. struct alc_spec {
  282. /* codec parameterization */
  283. struct snd_kcontrol_new *mixers[5]; /* mixer arrays */
  284. unsigned int num_mixers;
  285. struct snd_kcontrol_new *cap_mixer; /* capture mixer */
  286. unsigned int beep_amp; /* beep amp value, set via set_beep_amp() */
  287. const struct hda_verb *init_verbs[10]; /* initialization verbs
  288. * don't forget NULL
  289. * termination!
  290. */
  291. unsigned int num_init_verbs;
  292. char stream_name_analog[32]; /* analog PCM stream */
  293. struct hda_pcm_stream *stream_analog_playback;
  294. struct hda_pcm_stream *stream_analog_capture;
  295. struct hda_pcm_stream *stream_analog_alt_playback;
  296. struct hda_pcm_stream *stream_analog_alt_capture;
  297. char stream_name_digital[32]; /* digital PCM stream */
  298. struct hda_pcm_stream *stream_digital_playback;
  299. struct hda_pcm_stream *stream_digital_capture;
  300. /* playback */
  301. struct hda_multi_out multiout; /* playback set-up
  302. * max_channels, dacs must be set
  303. * dig_out_nid and hp_nid are optional
  304. */
  305. hda_nid_t alt_dac_nid;
  306. hda_nid_t slave_dig_outs[3]; /* optional - for auto-parsing */
  307. int dig_out_type;
  308. /* capture */
  309. unsigned int num_adc_nids;
  310. hda_nid_t *adc_nids;
  311. hda_nid_t *capsrc_nids;
  312. hda_nid_t dig_in_nid; /* digital-in NID; optional */
  313. /* capture setup for dynamic dual-adc switch */
  314. unsigned int cur_adc_idx;
  315. hda_nid_t cur_adc;
  316. unsigned int cur_adc_stream_tag;
  317. unsigned int cur_adc_format;
  318. /* capture source */
  319. unsigned int num_mux_defs;
  320. const struct hda_input_mux *input_mux;
  321. unsigned int cur_mux[3];
  322. struct alc_mic_route ext_mic;
  323. struct alc_mic_route int_mic;
  324. /* channel model */
  325. const struct hda_channel_mode *channel_mode;
  326. int num_channel_mode;
  327. int need_dac_fix;
  328. int const_channel_count;
  329. int ext_channel_count;
  330. /* PCM information */
  331. struct hda_pcm pcm_rec[3]; /* used in alc_build_pcms() */
  332. /* dynamic controls, init_verbs and input_mux */
  333. struct auto_pin_cfg autocfg;
  334. struct alc_customize_define cdefine;
  335. struct snd_array kctls;
  336. struct hda_input_mux private_imux[3];
  337. hda_nid_t private_dac_nids[AUTO_CFG_MAX_OUTS];
  338. hda_nid_t private_adc_nids[AUTO_CFG_MAX_OUTS];
  339. hda_nid_t private_capsrc_nids[AUTO_CFG_MAX_OUTS];
  340. /* hooks */
  341. void (*init_hook)(struct hda_codec *codec);
  342. void (*unsol_event)(struct hda_codec *codec, unsigned int res);
  343. #ifdef CONFIG_SND_HDA_POWER_SAVE
  344. void (*power_hook)(struct hda_codec *codec);
  345. #endif
  346. /* for pin sensing */
  347. unsigned int sense_updated: 1;
  348. unsigned int jack_present: 1;
  349. unsigned int master_sw: 1;
  350. unsigned int auto_mic:1;
  351. /* other flags */
  352. unsigned int no_analog :1; /* digital I/O only */
  353. unsigned int dual_adc_switch:1; /* switch ADCs (for ALC275) */
  354. int init_amp;
  355. /* for virtual master */
  356. hda_nid_t vmaster_nid;
  357. #ifdef CONFIG_SND_HDA_POWER_SAVE
  358. struct hda_loopback_check loopback;
  359. #endif
  360. /* for PLL fix */
  361. hda_nid_t pll_nid;
  362. unsigned int pll_coef_idx, pll_coef_bit;
  363. };
  364. /*
  365. * configuration template - to be copied to the spec instance
  366. */
  367. struct alc_config_preset {
  368. struct snd_kcontrol_new *mixers[5]; /* should be identical size
  369. * with spec
  370. */
  371. struct snd_kcontrol_new *cap_mixer; /* capture mixer */
  372. const struct hda_verb *init_verbs[5];
  373. unsigned int num_dacs;
  374. hda_nid_t *dac_nids;
  375. hda_nid_t dig_out_nid; /* optional */
  376. hda_nid_t hp_nid; /* optional */
  377. hda_nid_t *slave_dig_outs;
  378. unsigned int num_adc_nids;
  379. hda_nid_t *adc_nids;
  380. hda_nid_t *capsrc_nids;
  381. hda_nid_t dig_in_nid;
  382. unsigned int num_channel_mode;
  383. const struct hda_channel_mode *channel_mode;
  384. int need_dac_fix;
  385. int const_channel_count;
  386. unsigned int num_mux_defs;
  387. const struct hda_input_mux *input_mux;
  388. void (*unsol_event)(struct hda_codec *, unsigned int);
  389. void (*setup)(struct hda_codec *);
  390. void (*init_hook)(struct hda_codec *);
  391. #ifdef CONFIG_SND_HDA_POWER_SAVE
  392. struct hda_amp_list *loopbacks;
  393. void (*power_hook)(struct hda_codec *codec);
  394. #endif
  395. };
  396. /*
  397. * input MUX handling
  398. */
  399. static int alc_mux_enum_info(struct snd_kcontrol *kcontrol,
  400. struct snd_ctl_elem_info *uinfo)
  401. {
  402. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  403. struct alc_spec *spec = codec->spec;
  404. unsigned int mux_idx = snd_ctl_get_ioffidx(kcontrol, &uinfo->id);
  405. if (mux_idx >= spec->num_mux_defs)
  406. mux_idx = 0;
  407. if (!spec->input_mux[mux_idx].num_items && mux_idx > 0)
  408. mux_idx = 0;
  409. return snd_hda_input_mux_info(&spec->input_mux[mux_idx], uinfo);
  410. }
  411. static int alc_mux_enum_get(struct snd_kcontrol *kcontrol,
  412. struct snd_ctl_elem_value *ucontrol)
  413. {
  414. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  415. struct alc_spec *spec = codec->spec;
  416. unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
  417. ucontrol->value.enumerated.item[0] = spec->cur_mux[adc_idx];
  418. return 0;
  419. }
  420. static int alc_mux_enum_put(struct snd_kcontrol *kcontrol,
  421. struct snd_ctl_elem_value *ucontrol)
  422. {
  423. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  424. struct alc_spec *spec = codec->spec;
  425. const struct hda_input_mux *imux;
  426. unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
  427. unsigned int mux_idx;
  428. hda_nid_t nid = spec->capsrc_nids ?
  429. spec->capsrc_nids[adc_idx] : spec->adc_nids[adc_idx];
  430. unsigned int type;
  431. mux_idx = adc_idx >= spec->num_mux_defs ? 0 : adc_idx;
  432. imux = &spec->input_mux[mux_idx];
  433. if (!imux->num_items && mux_idx > 0)
  434. imux = &spec->input_mux[0];
  435. type = get_wcaps_type(get_wcaps(codec, nid));
  436. if (type == AC_WID_AUD_MIX) {
  437. /* Matrix-mixer style (e.g. ALC882) */
  438. unsigned int *cur_val = &spec->cur_mux[adc_idx];
  439. unsigned int i, idx;
  440. idx = ucontrol->value.enumerated.item[0];
  441. if (idx >= imux->num_items)
  442. idx = imux->num_items - 1;
  443. if (*cur_val == idx)
  444. return 0;
  445. for (i = 0; i < imux->num_items; i++) {
  446. unsigned int v = (i == idx) ? 0 : HDA_AMP_MUTE;
  447. snd_hda_codec_amp_stereo(codec, nid, HDA_INPUT,
  448. imux->items[i].index,
  449. HDA_AMP_MUTE, v);
  450. }
  451. *cur_val = idx;
  452. return 1;
  453. } else {
  454. /* MUX style (e.g. ALC880) */
  455. return snd_hda_input_mux_put(codec, imux, ucontrol, nid,
  456. &spec->cur_mux[adc_idx]);
  457. }
  458. }
  459. /*
  460. * channel mode setting
  461. */
  462. static int alc_ch_mode_info(struct snd_kcontrol *kcontrol,
  463. struct snd_ctl_elem_info *uinfo)
  464. {
  465. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  466. struct alc_spec *spec = codec->spec;
  467. return snd_hda_ch_mode_info(codec, uinfo, spec->channel_mode,
  468. spec->num_channel_mode);
  469. }
  470. static int alc_ch_mode_get(struct snd_kcontrol *kcontrol,
  471. struct snd_ctl_elem_value *ucontrol)
  472. {
  473. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  474. struct alc_spec *spec = codec->spec;
  475. return snd_hda_ch_mode_get(codec, ucontrol, spec->channel_mode,
  476. spec->num_channel_mode,
  477. spec->ext_channel_count);
  478. }
  479. static int alc_ch_mode_put(struct snd_kcontrol *kcontrol,
  480. struct snd_ctl_elem_value *ucontrol)
  481. {
  482. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  483. struct alc_spec *spec = codec->spec;
  484. int err = snd_hda_ch_mode_put(codec, ucontrol, spec->channel_mode,
  485. spec->num_channel_mode,
  486. &spec->ext_channel_count);
  487. if (err >= 0 && !spec->const_channel_count) {
  488. spec->multiout.max_channels = spec->ext_channel_count;
  489. if (spec->need_dac_fix)
  490. spec->multiout.num_dacs = spec->multiout.max_channels / 2;
  491. }
  492. return err;
  493. }
  494. /*
  495. * Control the mode of pin widget settings via the mixer. "pc" is used
  496. * instead of "%" to avoid consequences of accidently treating the % as
  497. * being part of a format specifier. Maximum allowed length of a value is
  498. * 63 characters plus NULL terminator.
  499. *
  500. * Note: some retasking pin complexes seem to ignore requests for input
  501. * states other than HiZ (eg: PIN_VREFxx) and revert to HiZ if any of these
  502. * are requested. Therefore order this list so that this behaviour will not
  503. * cause problems when mixer clients move through the enum sequentially.
  504. * NIDs 0x0f and 0x10 have been observed to have this behaviour as of
  505. * March 2006.
  506. */
  507. static char *alc_pin_mode_names[] = {
  508. "Mic 50pc bias", "Mic 80pc bias",
  509. "Line in", "Line out", "Headphone out",
  510. };
  511. static unsigned char alc_pin_mode_values[] = {
  512. PIN_VREF50, PIN_VREF80, PIN_IN, PIN_OUT, PIN_HP,
  513. };
  514. /* The control can present all 5 options, or it can limit the options based
  515. * in the pin being assumed to be exclusively an input or an output pin. In
  516. * addition, "input" pins may or may not process the mic bias option
  517. * depending on actual widget capability (NIDs 0x0f and 0x10 don't seem to
  518. * accept requests for bias as of chip versions up to March 2006) and/or
  519. * wiring in the computer.
  520. */
  521. #define ALC_PIN_DIR_IN 0x00
  522. #define ALC_PIN_DIR_OUT 0x01
  523. #define ALC_PIN_DIR_INOUT 0x02
  524. #define ALC_PIN_DIR_IN_NOMICBIAS 0x03
  525. #define ALC_PIN_DIR_INOUT_NOMICBIAS 0x04
  526. /* Info about the pin modes supported by the different pin direction modes.
  527. * For each direction the minimum and maximum values are given.
  528. */
  529. static signed char alc_pin_mode_dir_info[5][2] = {
  530. { 0, 2 }, /* ALC_PIN_DIR_IN */
  531. { 3, 4 }, /* ALC_PIN_DIR_OUT */
  532. { 0, 4 }, /* ALC_PIN_DIR_INOUT */
  533. { 2, 2 }, /* ALC_PIN_DIR_IN_NOMICBIAS */
  534. { 2, 4 }, /* ALC_PIN_DIR_INOUT_NOMICBIAS */
  535. };
  536. #define alc_pin_mode_min(_dir) (alc_pin_mode_dir_info[_dir][0])
  537. #define alc_pin_mode_max(_dir) (alc_pin_mode_dir_info[_dir][1])
  538. #define alc_pin_mode_n_items(_dir) \
  539. (alc_pin_mode_max(_dir)-alc_pin_mode_min(_dir)+1)
  540. static int alc_pin_mode_info(struct snd_kcontrol *kcontrol,
  541. struct snd_ctl_elem_info *uinfo)
  542. {
  543. unsigned int item_num = uinfo->value.enumerated.item;
  544. unsigned char dir = (kcontrol->private_value >> 16) & 0xff;
  545. uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
  546. uinfo->count = 1;
  547. uinfo->value.enumerated.items = alc_pin_mode_n_items(dir);
  548. if (item_num<alc_pin_mode_min(dir) || item_num>alc_pin_mode_max(dir))
  549. item_num = alc_pin_mode_min(dir);
  550. strcpy(uinfo->value.enumerated.name, alc_pin_mode_names[item_num]);
  551. return 0;
  552. }
  553. static int alc_pin_mode_get(struct snd_kcontrol *kcontrol,
  554. struct snd_ctl_elem_value *ucontrol)
  555. {
  556. unsigned int i;
  557. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  558. hda_nid_t nid = kcontrol->private_value & 0xffff;
  559. unsigned char dir = (kcontrol->private_value >> 16) & 0xff;
  560. long *valp = ucontrol->value.integer.value;
  561. unsigned int pinctl = snd_hda_codec_read(codec, nid, 0,
  562. AC_VERB_GET_PIN_WIDGET_CONTROL,
  563. 0x00);
  564. /* Find enumerated value for current pinctl setting */
  565. i = alc_pin_mode_min(dir);
  566. while (i <= alc_pin_mode_max(dir) && alc_pin_mode_values[i] != pinctl)
  567. i++;
  568. *valp = i <= alc_pin_mode_max(dir) ? i: alc_pin_mode_min(dir);
  569. return 0;
  570. }
  571. static int alc_pin_mode_put(struct snd_kcontrol *kcontrol,
  572. struct snd_ctl_elem_value *ucontrol)
  573. {
  574. signed int change;
  575. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  576. hda_nid_t nid = kcontrol->private_value & 0xffff;
  577. unsigned char dir = (kcontrol->private_value >> 16) & 0xff;
  578. long val = *ucontrol->value.integer.value;
  579. unsigned int pinctl = snd_hda_codec_read(codec, nid, 0,
  580. AC_VERB_GET_PIN_WIDGET_CONTROL,
  581. 0x00);
  582. if (val < alc_pin_mode_min(dir) || val > alc_pin_mode_max(dir))
  583. val = alc_pin_mode_min(dir);
  584. change = pinctl != alc_pin_mode_values[val];
  585. if (change) {
  586. /* Set pin mode to that requested */
  587. snd_hda_codec_write_cache(codec, nid, 0,
  588. AC_VERB_SET_PIN_WIDGET_CONTROL,
  589. alc_pin_mode_values[val]);
  590. /* Also enable the retasking pin's input/output as required
  591. * for the requested pin mode. Enum values of 2 or less are
  592. * input modes.
  593. *
  594. * Dynamically switching the input/output buffers probably
  595. * reduces noise slightly (particularly on input) so we'll
  596. * do it. However, having both input and output buffers
  597. * enabled simultaneously doesn't seem to be problematic if
  598. * this turns out to be necessary in the future.
  599. */
  600. if (val <= 2) {
  601. snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0,
  602. HDA_AMP_MUTE, HDA_AMP_MUTE);
  603. snd_hda_codec_amp_stereo(codec, nid, HDA_INPUT, 0,
  604. HDA_AMP_MUTE, 0);
  605. } else {
  606. snd_hda_codec_amp_stereo(codec, nid, HDA_INPUT, 0,
  607. HDA_AMP_MUTE, HDA_AMP_MUTE);
  608. snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0,
  609. HDA_AMP_MUTE, 0);
  610. }
  611. }
  612. return change;
  613. }
  614. #define ALC_PIN_MODE(xname, nid, dir) \
  615. { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = 0, \
  616. .subdevice = HDA_SUBDEV_NID_FLAG | nid, \
  617. .info = alc_pin_mode_info, \
  618. .get = alc_pin_mode_get, \
  619. .put = alc_pin_mode_put, \
  620. .private_value = nid | (dir<<16) }
  621. /* A switch control for ALC260 GPIO pins. Multiple GPIOs can be ganged
  622. * together using a mask with more than one bit set. This control is
  623. * currently used only by the ALC260 test model. At this stage they are not
  624. * needed for any "production" models.
  625. */
  626. #ifdef CONFIG_SND_DEBUG
  627. #define alc_gpio_data_info snd_ctl_boolean_mono_info
  628. static int alc_gpio_data_get(struct snd_kcontrol *kcontrol,
  629. struct snd_ctl_elem_value *ucontrol)
  630. {
  631. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  632. hda_nid_t nid = kcontrol->private_value & 0xffff;
  633. unsigned char mask = (kcontrol->private_value >> 16) & 0xff;
  634. long *valp = ucontrol->value.integer.value;
  635. unsigned int val = snd_hda_codec_read(codec, nid, 0,
  636. AC_VERB_GET_GPIO_DATA, 0x00);
  637. *valp = (val & mask) != 0;
  638. return 0;
  639. }
  640. static int alc_gpio_data_put(struct snd_kcontrol *kcontrol,
  641. struct snd_ctl_elem_value *ucontrol)
  642. {
  643. signed int change;
  644. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  645. hda_nid_t nid = kcontrol->private_value & 0xffff;
  646. unsigned char mask = (kcontrol->private_value >> 16) & 0xff;
  647. long val = *ucontrol->value.integer.value;
  648. unsigned int gpio_data = snd_hda_codec_read(codec, nid, 0,
  649. AC_VERB_GET_GPIO_DATA,
  650. 0x00);
  651. /* Set/unset the masked GPIO bit(s) as needed */
  652. change = (val == 0 ? 0 : mask) != (gpio_data & mask);
  653. if (val == 0)
  654. gpio_data &= ~mask;
  655. else
  656. gpio_data |= mask;
  657. snd_hda_codec_write_cache(codec, nid, 0,
  658. AC_VERB_SET_GPIO_DATA, gpio_data);
  659. return change;
  660. }
  661. #define ALC_GPIO_DATA_SWITCH(xname, nid, mask) \
  662. { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = 0, \
  663. .subdevice = HDA_SUBDEV_NID_FLAG | nid, \
  664. .info = alc_gpio_data_info, \
  665. .get = alc_gpio_data_get, \
  666. .put = alc_gpio_data_put, \
  667. .private_value = nid | (mask<<16) }
  668. #endif /* CONFIG_SND_DEBUG */
  669. /* A switch control to allow the enabling of the digital IO pins on the
  670. * ALC260. This is incredibly simplistic; the intention of this control is
  671. * to provide something in the test model allowing digital outputs to be
  672. * identified if present. If models are found which can utilise these
  673. * outputs a more complete mixer control can be devised for those models if
  674. * necessary.
  675. */
  676. #ifdef CONFIG_SND_DEBUG
  677. #define alc_spdif_ctrl_info snd_ctl_boolean_mono_info
  678. static int alc_spdif_ctrl_get(struct snd_kcontrol *kcontrol,
  679. struct snd_ctl_elem_value *ucontrol)
  680. {
  681. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  682. hda_nid_t nid = kcontrol->private_value & 0xffff;
  683. unsigned char mask = (kcontrol->private_value >> 16) & 0xff;
  684. long *valp = ucontrol->value.integer.value;
  685. unsigned int val = snd_hda_codec_read(codec, nid, 0,
  686. AC_VERB_GET_DIGI_CONVERT_1, 0x00);
  687. *valp = (val & mask) != 0;
  688. return 0;
  689. }
  690. static int alc_spdif_ctrl_put(struct snd_kcontrol *kcontrol,
  691. struct snd_ctl_elem_value *ucontrol)
  692. {
  693. signed int change;
  694. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  695. hda_nid_t nid = kcontrol->private_value & 0xffff;
  696. unsigned char mask = (kcontrol->private_value >> 16) & 0xff;
  697. long val = *ucontrol->value.integer.value;
  698. unsigned int ctrl_data = snd_hda_codec_read(codec, nid, 0,
  699. AC_VERB_GET_DIGI_CONVERT_1,
  700. 0x00);
  701. /* Set/unset the masked control bit(s) as needed */
  702. change = (val == 0 ? 0 : mask) != (ctrl_data & mask);
  703. if (val==0)
  704. ctrl_data &= ~mask;
  705. else
  706. ctrl_data |= mask;
  707. snd_hda_codec_write_cache(codec, nid, 0, AC_VERB_SET_DIGI_CONVERT_1,
  708. ctrl_data);
  709. return change;
  710. }
  711. #define ALC_SPDIF_CTRL_SWITCH(xname, nid, mask) \
  712. { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = 0, \
  713. .subdevice = HDA_SUBDEV_NID_FLAG | nid, \
  714. .info = alc_spdif_ctrl_info, \
  715. .get = alc_spdif_ctrl_get, \
  716. .put = alc_spdif_ctrl_put, \
  717. .private_value = nid | (mask<<16) }
  718. #endif /* CONFIG_SND_DEBUG */
  719. /* A switch control to allow the enabling EAPD digital outputs on the ALC26x.
  720. * Again, this is only used in the ALC26x test models to help identify when
  721. * the EAPD line must be asserted for features to work.
  722. */
  723. #ifdef CONFIG_SND_DEBUG
  724. #define alc_eapd_ctrl_info snd_ctl_boolean_mono_info
  725. static int alc_eapd_ctrl_get(struct snd_kcontrol *kcontrol,
  726. struct snd_ctl_elem_value *ucontrol)
  727. {
  728. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  729. hda_nid_t nid = kcontrol->private_value & 0xffff;
  730. unsigned char mask = (kcontrol->private_value >> 16) & 0xff;
  731. long *valp = ucontrol->value.integer.value;
  732. unsigned int val = snd_hda_codec_read(codec, nid, 0,
  733. AC_VERB_GET_EAPD_BTLENABLE, 0x00);
  734. *valp = (val & mask) != 0;
  735. return 0;
  736. }
  737. static int alc_eapd_ctrl_put(struct snd_kcontrol *kcontrol,
  738. struct snd_ctl_elem_value *ucontrol)
  739. {
  740. int change;
  741. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  742. hda_nid_t nid = kcontrol->private_value & 0xffff;
  743. unsigned char mask = (kcontrol->private_value >> 16) & 0xff;
  744. long val = *ucontrol->value.integer.value;
  745. unsigned int ctrl_data = snd_hda_codec_read(codec, nid, 0,
  746. AC_VERB_GET_EAPD_BTLENABLE,
  747. 0x00);
  748. /* Set/unset the masked control bit(s) as needed */
  749. change = (!val ? 0 : mask) != (ctrl_data & mask);
  750. if (!val)
  751. ctrl_data &= ~mask;
  752. else
  753. ctrl_data |= mask;
  754. snd_hda_codec_write_cache(codec, nid, 0, AC_VERB_SET_EAPD_BTLENABLE,
  755. ctrl_data);
  756. return change;
  757. }
  758. #define ALC_EAPD_CTRL_SWITCH(xname, nid, mask) \
  759. { .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = 0, \
  760. .subdevice = HDA_SUBDEV_NID_FLAG | nid, \
  761. .info = alc_eapd_ctrl_info, \
  762. .get = alc_eapd_ctrl_get, \
  763. .put = alc_eapd_ctrl_put, \
  764. .private_value = nid | (mask<<16) }
  765. #endif /* CONFIG_SND_DEBUG */
  766. /*
  767. * set up the input pin config (depending on the given auto-pin type)
  768. */
  769. static void alc_set_input_pin(struct hda_codec *codec, hda_nid_t nid,
  770. int auto_pin_type)
  771. {
  772. unsigned int val = PIN_IN;
  773. if (auto_pin_type <= AUTO_PIN_FRONT_MIC) {
  774. unsigned int pincap;
  775. unsigned int oldval;
  776. oldval = snd_hda_codec_read(codec, nid, 0,
  777. AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
  778. pincap = snd_hda_query_pin_caps(codec, nid);
  779. pincap = (pincap & AC_PINCAP_VREF) >> AC_PINCAP_VREF_SHIFT;
  780. /* if the default pin setup is vref50, we give it priority */
  781. if ((pincap & AC_PINCAP_VREF_80) && oldval != PIN_VREF50)
  782. val = PIN_VREF80;
  783. else if (pincap & AC_PINCAP_VREF_50)
  784. val = PIN_VREF50;
  785. else if (pincap & AC_PINCAP_VREF_100)
  786. val = PIN_VREF100;
  787. else if (pincap & AC_PINCAP_VREF_GRD)
  788. val = PIN_VREFGRD;
  789. }
  790. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL, val);
  791. }
  792. /*
  793. */
  794. static void add_mixer(struct alc_spec *spec, struct snd_kcontrol_new *mix)
  795. {
  796. if (snd_BUG_ON(spec->num_mixers >= ARRAY_SIZE(spec->mixers)))
  797. return;
  798. spec->mixers[spec->num_mixers++] = mix;
  799. }
  800. static void add_verb(struct alc_spec *spec, const struct hda_verb *verb)
  801. {
  802. if (snd_BUG_ON(spec->num_init_verbs >= ARRAY_SIZE(spec->init_verbs)))
  803. return;
  804. spec->init_verbs[spec->num_init_verbs++] = verb;
  805. }
  806. /*
  807. * set up from the preset table
  808. */
  809. static void setup_preset(struct hda_codec *codec,
  810. const struct alc_config_preset *preset)
  811. {
  812. struct alc_spec *spec = codec->spec;
  813. int i;
  814. for (i = 0; i < ARRAY_SIZE(preset->mixers) && preset->mixers[i]; i++)
  815. add_mixer(spec, preset->mixers[i]);
  816. spec->cap_mixer = preset->cap_mixer;
  817. for (i = 0; i < ARRAY_SIZE(preset->init_verbs) && preset->init_verbs[i];
  818. i++)
  819. add_verb(spec, preset->init_verbs[i]);
  820. spec->channel_mode = preset->channel_mode;
  821. spec->num_channel_mode = preset->num_channel_mode;
  822. spec->need_dac_fix = preset->need_dac_fix;
  823. spec->const_channel_count = preset->const_channel_count;
  824. if (preset->const_channel_count)
  825. spec->multiout.max_channels = preset->const_channel_count;
  826. else
  827. spec->multiout.max_channels = spec->channel_mode[0].channels;
  828. spec->ext_channel_count = spec->channel_mode[0].channels;
  829. spec->multiout.num_dacs = preset->num_dacs;
  830. spec->multiout.dac_nids = preset->dac_nids;
  831. spec->multiout.dig_out_nid = preset->dig_out_nid;
  832. spec->multiout.slave_dig_outs = preset->slave_dig_outs;
  833. spec->multiout.hp_nid = preset->hp_nid;
  834. spec->num_mux_defs = preset->num_mux_defs;
  835. if (!spec->num_mux_defs)
  836. spec->num_mux_defs = 1;
  837. spec->input_mux = preset->input_mux;
  838. spec->num_adc_nids = preset->num_adc_nids;
  839. spec->adc_nids = preset->adc_nids;
  840. spec->capsrc_nids = preset->capsrc_nids;
  841. spec->dig_in_nid = preset->dig_in_nid;
  842. spec->unsol_event = preset->unsol_event;
  843. spec->init_hook = preset->init_hook;
  844. #ifdef CONFIG_SND_HDA_POWER_SAVE
  845. spec->power_hook = preset->power_hook;
  846. spec->loopback.amplist = preset->loopbacks;
  847. #endif
  848. if (preset->setup)
  849. preset->setup(codec);
  850. }
  851. /* Enable GPIO mask and set output */
  852. static struct hda_verb alc_gpio1_init_verbs[] = {
  853. {0x01, AC_VERB_SET_GPIO_MASK, 0x01},
  854. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x01},
  855. {0x01, AC_VERB_SET_GPIO_DATA, 0x01},
  856. { }
  857. };
  858. static struct hda_verb alc_gpio2_init_verbs[] = {
  859. {0x01, AC_VERB_SET_GPIO_MASK, 0x02},
  860. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x02},
  861. {0x01, AC_VERB_SET_GPIO_DATA, 0x02},
  862. { }
  863. };
  864. static struct hda_verb alc_gpio3_init_verbs[] = {
  865. {0x01, AC_VERB_SET_GPIO_MASK, 0x03},
  866. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x03},
  867. {0x01, AC_VERB_SET_GPIO_DATA, 0x03},
  868. { }
  869. };
  870. /*
  871. * Fix hardware PLL issue
  872. * On some codecs, the analog PLL gating control must be off while
  873. * the default value is 1.
  874. */
  875. static void alc_fix_pll(struct hda_codec *codec)
  876. {
  877. struct alc_spec *spec = codec->spec;
  878. unsigned int val;
  879. if (!spec->pll_nid)
  880. return;
  881. snd_hda_codec_write(codec, spec->pll_nid, 0, AC_VERB_SET_COEF_INDEX,
  882. spec->pll_coef_idx);
  883. val = snd_hda_codec_read(codec, spec->pll_nid, 0,
  884. AC_VERB_GET_PROC_COEF, 0);
  885. snd_hda_codec_write(codec, spec->pll_nid, 0, AC_VERB_SET_COEF_INDEX,
  886. spec->pll_coef_idx);
  887. snd_hda_codec_write(codec, spec->pll_nid, 0, AC_VERB_SET_PROC_COEF,
  888. val & ~(1 << spec->pll_coef_bit));
  889. }
  890. static void alc_fix_pll_init(struct hda_codec *codec, hda_nid_t nid,
  891. unsigned int coef_idx, unsigned int coef_bit)
  892. {
  893. struct alc_spec *spec = codec->spec;
  894. spec->pll_nid = nid;
  895. spec->pll_coef_idx = coef_idx;
  896. spec->pll_coef_bit = coef_bit;
  897. alc_fix_pll(codec);
  898. }
  899. static void alc_automute_pin(struct hda_codec *codec)
  900. {
  901. struct alc_spec *spec = codec->spec;
  902. unsigned int nid = spec->autocfg.hp_pins[0];
  903. int i;
  904. if (!nid)
  905. return;
  906. spec->jack_present = snd_hda_jack_detect(codec, nid);
  907. for (i = 0; i < ARRAY_SIZE(spec->autocfg.speaker_pins); i++) {
  908. nid = spec->autocfg.speaker_pins[i];
  909. if (!nid)
  910. break;
  911. snd_hda_codec_write(codec, nid, 0,
  912. AC_VERB_SET_PIN_WIDGET_CONTROL,
  913. spec->jack_present ? 0 : PIN_OUT);
  914. }
  915. }
  916. static int get_connection_index(struct hda_codec *codec, hda_nid_t mux,
  917. hda_nid_t nid)
  918. {
  919. hda_nid_t conn[HDA_MAX_NUM_INPUTS];
  920. int i, nums;
  921. nums = snd_hda_get_connections(codec, mux, conn, ARRAY_SIZE(conn));
  922. for (i = 0; i < nums; i++)
  923. if (conn[i] == nid)
  924. return i;
  925. return -1;
  926. }
  927. /* switch the current ADC according to the jack state */
  928. static void alc_dual_mic_adc_auto_switch(struct hda_codec *codec)
  929. {
  930. struct alc_spec *spec = codec->spec;
  931. unsigned int present;
  932. hda_nid_t new_adc;
  933. present = snd_hda_jack_detect(codec, spec->ext_mic.pin);
  934. if (present)
  935. spec->cur_adc_idx = 1;
  936. else
  937. spec->cur_adc_idx = 0;
  938. new_adc = spec->adc_nids[spec->cur_adc_idx];
  939. if (spec->cur_adc && spec->cur_adc != new_adc) {
  940. /* stream is running, let's swap the current ADC */
  941. __snd_hda_codec_cleanup_stream(codec, spec->cur_adc, 1);
  942. spec->cur_adc = new_adc;
  943. snd_hda_codec_setup_stream(codec, new_adc,
  944. spec->cur_adc_stream_tag, 0,
  945. spec->cur_adc_format);
  946. }
  947. }
  948. static void alc_mic_automute(struct hda_codec *codec)
  949. {
  950. struct alc_spec *spec = codec->spec;
  951. struct alc_mic_route *dead, *alive;
  952. unsigned int present, type;
  953. hda_nid_t cap_nid;
  954. if (!spec->auto_mic)
  955. return;
  956. if (!spec->int_mic.pin || !spec->ext_mic.pin)
  957. return;
  958. if (snd_BUG_ON(!spec->adc_nids))
  959. return;
  960. if (spec->dual_adc_switch) {
  961. alc_dual_mic_adc_auto_switch(codec);
  962. return;
  963. }
  964. cap_nid = spec->capsrc_nids ? spec->capsrc_nids[0] : spec->adc_nids[0];
  965. present = snd_hda_jack_detect(codec, spec->ext_mic.pin);
  966. if (present) {
  967. alive = &spec->ext_mic;
  968. dead = &spec->int_mic;
  969. } else {
  970. alive = &spec->int_mic;
  971. dead = &spec->ext_mic;
  972. }
  973. type = get_wcaps_type(get_wcaps(codec, cap_nid));
  974. if (type == AC_WID_AUD_MIX) {
  975. /* Matrix-mixer style (e.g. ALC882) */
  976. snd_hda_codec_amp_stereo(codec, cap_nid, HDA_INPUT,
  977. alive->mux_idx,
  978. HDA_AMP_MUTE, 0);
  979. snd_hda_codec_amp_stereo(codec, cap_nid, HDA_INPUT,
  980. dead->mux_idx,
  981. HDA_AMP_MUTE, HDA_AMP_MUTE);
  982. } else {
  983. /* MUX style (e.g. ALC880) */
  984. snd_hda_codec_write_cache(codec, cap_nid, 0,
  985. AC_VERB_SET_CONNECT_SEL,
  986. alive->mux_idx);
  987. }
  988. /* FIXME: analog mixer */
  989. }
  990. /* unsolicited event for HP jack sensing */
  991. static void alc_sku_unsol_event(struct hda_codec *codec, unsigned int res)
  992. {
  993. if (codec->vendor_id == 0x10ec0880)
  994. res >>= 28;
  995. else
  996. res >>= 26;
  997. switch (res) {
  998. case ALC880_HP_EVENT:
  999. alc_automute_pin(codec);
  1000. break;
  1001. case ALC880_MIC_EVENT:
  1002. alc_mic_automute(codec);
  1003. break;
  1004. }
  1005. }
  1006. static void alc_inithook(struct hda_codec *codec)
  1007. {
  1008. alc_automute_pin(codec);
  1009. alc_mic_automute(codec);
  1010. }
  1011. /* additional initialization for ALC888 variants */
  1012. static void alc888_coef_init(struct hda_codec *codec)
  1013. {
  1014. unsigned int tmp;
  1015. snd_hda_codec_write(codec, 0x20, 0, AC_VERB_SET_COEF_INDEX, 0);
  1016. tmp = snd_hda_codec_read(codec, 0x20, 0, AC_VERB_GET_PROC_COEF, 0);
  1017. snd_hda_codec_write(codec, 0x20, 0, AC_VERB_SET_COEF_INDEX, 7);
  1018. if ((tmp & 0xf0) == 0x20)
  1019. /* alc888S-VC */
  1020. snd_hda_codec_read(codec, 0x20, 0,
  1021. AC_VERB_SET_PROC_COEF, 0x830);
  1022. else
  1023. /* alc888-VB */
  1024. snd_hda_codec_read(codec, 0x20, 0,
  1025. AC_VERB_SET_PROC_COEF, 0x3030);
  1026. }
  1027. static void alc889_coef_init(struct hda_codec *codec)
  1028. {
  1029. unsigned int tmp;
  1030. snd_hda_codec_write(codec, 0x20, 0, AC_VERB_SET_COEF_INDEX, 7);
  1031. tmp = snd_hda_codec_read(codec, 0x20, 0, AC_VERB_GET_PROC_COEF, 0);
  1032. snd_hda_codec_write(codec, 0x20, 0, AC_VERB_SET_COEF_INDEX, 7);
  1033. snd_hda_codec_write(codec, 0x20, 0, AC_VERB_SET_PROC_COEF, tmp|0x2010);
  1034. }
  1035. /* turn on/off EAPD control (only if available) */
  1036. static void set_eapd(struct hda_codec *codec, hda_nid_t nid, int on)
  1037. {
  1038. if (get_wcaps_type(get_wcaps(codec, nid)) != AC_WID_PIN)
  1039. return;
  1040. if (snd_hda_query_pin_caps(codec, nid) & AC_PINCAP_EAPD)
  1041. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_EAPD_BTLENABLE,
  1042. on ? 2 : 0);
  1043. }
  1044. static void alc_auto_init_amp(struct hda_codec *codec, int type)
  1045. {
  1046. unsigned int tmp;
  1047. switch (type) {
  1048. case ALC_INIT_GPIO1:
  1049. snd_hda_sequence_write(codec, alc_gpio1_init_verbs);
  1050. break;
  1051. case ALC_INIT_GPIO2:
  1052. snd_hda_sequence_write(codec, alc_gpio2_init_verbs);
  1053. break;
  1054. case ALC_INIT_GPIO3:
  1055. snd_hda_sequence_write(codec, alc_gpio3_init_verbs);
  1056. break;
  1057. case ALC_INIT_DEFAULT:
  1058. switch (codec->vendor_id) {
  1059. case 0x10ec0260:
  1060. set_eapd(codec, 0x0f, 1);
  1061. set_eapd(codec, 0x10, 1);
  1062. break;
  1063. case 0x10ec0262:
  1064. case 0x10ec0267:
  1065. case 0x10ec0268:
  1066. case 0x10ec0269:
  1067. case 0x10ec0270:
  1068. case 0x10ec0272:
  1069. case 0x10ec0660:
  1070. case 0x10ec0662:
  1071. case 0x10ec0663:
  1072. case 0x10ec0862:
  1073. case 0x10ec0889:
  1074. set_eapd(codec, 0x14, 1);
  1075. set_eapd(codec, 0x15, 1);
  1076. break;
  1077. }
  1078. switch (codec->vendor_id) {
  1079. case 0x10ec0260:
  1080. snd_hda_codec_write(codec, 0x1a, 0,
  1081. AC_VERB_SET_COEF_INDEX, 7);
  1082. tmp = snd_hda_codec_read(codec, 0x1a, 0,
  1083. AC_VERB_GET_PROC_COEF, 0);
  1084. snd_hda_codec_write(codec, 0x1a, 0,
  1085. AC_VERB_SET_COEF_INDEX, 7);
  1086. snd_hda_codec_write(codec, 0x1a, 0,
  1087. AC_VERB_SET_PROC_COEF,
  1088. tmp | 0x2010);
  1089. break;
  1090. case 0x10ec0262:
  1091. case 0x10ec0880:
  1092. case 0x10ec0882:
  1093. case 0x10ec0883:
  1094. case 0x10ec0885:
  1095. case 0x10ec0887:
  1096. case 0x10ec0889:
  1097. alc889_coef_init(codec);
  1098. break;
  1099. case 0x10ec0888:
  1100. alc888_coef_init(codec);
  1101. break;
  1102. #if 0 /* XXX: This may cause the silent output on speaker on some machines */
  1103. case 0x10ec0267:
  1104. case 0x10ec0268:
  1105. snd_hda_codec_write(codec, 0x20, 0,
  1106. AC_VERB_SET_COEF_INDEX, 7);
  1107. tmp = snd_hda_codec_read(codec, 0x20, 0,
  1108. AC_VERB_GET_PROC_COEF, 0);
  1109. snd_hda_codec_write(codec, 0x20, 0,
  1110. AC_VERB_SET_COEF_INDEX, 7);
  1111. snd_hda_codec_write(codec, 0x20, 0,
  1112. AC_VERB_SET_PROC_COEF,
  1113. tmp | 0x3000);
  1114. break;
  1115. #endif /* XXX */
  1116. }
  1117. break;
  1118. }
  1119. }
  1120. static void alc_init_auto_hp(struct hda_codec *codec)
  1121. {
  1122. struct alc_spec *spec = codec->spec;
  1123. if (!spec->autocfg.hp_pins[0])
  1124. return;
  1125. if (!spec->autocfg.speaker_pins[0]) {
  1126. if (spec->autocfg.line_out_pins[0] &&
  1127. spec->autocfg.line_out_type == AUTO_PIN_SPEAKER_OUT)
  1128. spec->autocfg.speaker_pins[0] =
  1129. spec->autocfg.line_out_pins[0];
  1130. else
  1131. return;
  1132. }
  1133. snd_printdd("realtek: Enable HP auto-muting on NID 0x%x\n",
  1134. spec->autocfg.hp_pins[0]);
  1135. snd_hda_codec_write_cache(codec, spec->autocfg.hp_pins[0], 0,
  1136. AC_VERB_SET_UNSOLICITED_ENABLE,
  1137. AC_USRSP_EN | ALC880_HP_EVENT);
  1138. spec->unsol_event = alc_sku_unsol_event;
  1139. }
  1140. static void alc_init_auto_mic(struct hda_codec *codec)
  1141. {
  1142. struct alc_spec *spec = codec->spec;
  1143. struct auto_pin_cfg *cfg = &spec->autocfg;
  1144. hda_nid_t fixed, ext;
  1145. int i;
  1146. /* there must be only two mic inputs exclusively */
  1147. for (i = AUTO_PIN_LINE; i < AUTO_PIN_LAST; i++)
  1148. if (cfg->input_pins[i])
  1149. return;
  1150. fixed = ext = 0;
  1151. for (i = AUTO_PIN_MIC; i <= AUTO_PIN_FRONT_MIC; i++) {
  1152. hda_nid_t nid = cfg->input_pins[i];
  1153. unsigned int defcfg;
  1154. if (!nid)
  1155. return;
  1156. defcfg = snd_hda_codec_get_pincfg(codec, nid);
  1157. switch (get_defcfg_connect(defcfg)) {
  1158. case AC_JACK_PORT_FIXED:
  1159. if (fixed)
  1160. return; /* already occupied */
  1161. fixed = nid;
  1162. break;
  1163. case AC_JACK_PORT_COMPLEX:
  1164. if (ext)
  1165. return; /* already occupied */
  1166. ext = nid;
  1167. break;
  1168. default:
  1169. return; /* invalid entry */
  1170. }
  1171. }
  1172. if (!ext || !fixed)
  1173. return;
  1174. if (!(get_wcaps(codec, ext) & AC_WCAP_UNSOL_CAP))
  1175. return; /* no unsol support */
  1176. snd_printdd("realtek: Enable auto-mic switch on NID 0x%x/0x%x\n",
  1177. ext, fixed);
  1178. spec->ext_mic.pin = ext;
  1179. spec->int_mic.pin = fixed;
  1180. spec->ext_mic.mux_idx = MUX_IDX_UNDEF; /* set later */
  1181. spec->int_mic.mux_idx = MUX_IDX_UNDEF; /* set later */
  1182. spec->auto_mic = 1;
  1183. snd_hda_codec_write_cache(codec, spec->ext_mic.pin, 0,
  1184. AC_VERB_SET_UNSOLICITED_ENABLE,
  1185. AC_USRSP_EN | ALC880_MIC_EVENT);
  1186. spec->unsol_event = alc_sku_unsol_event;
  1187. }
  1188. static int alc_auto_parse_customize_define(struct hda_codec *codec)
  1189. {
  1190. unsigned int ass, tmp, i;
  1191. unsigned nid = 0;
  1192. struct alc_spec *spec = codec->spec;
  1193. spec->cdefine.enable_pcbeep = 1; /* assume always enabled */
  1194. ass = codec->subsystem_id & 0xffff;
  1195. if (ass != codec->bus->pci->subsystem_device && (ass & 1))
  1196. goto do_sku;
  1197. nid = 0x1d;
  1198. if (codec->vendor_id == 0x10ec0260)
  1199. nid = 0x17;
  1200. ass = snd_hda_codec_get_pincfg(codec, nid);
  1201. if (!(ass & 1)) {
  1202. printk(KERN_INFO "hda_codec: %s: SKU not ready 0x%08x\n",
  1203. codec->chip_name, ass);
  1204. return -1;
  1205. }
  1206. /* check sum */
  1207. tmp = 0;
  1208. for (i = 1; i < 16; i++) {
  1209. if ((ass >> i) & 1)
  1210. tmp++;
  1211. }
  1212. if (((ass >> 16) & 0xf) != tmp)
  1213. return -1;
  1214. spec->cdefine.port_connectivity = ass >> 30;
  1215. spec->cdefine.enable_pcbeep = (ass & 0x100000) >> 20;
  1216. spec->cdefine.check_sum = (ass >> 16) & 0xf;
  1217. spec->cdefine.customization = ass >> 8;
  1218. do_sku:
  1219. spec->cdefine.sku_cfg = ass;
  1220. spec->cdefine.external_amp = (ass & 0x38) >> 3;
  1221. spec->cdefine.platform_type = (ass & 0x4) >> 2;
  1222. spec->cdefine.swap = (ass & 0x2) >> 1;
  1223. spec->cdefine.override = ass & 0x1;
  1224. snd_printd("SKU: Nid=0x%x sku_cfg=0x%08x\n",
  1225. nid, spec->cdefine.sku_cfg);
  1226. snd_printd("SKU: port_connectivity=0x%x\n",
  1227. spec->cdefine.port_connectivity);
  1228. snd_printd("SKU: enable_pcbeep=0x%x\n", spec->cdefine.enable_pcbeep);
  1229. snd_printd("SKU: check_sum=0x%08x\n", spec->cdefine.check_sum);
  1230. snd_printd("SKU: customization=0x%08x\n", spec->cdefine.customization);
  1231. snd_printd("SKU: external_amp=0x%x\n", spec->cdefine.external_amp);
  1232. snd_printd("SKU: platform_type=0x%x\n", spec->cdefine.platform_type);
  1233. snd_printd("SKU: swap=0x%x\n", spec->cdefine.swap);
  1234. snd_printd("SKU: override=0x%x\n", spec->cdefine.override);
  1235. return 0;
  1236. }
  1237. /* check subsystem ID and set up device-specific initialization;
  1238. * return 1 if initialized, 0 if invalid SSID
  1239. */
  1240. /* 32-bit subsystem ID for BIOS loading in HD Audio codec.
  1241. * 31 ~ 16 : Manufacture ID
  1242. * 15 ~ 8 : SKU ID
  1243. * 7 ~ 0 : Assembly ID
  1244. * port-A --> pin 39/41, port-E --> pin 14/15, port-D --> pin 35/36
  1245. */
  1246. static int alc_subsystem_id(struct hda_codec *codec,
  1247. hda_nid_t porta, hda_nid_t porte,
  1248. hda_nid_t portd, hda_nid_t porti)
  1249. {
  1250. unsigned int ass, tmp, i;
  1251. unsigned nid;
  1252. struct alc_spec *spec = codec->spec;
  1253. ass = codec->subsystem_id & 0xffff;
  1254. if ((ass != codec->bus->pci->subsystem_device) && (ass & 1))
  1255. goto do_sku;
  1256. /* invalid SSID, check the special NID pin defcfg instead */
  1257. /*
  1258. * 31~30 : port connectivity
  1259. * 29~21 : reserve
  1260. * 20 : PCBEEP input
  1261. * 19~16 : Check sum (15:1)
  1262. * 15~1 : Custom
  1263. * 0 : override
  1264. */
  1265. nid = 0x1d;
  1266. if (codec->vendor_id == 0x10ec0260)
  1267. nid = 0x17;
  1268. ass = snd_hda_codec_get_pincfg(codec, nid);
  1269. snd_printd("realtek: No valid SSID, "
  1270. "checking pincfg 0x%08x for NID 0x%x\n",
  1271. ass, nid);
  1272. if (!(ass & 1))
  1273. return 0;
  1274. if ((ass >> 30) != 1) /* no physical connection */
  1275. return 0;
  1276. /* check sum */
  1277. tmp = 0;
  1278. for (i = 1; i < 16; i++) {
  1279. if ((ass >> i) & 1)
  1280. tmp++;
  1281. }
  1282. if (((ass >> 16) & 0xf) != tmp)
  1283. return 0;
  1284. do_sku:
  1285. snd_printd("realtek: Enabling init ASM_ID=0x%04x CODEC_ID=%08x\n",
  1286. ass & 0xffff, codec->vendor_id);
  1287. /*
  1288. * 0 : override
  1289. * 1 : Swap Jack
  1290. * 2 : 0 --> Desktop, 1 --> Laptop
  1291. * 3~5 : External Amplifier control
  1292. * 7~6 : Reserved
  1293. */
  1294. tmp = (ass & 0x38) >> 3; /* external Amp control */
  1295. switch (tmp) {
  1296. case 1:
  1297. spec->init_amp = ALC_INIT_GPIO1;
  1298. break;
  1299. case 3:
  1300. spec->init_amp = ALC_INIT_GPIO2;
  1301. break;
  1302. case 7:
  1303. spec->init_amp = ALC_INIT_GPIO3;
  1304. break;
  1305. case 5:
  1306. spec->init_amp = ALC_INIT_DEFAULT;
  1307. break;
  1308. }
  1309. /* is laptop or Desktop and enable the function "Mute internal speaker
  1310. * when the external headphone out jack is plugged"
  1311. */
  1312. if (!(ass & 0x8000))
  1313. return 1;
  1314. /*
  1315. * 10~8 : Jack location
  1316. * 12~11: Headphone out -> 00: PortA, 01: PortE, 02: PortD, 03: Resvered
  1317. * 14~13: Resvered
  1318. * 15 : 1 --> enable the function "Mute internal speaker
  1319. * when the external headphone out jack is plugged"
  1320. */
  1321. if (!spec->autocfg.hp_pins[0]) {
  1322. hda_nid_t nid;
  1323. tmp = (ass >> 11) & 0x3; /* HP to chassis */
  1324. if (tmp == 0)
  1325. nid = porta;
  1326. else if (tmp == 1)
  1327. nid = porte;
  1328. else if (tmp == 2)
  1329. nid = portd;
  1330. else if (tmp == 3)
  1331. nid = porti;
  1332. else
  1333. return 1;
  1334. for (i = 0; i < spec->autocfg.line_outs; i++)
  1335. if (spec->autocfg.line_out_pins[i] == nid)
  1336. return 1;
  1337. spec->autocfg.hp_pins[0] = nid;
  1338. }
  1339. alc_init_auto_hp(codec);
  1340. alc_init_auto_mic(codec);
  1341. return 1;
  1342. }
  1343. static void alc_ssid_check(struct hda_codec *codec,
  1344. hda_nid_t porta, hda_nid_t porte,
  1345. hda_nid_t portd, hda_nid_t porti)
  1346. {
  1347. if (!alc_subsystem_id(codec, porta, porte, portd, porti)) {
  1348. struct alc_spec *spec = codec->spec;
  1349. snd_printd("realtek: "
  1350. "Enable default setup for auto mode as fallback\n");
  1351. spec->init_amp = ALC_INIT_DEFAULT;
  1352. alc_init_auto_hp(codec);
  1353. alc_init_auto_mic(codec);
  1354. }
  1355. }
  1356. /*
  1357. * Fix-up pin default configurations and add default verbs
  1358. */
  1359. struct alc_pincfg {
  1360. hda_nid_t nid;
  1361. u32 val;
  1362. };
  1363. struct alc_fixup {
  1364. const struct alc_pincfg *pins;
  1365. const struct hda_verb *verbs;
  1366. };
  1367. static void alc_pick_fixup(struct hda_codec *codec,
  1368. const struct snd_pci_quirk *quirk,
  1369. const struct alc_fixup *fix,
  1370. int pre_init)
  1371. {
  1372. const struct alc_pincfg *cfg;
  1373. quirk = snd_pci_quirk_lookup(codec->bus->pci, quirk);
  1374. if (!quirk)
  1375. return;
  1376. fix += quirk->value;
  1377. cfg = fix->pins;
  1378. if (pre_init && cfg) {
  1379. #ifdef CONFIG_SND_DEBUG_VERBOSE
  1380. snd_printdd(KERN_INFO "hda_codec: %s: Apply pincfg for %s\n",
  1381. codec->chip_name, quirk->name);
  1382. #endif
  1383. for (; cfg->nid; cfg++)
  1384. snd_hda_codec_set_pincfg(codec, cfg->nid, cfg->val);
  1385. }
  1386. if (!pre_init && fix->verbs) {
  1387. #ifdef CONFIG_SND_DEBUG_VERBOSE
  1388. snd_printdd(KERN_INFO "hda_codec: %s: Apply fix-verbs for %s\n",
  1389. codec->chip_name, quirk->name);
  1390. #endif
  1391. add_verb(codec->spec, fix->verbs);
  1392. }
  1393. }
  1394. static int alc_read_coef_idx(struct hda_codec *codec,
  1395. unsigned int coef_idx)
  1396. {
  1397. unsigned int val;
  1398. snd_hda_codec_write(codec, 0x20, 0, AC_VERB_SET_COEF_INDEX,
  1399. coef_idx);
  1400. val = snd_hda_codec_read(codec, 0x20, 0,
  1401. AC_VERB_GET_PROC_COEF, 0);
  1402. return val;
  1403. }
  1404. /* set right pin controls for digital I/O */
  1405. static void alc_auto_init_digital(struct hda_codec *codec)
  1406. {
  1407. struct alc_spec *spec = codec->spec;
  1408. int i;
  1409. hda_nid_t pin;
  1410. for (i = 0; i < spec->autocfg.dig_outs; i++) {
  1411. pin = spec->autocfg.dig_out_pins[i];
  1412. if (pin) {
  1413. snd_hda_codec_write(codec, pin, 0,
  1414. AC_VERB_SET_PIN_WIDGET_CONTROL,
  1415. PIN_OUT);
  1416. }
  1417. }
  1418. pin = spec->autocfg.dig_in_pin;
  1419. if (pin)
  1420. snd_hda_codec_write(codec, pin, 0,
  1421. AC_VERB_SET_PIN_WIDGET_CONTROL,
  1422. PIN_IN);
  1423. }
  1424. /* parse digital I/Os and set up NIDs in BIOS auto-parse mode */
  1425. static void alc_auto_parse_digital(struct hda_codec *codec)
  1426. {
  1427. struct alc_spec *spec = codec->spec;
  1428. int i, err;
  1429. hda_nid_t dig_nid;
  1430. /* support multiple SPDIFs; the secondary is set up as a slave */
  1431. for (i = 0; i < spec->autocfg.dig_outs; i++) {
  1432. err = snd_hda_get_connections(codec,
  1433. spec->autocfg.dig_out_pins[i],
  1434. &dig_nid, 1);
  1435. if (err < 0)
  1436. continue;
  1437. if (!i) {
  1438. spec->multiout.dig_out_nid = dig_nid;
  1439. spec->dig_out_type = spec->autocfg.dig_out_type[0];
  1440. } else {
  1441. spec->multiout.slave_dig_outs = spec->slave_dig_outs;
  1442. if (i >= ARRAY_SIZE(spec->slave_dig_outs) - 1)
  1443. break;
  1444. spec->slave_dig_outs[i - 1] = dig_nid;
  1445. }
  1446. }
  1447. if (spec->autocfg.dig_in_pin) {
  1448. dig_nid = codec->start_nid;
  1449. for (i = 0; i < codec->num_nodes; i++, dig_nid++) {
  1450. unsigned int wcaps = get_wcaps(codec, dig_nid);
  1451. if (get_wcaps_type(wcaps) != AC_WID_AUD_IN)
  1452. continue;
  1453. if (!(wcaps & AC_WCAP_DIGITAL))
  1454. continue;
  1455. if (!(wcaps & AC_WCAP_CONN_LIST))
  1456. continue;
  1457. err = get_connection_index(codec, dig_nid,
  1458. spec->autocfg.dig_in_pin);
  1459. if (err >= 0) {
  1460. spec->dig_in_nid = dig_nid;
  1461. break;
  1462. }
  1463. }
  1464. }
  1465. }
  1466. /*
  1467. * ALC888
  1468. */
  1469. /*
  1470. * 2ch mode
  1471. */
  1472. static struct hda_verb alc888_4ST_ch2_intel_init[] = {
  1473. /* Mic-in jack as mic in */
  1474. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  1475. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  1476. /* Line-in jack as Line in */
  1477. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  1478. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  1479. /* Line-Out as Front */
  1480. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x00},
  1481. { } /* end */
  1482. };
  1483. /*
  1484. * 4ch mode
  1485. */
  1486. static struct hda_verb alc888_4ST_ch4_intel_init[] = {
  1487. /* Mic-in jack as mic in */
  1488. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  1489. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  1490. /* Line-in jack as Surround */
  1491. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  1492. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  1493. /* Line-Out as Front */
  1494. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x00},
  1495. { } /* end */
  1496. };
  1497. /*
  1498. * 6ch mode
  1499. */
  1500. static struct hda_verb alc888_4ST_ch6_intel_init[] = {
  1501. /* Mic-in jack as CLFE */
  1502. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  1503. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  1504. /* Line-in jack as Surround */
  1505. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  1506. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  1507. /* Line-Out as CLFE (workaround because Mic-in is not loud enough) */
  1508. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x03},
  1509. { } /* end */
  1510. };
  1511. /*
  1512. * 8ch mode
  1513. */
  1514. static struct hda_verb alc888_4ST_ch8_intel_init[] = {
  1515. /* Mic-in jack as CLFE */
  1516. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  1517. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  1518. /* Line-in jack as Surround */
  1519. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  1520. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  1521. /* Line-Out as Side */
  1522. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x03},
  1523. { } /* end */
  1524. };
  1525. static struct hda_channel_mode alc888_4ST_8ch_intel_modes[4] = {
  1526. { 2, alc888_4ST_ch2_intel_init },
  1527. { 4, alc888_4ST_ch4_intel_init },
  1528. { 6, alc888_4ST_ch6_intel_init },
  1529. { 8, alc888_4ST_ch8_intel_init },
  1530. };
  1531. /*
  1532. * ALC888 Fujitsu Siemens Amillo xa3530
  1533. */
  1534. static struct hda_verb alc888_fujitsu_xa3530_verbs[] = {
  1535. /* Front Mic: set to PIN_IN (empty by default) */
  1536. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  1537. /* Connect Internal HP to Front */
  1538. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1539. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1540. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  1541. /* Connect Bass HP to Front */
  1542. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1543. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1544. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  1545. /* Connect Line-Out side jack (SPDIF) to Side */
  1546. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1547. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1548. {0x17, AC_VERB_SET_CONNECT_SEL, 0x03},
  1549. /* Connect Mic jack to CLFE */
  1550. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1551. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1552. {0x18, AC_VERB_SET_CONNECT_SEL, 0x02},
  1553. /* Connect Line-in jack to Surround */
  1554. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1555. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1556. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x01},
  1557. /* Connect HP out jack to Front */
  1558. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1559. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1560. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  1561. /* Enable unsolicited event for HP jack and Line-out jack */
  1562. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  1563. {0x17, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  1564. {}
  1565. };
  1566. static void alc_automute_amp(struct hda_codec *codec)
  1567. {
  1568. struct alc_spec *spec = codec->spec;
  1569. unsigned int mute;
  1570. hda_nid_t nid;
  1571. int i;
  1572. spec->jack_present = 0;
  1573. for (i = 0; i < ARRAY_SIZE(spec->autocfg.hp_pins); i++) {
  1574. nid = spec->autocfg.hp_pins[i];
  1575. if (!nid)
  1576. break;
  1577. if (snd_hda_jack_detect(codec, nid)) {
  1578. spec->jack_present = 1;
  1579. break;
  1580. }
  1581. }
  1582. mute = spec->jack_present ? HDA_AMP_MUTE : 0;
  1583. /* Toggle internal speakers muting */
  1584. for (i = 0; i < ARRAY_SIZE(spec->autocfg.speaker_pins); i++) {
  1585. nid = spec->autocfg.speaker_pins[i];
  1586. if (!nid)
  1587. break;
  1588. snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0,
  1589. HDA_AMP_MUTE, mute);
  1590. }
  1591. }
  1592. static void alc_automute_amp_unsol_event(struct hda_codec *codec,
  1593. unsigned int res)
  1594. {
  1595. if (codec->vendor_id == 0x10ec0880)
  1596. res >>= 28;
  1597. else
  1598. res >>= 26;
  1599. if (res == ALC880_HP_EVENT)
  1600. alc_automute_amp(codec);
  1601. }
  1602. static void alc889_automute_setup(struct hda_codec *codec)
  1603. {
  1604. struct alc_spec *spec = codec->spec;
  1605. spec->autocfg.hp_pins[0] = 0x15;
  1606. spec->autocfg.speaker_pins[0] = 0x14;
  1607. spec->autocfg.speaker_pins[1] = 0x16;
  1608. spec->autocfg.speaker_pins[2] = 0x17;
  1609. spec->autocfg.speaker_pins[3] = 0x19;
  1610. spec->autocfg.speaker_pins[4] = 0x1a;
  1611. }
  1612. static void alc889_intel_init_hook(struct hda_codec *codec)
  1613. {
  1614. alc889_coef_init(codec);
  1615. alc_automute_amp(codec);
  1616. }
  1617. static void alc888_fujitsu_xa3530_setup(struct hda_codec *codec)
  1618. {
  1619. struct alc_spec *spec = codec->spec;
  1620. spec->autocfg.hp_pins[0] = 0x17; /* line-out */
  1621. spec->autocfg.hp_pins[1] = 0x1b; /* hp */
  1622. spec->autocfg.speaker_pins[0] = 0x14; /* speaker */
  1623. spec->autocfg.speaker_pins[1] = 0x15; /* bass */
  1624. }
  1625. /*
  1626. * ALC888 Acer Aspire 4930G model
  1627. */
  1628. static struct hda_verb alc888_acer_aspire_4930g_verbs[] = {
  1629. /* Front Mic: set to PIN_IN (empty by default) */
  1630. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  1631. /* Unselect Front Mic by default in input mixer 3 */
  1632. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0xb)},
  1633. /* Enable unsolicited event for HP jack */
  1634. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  1635. /* Connect Internal HP to front */
  1636. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1637. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1638. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  1639. /* Connect HP out to front */
  1640. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1641. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1642. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  1643. { }
  1644. };
  1645. /*
  1646. * ALC888 Acer Aspire 6530G model
  1647. */
  1648. static struct hda_verb alc888_acer_aspire_6530g_verbs[] = {
  1649. /* Route to built-in subwoofer as well as speakers */
  1650. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  1651. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  1652. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  1653. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  1654. /* Bias voltage on for external mic port */
  1655. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN | PIN_VREF80},
  1656. /* Front Mic: set to PIN_IN (empty by default) */
  1657. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  1658. /* Unselect Front Mic by default in input mixer 3 */
  1659. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0xb)},
  1660. /* Enable unsolicited event for HP jack */
  1661. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  1662. /* Enable speaker output */
  1663. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1664. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1665. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  1666. /* Enable headphone output */
  1667. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | PIN_HP},
  1668. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1669. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  1670. {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
  1671. { }
  1672. };
  1673. /*
  1674. * ALC889 Acer Aspire 8930G model
  1675. */
  1676. static struct hda_verb alc889_acer_aspire_8930g_verbs[] = {
  1677. /* Front Mic: set to PIN_IN (empty by default) */
  1678. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  1679. /* Unselect Front Mic by default in input mixer 3 */
  1680. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0xb)},
  1681. /* Enable unsolicited event for HP jack */
  1682. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  1683. /* Connect Internal Front to Front */
  1684. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1685. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1686. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  1687. /* Connect Internal Rear to Rear */
  1688. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1689. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1690. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x01},
  1691. /* Connect Internal CLFE to CLFE */
  1692. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  1693. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1694. {0x16, AC_VERB_SET_CONNECT_SEL, 0x02},
  1695. /* Connect HP out to Front */
  1696. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | PIN_HP},
  1697. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  1698. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  1699. /* Enable all DACs */
  1700. /* DAC DISABLE/MUTE 1? */
  1701. /* setting bits 1-5 disables DAC nids 0x02-0x06 apparently. Init=0x38 */
  1702. {0x20, AC_VERB_SET_COEF_INDEX, 0x03},
  1703. {0x20, AC_VERB_SET_PROC_COEF, 0x0000},
  1704. /* DAC DISABLE/MUTE 2? */
  1705. /* some bit here disables the other DACs. Init=0x4900 */
  1706. {0x20, AC_VERB_SET_COEF_INDEX, 0x08},
  1707. {0x20, AC_VERB_SET_PROC_COEF, 0x0000},
  1708. /* DMIC fix
  1709. * This laptop has a stereo digital microphone. The mics are only 1cm apart
  1710. * which makes the stereo useless. However, either the mic or the ALC889
  1711. * makes the signal become a difference/sum signal instead of standard
  1712. * stereo, which is annoying. So instead we flip this bit which makes the
  1713. * codec replicate the sum signal to both channels, turning it into a
  1714. * normal mono mic.
  1715. */
  1716. /* DMIC_CONTROL? Init value = 0x0001 */
  1717. {0x20, AC_VERB_SET_COEF_INDEX, 0x0b},
  1718. {0x20, AC_VERB_SET_PROC_COEF, 0x0003},
  1719. { }
  1720. };
  1721. static struct hda_input_mux alc888_2_capture_sources[2] = {
  1722. /* Front mic only available on one ADC */
  1723. {
  1724. .num_items = 4,
  1725. .items = {
  1726. { "Mic", 0x0 },
  1727. { "Line", 0x2 },
  1728. { "CD", 0x4 },
  1729. { "Front Mic", 0xb },
  1730. },
  1731. },
  1732. {
  1733. .num_items = 3,
  1734. .items = {
  1735. { "Mic", 0x0 },
  1736. { "Line", 0x2 },
  1737. { "CD", 0x4 },
  1738. },
  1739. }
  1740. };
  1741. static struct hda_input_mux alc888_acer_aspire_6530_sources[2] = {
  1742. /* Interal mic only available on one ADC */
  1743. {
  1744. .num_items = 5,
  1745. .items = {
  1746. { "Ext Mic", 0x0 },
  1747. { "Line In", 0x2 },
  1748. { "CD", 0x4 },
  1749. { "Input Mix", 0xa },
  1750. { "Int Mic", 0xb },
  1751. },
  1752. },
  1753. {
  1754. .num_items = 4,
  1755. .items = {
  1756. { "Ext Mic", 0x0 },
  1757. { "Line In", 0x2 },
  1758. { "CD", 0x4 },
  1759. { "Input Mix", 0xa },
  1760. },
  1761. }
  1762. };
  1763. static struct hda_input_mux alc889_capture_sources[3] = {
  1764. /* Digital mic only available on first "ADC" */
  1765. {
  1766. .num_items = 5,
  1767. .items = {
  1768. { "Mic", 0x0 },
  1769. { "Line", 0x2 },
  1770. { "CD", 0x4 },
  1771. { "Front Mic", 0xb },
  1772. { "Input Mix", 0xa },
  1773. },
  1774. },
  1775. {
  1776. .num_items = 4,
  1777. .items = {
  1778. { "Mic", 0x0 },
  1779. { "Line", 0x2 },
  1780. { "CD", 0x4 },
  1781. { "Input Mix", 0xa },
  1782. },
  1783. },
  1784. {
  1785. .num_items = 4,
  1786. .items = {
  1787. { "Mic", 0x0 },
  1788. { "Line", 0x2 },
  1789. { "CD", 0x4 },
  1790. { "Input Mix", 0xa },
  1791. },
  1792. }
  1793. };
  1794. static struct snd_kcontrol_new alc888_base_mixer[] = {
  1795. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  1796. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  1797. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  1798. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  1799. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0,
  1800. HDA_OUTPUT),
  1801. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  1802. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  1803. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  1804. HDA_CODEC_VOLUME("Side Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  1805. HDA_BIND_MUTE("Side Playback Switch", 0x0f, 2, HDA_INPUT),
  1806. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  1807. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  1808. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  1809. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  1810. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  1811. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  1812. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  1813. { } /* end */
  1814. };
  1815. static struct snd_kcontrol_new alc889_acer_aspire_8930g_mixer[] = {
  1816. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  1817. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  1818. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  1819. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  1820. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0,
  1821. HDA_OUTPUT),
  1822. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  1823. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  1824. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  1825. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  1826. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  1827. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  1828. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  1829. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  1830. { } /* end */
  1831. };
  1832. static void alc888_acer_aspire_4930g_setup(struct hda_codec *codec)
  1833. {
  1834. struct alc_spec *spec = codec->spec;
  1835. spec->autocfg.hp_pins[0] = 0x15;
  1836. spec->autocfg.speaker_pins[0] = 0x14;
  1837. spec->autocfg.speaker_pins[1] = 0x16;
  1838. spec->autocfg.speaker_pins[2] = 0x17;
  1839. }
  1840. static void alc888_acer_aspire_6530g_setup(struct hda_codec *codec)
  1841. {
  1842. struct alc_spec *spec = codec->spec;
  1843. spec->autocfg.hp_pins[0] = 0x15;
  1844. spec->autocfg.speaker_pins[0] = 0x14;
  1845. spec->autocfg.speaker_pins[1] = 0x16;
  1846. spec->autocfg.speaker_pins[2] = 0x17;
  1847. }
  1848. static void alc889_acer_aspire_8930g_setup(struct hda_codec *codec)
  1849. {
  1850. struct alc_spec *spec = codec->spec;
  1851. spec->autocfg.hp_pins[0] = 0x15;
  1852. spec->autocfg.speaker_pins[0] = 0x14;
  1853. spec->autocfg.speaker_pins[1] = 0x16;
  1854. spec->autocfg.speaker_pins[2] = 0x1b;
  1855. }
  1856. /*
  1857. * ALC880 3-stack model
  1858. *
  1859. * DAC: Front = 0x02 (0x0c), Surr = 0x05 (0x0f), CLFE = 0x04 (0x0e)
  1860. * Pin assignment: Front = 0x14, Line-In/Surr = 0x1a, Mic/CLFE = 0x18,
  1861. * F-Mic = 0x1b, HP = 0x19
  1862. */
  1863. static hda_nid_t alc880_dac_nids[4] = {
  1864. /* front, rear, clfe, rear_surr */
  1865. 0x02, 0x05, 0x04, 0x03
  1866. };
  1867. static hda_nid_t alc880_adc_nids[3] = {
  1868. /* ADC0-2 */
  1869. 0x07, 0x08, 0x09,
  1870. };
  1871. /* The datasheet says the node 0x07 is connected from inputs,
  1872. * but it shows zero connection in the real implementation on some devices.
  1873. * Note: this is a 915GAV bug, fixed on 915GLV
  1874. */
  1875. static hda_nid_t alc880_adc_nids_alt[2] = {
  1876. /* ADC1-2 */
  1877. 0x08, 0x09,
  1878. };
  1879. #define ALC880_DIGOUT_NID 0x06
  1880. #define ALC880_DIGIN_NID 0x0a
  1881. static struct hda_input_mux alc880_capture_source = {
  1882. .num_items = 4,
  1883. .items = {
  1884. { "Mic", 0x0 },
  1885. { "Front Mic", 0x3 },
  1886. { "Line", 0x2 },
  1887. { "CD", 0x4 },
  1888. },
  1889. };
  1890. /* channel source setting (2/6 channel selection for 3-stack) */
  1891. /* 2ch mode */
  1892. static struct hda_verb alc880_threestack_ch2_init[] = {
  1893. /* set line-in to input, mute it */
  1894. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  1895. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  1896. /* set mic-in to input vref 80%, mute it */
  1897. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  1898. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  1899. { } /* end */
  1900. };
  1901. /* 6ch mode */
  1902. static struct hda_verb alc880_threestack_ch6_init[] = {
  1903. /* set line-in to output, unmute it */
  1904. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  1905. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  1906. /* set mic-in to output, unmute it */
  1907. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  1908. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  1909. { } /* end */
  1910. };
  1911. static struct hda_channel_mode alc880_threestack_modes[2] = {
  1912. { 2, alc880_threestack_ch2_init },
  1913. { 6, alc880_threestack_ch6_init },
  1914. };
  1915. static struct snd_kcontrol_new alc880_three_stack_mixer[] = {
  1916. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  1917. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  1918. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  1919. HDA_BIND_MUTE("Surround Playback Switch", 0x0f, 2, HDA_INPUT),
  1920. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  1921. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  1922. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  1923. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  1924. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  1925. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  1926. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  1927. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  1928. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  1929. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  1930. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x3, HDA_INPUT),
  1931. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x3, HDA_INPUT),
  1932. HDA_CODEC_MUTE("Headphone Playback Switch", 0x19, 0x0, HDA_OUTPUT),
  1933. {
  1934. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  1935. .name = "Channel Mode",
  1936. .info = alc_ch_mode_info,
  1937. .get = alc_ch_mode_get,
  1938. .put = alc_ch_mode_put,
  1939. },
  1940. { } /* end */
  1941. };
  1942. /* capture mixer elements */
  1943. static int alc_cap_vol_info(struct snd_kcontrol *kcontrol,
  1944. struct snd_ctl_elem_info *uinfo)
  1945. {
  1946. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  1947. struct alc_spec *spec = codec->spec;
  1948. int err;
  1949. mutex_lock(&codec->control_mutex);
  1950. kcontrol->private_value = HDA_COMPOSE_AMP_VAL(spec->adc_nids[0], 3, 0,
  1951. HDA_INPUT);
  1952. err = snd_hda_mixer_amp_volume_info(kcontrol, uinfo);
  1953. mutex_unlock(&codec->control_mutex);
  1954. return err;
  1955. }
  1956. static int alc_cap_vol_tlv(struct snd_kcontrol *kcontrol, int op_flag,
  1957. unsigned int size, unsigned int __user *tlv)
  1958. {
  1959. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  1960. struct alc_spec *spec = codec->spec;
  1961. int err;
  1962. mutex_lock(&codec->control_mutex);
  1963. kcontrol->private_value = HDA_COMPOSE_AMP_VAL(spec->adc_nids[0], 3, 0,
  1964. HDA_INPUT);
  1965. err = snd_hda_mixer_amp_tlv(kcontrol, op_flag, size, tlv);
  1966. mutex_unlock(&codec->control_mutex);
  1967. return err;
  1968. }
  1969. typedef int (*getput_call_t)(struct snd_kcontrol *kcontrol,
  1970. struct snd_ctl_elem_value *ucontrol);
  1971. static int alc_cap_getput_caller(struct snd_kcontrol *kcontrol,
  1972. struct snd_ctl_elem_value *ucontrol,
  1973. getput_call_t func)
  1974. {
  1975. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  1976. struct alc_spec *spec = codec->spec;
  1977. unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
  1978. int err;
  1979. mutex_lock(&codec->control_mutex);
  1980. kcontrol->private_value = HDA_COMPOSE_AMP_VAL(spec->adc_nids[adc_idx],
  1981. 3, 0, HDA_INPUT);
  1982. err = func(kcontrol, ucontrol);
  1983. mutex_unlock(&codec->control_mutex);
  1984. return err;
  1985. }
  1986. static int alc_cap_vol_get(struct snd_kcontrol *kcontrol,
  1987. struct snd_ctl_elem_value *ucontrol)
  1988. {
  1989. return alc_cap_getput_caller(kcontrol, ucontrol,
  1990. snd_hda_mixer_amp_volume_get);
  1991. }
  1992. static int alc_cap_vol_put(struct snd_kcontrol *kcontrol,
  1993. struct snd_ctl_elem_value *ucontrol)
  1994. {
  1995. return alc_cap_getput_caller(kcontrol, ucontrol,
  1996. snd_hda_mixer_amp_volume_put);
  1997. }
  1998. /* capture mixer elements */
  1999. #define alc_cap_sw_info snd_ctl_boolean_stereo_info
  2000. static int alc_cap_sw_get(struct snd_kcontrol *kcontrol,
  2001. struct snd_ctl_elem_value *ucontrol)
  2002. {
  2003. return alc_cap_getput_caller(kcontrol, ucontrol,
  2004. snd_hda_mixer_amp_switch_get);
  2005. }
  2006. static int alc_cap_sw_put(struct snd_kcontrol *kcontrol,
  2007. struct snd_ctl_elem_value *ucontrol)
  2008. {
  2009. return alc_cap_getput_caller(kcontrol, ucontrol,
  2010. snd_hda_mixer_amp_switch_put);
  2011. }
  2012. #define _DEFINE_CAPMIX(num) \
  2013. { \
  2014. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  2015. .name = "Capture Switch", \
  2016. .access = SNDRV_CTL_ELEM_ACCESS_READWRITE, \
  2017. .count = num, \
  2018. .info = alc_cap_sw_info, \
  2019. .get = alc_cap_sw_get, \
  2020. .put = alc_cap_sw_put, \
  2021. }, \
  2022. { \
  2023. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  2024. .name = "Capture Volume", \
  2025. .access = (SNDRV_CTL_ELEM_ACCESS_READWRITE | \
  2026. SNDRV_CTL_ELEM_ACCESS_TLV_READ | \
  2027. SNDRV_CTL_ELEM_ACCESS_TLV_CALLBACK), \
  2028. .count = num, \
  2029. .info = alc_cap_vol_info, \
  2030. .get = alc_cap_vol_get, \
  2031. .put = alc_cap_vol_put, \
  2032. .tlv = { .c = alc_cap_vol_tlv }, \
  2033. }
  2034. #define _DEFINE_CAPSRC(num) \
  2035. { \
  2036. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  2037. /* .name = "Capture Source", */ \
  2038. .name = "Input Source", \
  2039. .count = num, \
  2040. .info = alc_mux_enum_info, \
  2041. .get = alc_mux_enum_get, \
  2042. .put = alc_mux_enum_put, \
  2043. }
  2044. #define DEFINE_CAPMIX(num) \
  2045. static struct snd_kcontrol_new alc_capture_mixer ## num[] = { \
  2046. _DEFINE_CAPMIX(num), \
  2047. _DEFINE_CAPSRC(num), \
  2048. { } /* end */ \
  2049. }
  2050. #define DEFINE_CAPMIX_NOSRC(num) \
  2051. static struct snd_kcontrol_new alc_capture_mixer_nosrc ## num[] = { \
  2052. _DEFINE_CAPMIX(num), \
  2053. { } /* end */ \
  2054. }
  2055. /* up to three ADCs */
  2056. DEFINE_CAPMIX(1);
  2057. DEFINE_CAPMIX(2);
  2058. DEFINE_CAPMIX(3);
  2059. DEFINE_CAPMIX_NOSRC(1);
  2060. DEFINE_CAPMIX_NOSRC(2);
  2061. DEFINE_CAPMIX_NOSRC(3);
  2062. /*
  2063. * ALC880 5-stack model
  2064. *
  2065. * DAC: Front = 0x02 (0x0c), Surr = 0x05 (0x0f), CLFE = 0x04 (0x0d),
  2066. * Side = 0x02 (0xd)
  2067. * Pin assignment: Front = 0x14, Surr = 0x17, CLFE = 0x16
  2068. * Line-In/Side = 0x1a, Mic = 0x18, F-Mic = 0x1b, HP = 0x19
  2069. */
  2070. /* additional mixers to alc880_three_stack_mixer */
  2071. static struct snd_kcontrol_new alc880_five_stack_mixer[] = {
  2072. HDA_CODEC_VOLUME("Side Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2073. HDA_BIND_MUTE("Side Playback Switch", 0x0d, 2, HDA_INPUT),
  2074. { } /* end */
  2075. };
  2076. /* channel source setting (6/8 channel selection for 5-stack) */
  2077. /* 6ch mode */
  2078. static struct hda_verb alc880_fivestack_ch6_init[] = {
  2079. /* set line-in to input, mute it */
  2080. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  2081. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  2082. { } /* end */
  2083. };
  2084. /* 8ch mode */
  2085. static struct hda_verb alc880_fivestack_ch8_init[] = {
  2086. /* set line-in to output, unmute it */
  2087. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  2088. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  2089. { } /* end */
  2090. };
  2091. static struct hda_channel_mode alc880_fivestack_modes[2] = {
  2092. { 6, alc880_fivestack_ch6_init },
  2093. { 8, alc880_fivestack_ch8_init },
  2094. };
  2095. /*
  2096. * ALC880 6-stack model
  2097. *
  2098. * DAC: Front = 0x02 (0x0c), Surr = 0x03 (0x0d), CLFE = 0x04 (0x0e),
  2099. * Side = 0x05 (0x0f)
  2100. * Pin assignment: Front = 0x14, Surr = 0x15, CLFE = 0x16, Side = 0x17,
  2101. * Mic = 0x18, F-Mic = 0x19, Line = 0x1a, HP = 0x1b
  2102. */
  2103. static hda_nid_t alc880_6st_dac_nids[4] = {
  2104. /* front, rear, clfe, rear_surr */
  2105. 0x02, 0x03, 0x04, 0x05
  2106. };
  2107. static struct hda_input_mux alc880_6stack_capture_source = {
  2108. .num_items = 4,
  2109. .items = {
  2110. { "Mic", 0x0 },
  2111. { "Front Mic", 0x1 },
  2112. { "Line", 0x2 },
  2113. { "CD", 0x4 },
  2114. },
  2115. };
  2116. /* fixed 8-channels */
  2117. static struct hda_channel_mode alc880_sixstack_modes[1] = {
  2118. { 8, NULL },
  2119. };
  2120. static struct snd_kcontrol_new alc880_six_stack_mixer[] = {
  2121. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2122. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  2123. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2124. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  2125. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  2126. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  2127. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  2128. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  2129. HDA_CODEC_VOLUME("Side Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  2130. HDA_BIND_MUTE("Side Playback Switch", 0x0f, 2, HDA_INPUT),
  2131. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  2132. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  2133. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  2134. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  2135. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  2136. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  2137. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  2138. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  2139. {
  2140. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  2141. .name = "Channel Mode",
  2142. .info = alc_ch_mode_info,
  2143. .get = alc_ch_mode_get,
  2144. .put = alc_ch_mode_put,
  2145. },
  2146. { } /* end */
  2147. };
  2148. /*
  2149. * ALC880 W810 model
  2150. *
  2151. * W810 has rear IO for:
  2152. * Front (DAC 02)
  2153. * Surround (DAC 03)
  2154. * Center/LFE (DAC 04)
  2155. * Digital out (06)
  2156. *
  2157. * The system also has a pair of internal speakers, and a headphone jack.
  2158. * These are both connected to Line2 on the codec, hence to DAC 02.
  2159. *
  2160. * There is a variable resistor to control the speaker or headphone
  2161. * volume. This is a hardware-only device without a software API.
  2162. *
  2163. * Plugging headphones in will disable the internal speakers. This is
  2164. * implemented in hardware, not via the driver using jack sense. In
  2165. * a similar fashion, plugging into the rear socket marked "front" will
  2166. * disable both the speakers and headphones.
  2167. *
  2168. * For input, there's a microphone jack, and an "audio in" jack.
  2169. * These may not do anything useful with this driver yet, because I
  2170. * haven't setup any initialization verbs for these yet...
  2171. */
  2172. static hda_nid_t alc880_w810_dac_nids[3] = {
  2173. /* front, rear/surround, clfe */
  2174. 0x02, 0x03, 0x04
  2175. };
  2176. /* fixed 6 channels */
  2177. static struct hda_channel_mode alc880_w810_modes[1] = {
  2178. { 6, NULL }
  2179. };
  2180. /* Pin assignment: Front = 0x14, Surr = 0x15, CLFE = 0x16, HP = 0x1b */
  2181. static struct snd_kcontrol_new alc880_w810_base_mixer[] = {
  2182. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2183. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  2184. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2185. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  2186. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  2187. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  2188. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  2189. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  2190. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  2191. { } /* end */
  2192. };
  2193. /*
  2194. * Z710V model
  2195. *
  2196. * DAC: Front = 0x02 (0x0c), HP = 0x03 (0x0d)
  2197. * Pin assignment: Front = 0x14, HP = 0x15, Mic = 0x18, Mic2 = 0x19(?),
  2198. * Line = 0x1a
  2199. */
  2200. static hda_nid_t alc880_z71v_dac_nids[1] = {
  2201. 0x02
  2202. };
  2203. #define ALC880_Z71V_HP_DAC 0x03
  2204. /* fixed 2 channels */
  2205. static struct hda_channel_mode alc880_2_jack_modes[1] = {
  2206. { 2, NULL }
  2207. };
  2208. static struct snd_kcontrol_new alc880_z71v_mixer[] = {
  2209. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2210. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  2211. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2212. HDA_BIND_MUTE("Headphone Playback Switch", 0x0d, 2, HDA_INPUT),
  2213. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  2214. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  2215. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  2216. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  2217. { } /* end */
  2218. };
  2219. /*
  2220. * ALC880 F1734 model
  2221. *
  2222. * DAC: HP = 0x02 (0x0c), Front = 0x03 (0x0d)
  2223. * Pin assignment: HP = 0x14, Front = 0x15, Mic = 0x18
  2224. */
  2225. static hda_nid_t alc880_f1734_dac_nids[1] = {
  2226. 0x03
  2227. };
  2228. #define ALC880_F1734_HP_DAC 0x02
  2229. static struct snd_kcontrol_new alc880_f1734_mixer[] = {
  2230. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2231. HDA_BIND_MUTE("Headphone Playback Switch", 0x0c, 2, HDA_INPUT),
  2232. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2233. HDA_BIND_MUTE("Speaker Playback Switch", 0x0d, 2, HDA_INPUT),
  2234. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  2235. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  2236. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  2237. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  2238. { } /* end */
  2239. };
  2240. static struct hda_input_mux alc880_f1734_capture_source = {
  2241. .num_items = 2,
  2242. .items = {
  2243. { "Mic", 0x1 },
  2244. { "CD", 0x4 },
  2245. },
  2246. };
  2247. /*
  2248. * ALC880 ASUS model
  2249. *
  2250. * DAC: HP/Front = 0x02 (0x0c), Surr = 0x03 (0x0d), CLFE = 0x04 (0x0e)
  2251. * Pin assignment: HP/Front = 0x14, Surr = 0x15, CLFE = 0x16,
  2252. * Mic = 0x18, Line = 0x1a
  2253. */
  2254. #define alc880_asus_dac_nids alc880_w810_dac_nids /* identical with w810 */
  2255. #define alc880_asus_modes alc880_threestack_modes /* 2/6 channel mode */
  2256. static struct snd_kcontrol_new alc880_asus_mixer[] = {
  2257. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2258. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  2259. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2260. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  2261. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  2262. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  2263. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  2264. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  2265. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  2266. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  2267. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  2268. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  2269. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  2270. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  2271. {
  2272. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  2273. .name = "Channel Mode",
  2274. .info = alc_ch_mode_info,
  2275. .get = alc_ch_mode_get,
  2276. .put = alc_ch_mode_put,
  2277. },
  2278. { } /* end */
  2279. };
  2280. /*
  2281. * ALC880 ASUS W1V model
  2282. *
  2283. * DAC: HP/Front = 0x02 (0x0c), Surr = 0x03 (0x0d), CLFE = 0x04 (0x0e)
  2284. * Pin assignment: HP/Front = 0x14, Surr = 0x15, CLFE = 0x16,
  2285. * Mic = 0x18, Line = 0x1a, Line2 = 0x1b
  2286. */
  2287. /* additional mixers to alc880_asus_mixer */
  2288. static struct snd_kcontrol_new alc880_asus_w1v_mixer[] = {
  2289. HDA_CODEC_VOLUME("Line2 Playback Volume", 0x0b, 0x03, HDA_INPUT),
  2290. HDA_CODEC_MUTE("Line2 Playback Switch", 0x0b, 0x03, HDA_INPUT),
  2291. { } /* end */
  2292. };
  2293. /* TCL S700 */
  2294. static struct snd_kcontrol_new alc880_tcl_s700_mixer[] = {
  2295. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2296. HDA_CODEC_MUTE("Front Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  2297. HDA_CODEC_MUTE("Headphone Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  2298. HDA_CODEC_VOLUME("CD Playback Volume", 0x0B, 0x04, HDA_INPUT),
  2299. HDA_CODEC_MUTE("CD Playback Switch", 0x0B, 0x04, HDA_INPUT),
  2300. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0B, 0x0, HDA_INPUT),
  2301. HDA_CODEC_MUTE("Mic Playback Switch", 0x0B, 0x0, HDA_INPUT),
  2302. HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
  2303. HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
  2304. { } /* end */
  2305. };
  2306. /* Uniwill */
  2307. static struct snd_kcontrol_new alc880_uniwill_mixer[] = {
  2308. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2309. HDA_BIND_MUTE("Headphone Playback Switch", 0x0c, 2, HDA_INPUT),
  2310. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2311. HDA_BIND_MUTE("Speaker Playback Switch", 0x0d, 2, HDA_INPUT),
  2312. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  2313. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  2314. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  2315. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  2316. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  2317. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  2318. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  2319. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  2320. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  2321. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  2322. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  2323. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  2324. {
  2325. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  2326. .name = "Channel Mode",
  2327. .info = alc_ch_mode_info,
  2328. .get = alc_ch_mode_get,
  2329. .put = alc_ch_mode_put,
  2330. },
  2331. { } /* end */
  2332. };
  2333. static struct snd_kcontrol_new alc880_fujitsu_mixer[] = {
  2334. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2335. HDA_BIND_MUTE("Headphone Playback Switch", 0x0c, 2, HDA_INPUT),
  2336. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2337. HDA_BIND_MUTE("Speaker Playback Switch", 0x0d, 2, HDA_INPUT),
  2338. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  2339. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  2340. HDA_CODEC_VOLUME("Ext Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  2341. HDA_CODEC_MUTE("Ext Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  2342. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  2343. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  2344. { } /* end */
  2345. };
  2346. static struct snd_kcontrol_new alc880_uniwill_p53_mixer[] = {
  2347. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  2348. HDA_BIND_MUTE("Headphone Playback Switch", 0x0c, 2, HDA_INPUT),
  2349. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  2350. HDA_BIND_MUTE("Speaker Playback Switch", 0x0d, 2, HDA_INPUT),
  2351. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  2352. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  2353. { } /* end */
  2354. };
  2355. /*
  2356. * virtual master controls
  2357. */
  2358. /*
  2359. * slave controls for virtual master
  2360. */
  2361. static const char *alc_slave_vols[] = {
  2362. "Front Playback Volume",
  2363. "Surround Playback Volume",
  2364. "Center Playback Volume",
  2365. "LFE Playback Volume",
  2366. "Side Playback Volume",
  2367. "Headphone Playback Volume",
  2368. "Speaker Playback Volume",
  2369. "Mono Playback Volume",
  2370. "Line-Out Playback Volume",
  2371. "PCM Playback Volume",
  2372. NULL,
  2373. };
  2374. static const char *alc_slave_sws[] = {
  2375. "Front Playback Switch",
  2376. "Surround Playback Switch",
  2377. "Center Playback Switch",
  2378. "LFE Playback Switch",
  2379. "Side Playback Switch",
  2380. "Headphone Playback Switch",
  2381. "Speaker Playback Switch",
  2382. "Mono Playback Switch",
  2383. "IEC958 Playback Switch",
  2384. "Line-Out Playback Switch",
  2385. "PCM Playback Switch",
  2386. NULL,
  2387. };
  2388. /*
  2389. * build control elements
  2390. */
  2391. #define NID_MAPPING (-1)
  2392. #define SUBDEV_SPEAKER_ (0 << 6)
  2393. #define SUBDEV_HP_ (1 << 6)
  2394. #define SUBDEV_LINE_ (2 << 6)
  2395. #define SUBDEV_SPEAKER(x) (SUBDEV_SPEAKER_ | ((x) & 0x3f))
  2396. #define SUBDEV_HP(x) (SUBDEV_HP_ | ((x) & 0x3f))
  2397. #define SUBDEV_LINE(x) (SUBDEV_LINE_ | ((x) & 0x3f))
  2398. static void alc_free_kctls(struct hda_codec *codec);
  2399. #ifdef CONFIG_SND_HDA_INPUT_BEEP
  2400. /* additional beep mixers; the actual parameters are overwritten at build */
  2401. static struct snd_kcontrol_new alc_beep_mixer[] = {
  2402. HDA_CODEC_VOLUME("Beep Playback Volume", 0, 0, HDA_INPUT),
  2403. HDA_CODEC_MUTE_BEEP("Beep Playback Switch", 0, 0, HDA_INPUT),
  2404. { } /* end */
  2405. };
  2406. #endif
  2407. static int alc_build_controls(struct hda_codec *codec)
  2408. {
  2409. struct alc_spec *spec = codec->spec;
  2410. struct snd_kcontrol *kctl = NULL;
  2411. struct snd_kcontrol_new *knew;
  2412. int i, j, err;
  2413. unsigned int u;
  2414. hda_nid_t nid;
  2415. for (i = 0; i < spec->num_mixers; i++) {
  2416. err = snd_hda_add_new_ctls(codec, spec->mixers[i]);
  2417. if (err < 0)
  2418. return err;
  2419. }
  2420. if (spec->cap_mixer) {
  2421. err = snd_hda_add_new_ctls(codec, spec->cap_mixer);
  2422. if (err < 0)
  2423. return err;
  2424. }
  2425. if (spec->multiout.dig_out_nid) {
  2426. err = snd_hda_create_spdif_out_ctls(codec,
  2427. spec->multiout.dig_out_nid);
  2428. if (err < 0)
  2429. return err;
  2430. if (!spec->no_analog) {
  2431. err = snd_hda_create_spdif_share_sw(codec,
  2432. &spec->multiout);
  2433. if (err < 0)
  2434. return err;
  2435. spec->multiout.share_spdif = 1;
  2436. }
  2437. }
  2438. if (spec->dig_in_nid) {
  2439. err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in_nid);
  2440. if (err < 0)
  2441. return err;
  2442. }
  2443. #ifdef CONFIG_SND_HDA_INPUT_BEEP
  2444. /* create beep controls if needed */
  2445. if (spec->beep_amp) {
  2446. struct snd_kcontrol_new *knew;
  2447. for (knew = alc_beep_mixer; knew->name; knew++) {
  2448. struct snd_kcontrol *kctl;
  2449. kctl = snd_ctl_new1(knew, codec);
  2450. if (!kctl)
  2451. return -ENOMEM;
  2452. kctl->private_value = spec->beep_amp;
  2453. err = snd_hda_ctl_add(codec, 0, kctl);
  2454. if (err < 0)
  2455. return err;
  2456. }
  2457. }
  2458. #endif
  2459. /* if we have no master control, let's create it */
  2460. if (!spec->no_analog &&
  2461. !snd_hda_find_mixer_ctl(codec, "Master Playback Volume")) {
  2462. unsigned int vmaster_tlv[4];
  2463. snd_hda_set_vmaster_tlv(codec, spec->vmaster_nid,
  2464. HDA_OUTPUT, vmaster_tlv);
  2465. err = snd_hda_add_vmaster(codec, "Master Playback Volume",
  2466. vmaster_tlv, alc_slave_vols);
  2467. if (err < 0)
  2468. return err;
  2469. }
  2470. if (!spec->no_analog &&
  2471. !snd_hda_find_mixer_ctl(codec, "Master Playback Switch")) {
  2472. err = snd_hda_add_vmaster(codec, "Master Playback Switch",
  2473. NULL, alc_slave_sws);
  2474. if (err < 0)
  2475. return err;
  2476. }
  2477. /* assign Capture Source enums to NID */
  2478. if (spec->capsrc_nids || spec->adc_nids) {
  2479. kctl = snd_hda_find_mixer_ctl(codec, "Capture Source");
  2480. if (!kctl)
  2481. kctl = snd_hda_find_mixer_ctl(codec, "Input Source");
  2482. for (i = 0; kctl && i < kctl->count; i++) {
  2483. hda_nid_t *nids = spec->capsrc_nids;
  2484. if (!nids)
  2485. nids = spec->adc_nids;
  2486. err = snd_hda_add_nid(codec, kctl, i, nids[i]);
  2487. if (err < 0)
  2488. return err;
  2489. }
  2490. }
  2491. if (spec->cap_mixer) {
  2492. const char *kname = kctl ? kctl->id.name : NULL;
  2493. for (knew = spec->cap_mixer; knew->name; knew++) {
  2494. if (kname && strcmp(knew->name, kname) == 0)
  2495. continue;
  2496. kctl = snd_hda_find_mixer_ctl(codec, knew->name);
  2497. for (i = 0; kctl && i < kctl->count; i++) {
  2498. err = snd_hda_add_nid(codec, kctl, i,
  2499. spec->adc_nids[i]);
  2500. if (err < 0)
  2501. return err;
  2502. }
  2503. }
  2504. }
  2505. /* other nid->control mapping */
  2506. for (i = 0; i < spec->num_mixers; i++) {
  2507. for (knew = spec->mixers[i]; knew->name; knew++) {
  2508. if (knew->iface != NID_MAPPING)
  2509. continue;
  2510. kctl = snd_hda_find_mixer_ctl(codec, knew->name);
  2511. if (kctl == NULL)
  2512. continue;
  2513. u = knew->subdevice;
  2514. for (j = 0; j < 4; j++, u >>= 8) {
  2515. nid = u & 0x3f;
  2516. if (nid == 0)
  2517. continue;
  2518. switch (u & 0xc0) {
  2519. case SUBDEV_SPEAKER_:
  2520. nid = spec->autocfg.speaker_pins[nid];
  2521. break;
  2522. case SUBDEV_LINE_:
  2523. nid = spec->autocfg.line_out_pins[nid];
  2524. break;
  2525. case SUBDEV_HP_:
  2526. nid = spec->autocfg.hp_pins[nid];
  2527. break;
  2528. default:
  2529. continue;
  2530. }
  2531. err = snd_hda_add_nid(codec, kctl, 0, nid);
  2532. if (err < 0)
  2533. return err;
  2534. }
  2535. u = knew->private_value;
  2536. for (j = 0; j < 4; j++, u >>= 8) {
  2537. nid = u & 0xff;
  2538. if (nid == 0)
  2539. continue;
  2540. err = snd_hda_add_nid(codec, kctl, 0, nid);
  2541. if (err < 0)
  2542. return err;
  2543. }
  2544. }
  2545. }
  2546. alc_free_kctls(codec); /* no longer needed */
  2547. return 0;
  2548. }
  2549. /*
  2550. * initialize the codec volumes, etc
  2551. */
  2552. /*
  2553. * generic initialization of ADC, input mixers and output mixers
  2554. */
  2555. static struct hda_verb alc880_volume_init_verbs[] = {
  2556. /*
  2557. * Unmute ADC0-2 and set the default input to mic-in
  2558. */
  2559. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  2560. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  2561. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  2562. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  2563. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  2564. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  2565. /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
  2566. * mixer widget
  2567. * Note: PASD motherboards uses the Line In 2 as the input for front
  2568. * panel mic (mic 2)
  2569. */
  2570. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  2571. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  2572. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  2573. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  2574. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  2575. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  2576. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)},
  2577. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)},
  2578. /*
  2579. * Set up output mixers (0x0c - 0x0f)
  2580. */
  2581. /* set vol=0 to output mixers */
  2582. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  2583. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  2584. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  2585. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  2586. /* set up input amps for analog loopback */
  2587. /* Amp Indices: DAC = 0, mixer = 1 */
  2588. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  2589. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  2590. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  2591. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  2592. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  2593. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  2594. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  2595. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  2596. { }
  2597. };
  2598. /*
  2599. * 3-stack pin configuration:
  2600. * front = 0x14, mic/clfe = 0x18, HP = 0x19, line/surr = 0x1a, f-mic = 0x1b
  2601. */
  2602. static struct hda_verb alc880_pin_3stack_init_verbs[] = {
  2603. /*
  2604. * preset connection lists of input pins
  2605. * 0 = front, 1 = rear_surr, 2 = CLFE, 3 = surround
  2606. */
  2607. {0x10, AC_VERB_SET_CONNECT_SEL, 0x02}, /* mic/clfe */
  2608. {0x11, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  2609. {0x12, AC_VERB_SET_CONNECT_SEL, 0x03}, /* line/surround */
  2610. /*
  2611. * Set pin mode and muting
  2612. */
  2613. /* set front pin widgets 0x14 for output */
  2614. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2615. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2616. /* Mic1 (rear panel) pin widget for input and vref at 80% */
  2617. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2618. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2619. /* Mic2 (as headphone out) for HP output */
  2620. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2621. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2622. /* Line In pin widget for input */
  2623. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2624. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2625. /* Line2 (as front mic) pin widget for input and vref at 80% */
  2626. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2627. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2628. /* CD pin widget for input */
  2629. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2630. { }
  2631. };
  2632. /*
  2633. * 5-stack pin configuration:
  2634. * front = 0x14, surround = 0x17, clfe = 0x16, mic = 0x18, HP = 0x19,
  2635. * line-in/side = 0x1a, f-mic = 0x1b
  2636. */
  2637. static struct hda_verb alc880_pin_5stack_init_verbs[] = {
  2638. /*
  2639. * preset connection lists of input pins
  2640. * 0 = front, 1 = rear_surr, 2 = CLFE, 3 = surround
  2641. */
  2642. {0x11, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  2643. {0x12, AC_VERB_SET_CONNECT_SEL, 0x01}, /* line/side */
  2644. /*
  2645. * Set pin mode and muting
  2646. */
  2647. /* set pin widgets 0x14-0x17 for output */
  2648. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2649. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2650. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2651. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2652. /* unmute pins for output (no gain on this amp) */
  2653. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2654. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2655. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2656. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2657. /* Mic1 (rear panel) pin widget for input and vref at 80% */
  2658. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2659. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2660. /* Mic2 (as headphone out) for HP output */
  2661. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2662. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2663. /* Line In pin widget for input */
  2664. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2665. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2666. /* Line2 (as front mic) pin widget for input and vref at 80% */
  2667. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2668. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2669. /* CD pin widget for input */
  2670. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2671. { }
  2672. };
  2673. /*
  2674. * W810 pin configuration:
  2675. * front = 0x14, surround = 0x15, clfe = 0x16, HP = 0x1b
  2676. */
  2677. static struct hda_verb alc880_pin_w810_init_verbs[] = {
  2678. /* hphone/speaker input selector: front DAC */
  2679. {0x13, AC_VERB_SET_CONNECT_SEL, 0x0},
  2680. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2681. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2682. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2683. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2684. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2685. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2686. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2687. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2688. { }
  2689. };
  2690. /*
  2691. * Z71V pin configuration:
  2692. * Speaker-out = 0x14, HP = 0x15, Mic = 0x18, Line-in = 0x1a, Mic2 = 0x1b (?)
  2693. */
  2694. static struct hda_verb alc880_pin_z71v_init_verbs[] = {
  2695. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2696. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2697. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2698. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2699. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2700. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2701. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2702. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2703. { }
  2704. };
  2705. /*
  2706. * 6-stack pin configuration:
  2707. * front = 0x14, surr = 0x15, clfe = 0x16, side = 0x17, mic = 0x18,
  2708. * f-mic = 0x19, line = 0x1a, HP = 0x1b
  2709. */
  2710. static struct hda_verb alc880_pin_6stack_init_verbs[] = {
  2711. {0x13, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  2712. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2713. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2714. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2715. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2716. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2717. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2718. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2719. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2720. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2721. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2722. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2723. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2724. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2725. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2726. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2727. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2728. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2729. { }
  2730. };
  2731. /*
  2732. * Uniwill pin configuration:
  2733. * HP = 0x14, InternalSpeaker = 0x15, mic = 0x18, internal mic = 0x19,
  2734. * line = 0x1a
  2735. */
  2736. static struct hda_verb alc880_uniwill_init_verbs[] = {
  2737. {0x13, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  2738. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2739. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2740. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2741. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2742. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2743. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2744. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2745. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2746. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  2747. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  2748. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  2749. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  2750. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  2751. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  2752. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2753. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2754. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2755. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2756. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2757. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2758. /* {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, */
  2759. /* {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, */
  2760. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2761. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  2762. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  2763. { }
  2764. };
  2765. /*
  2766. * Uniwill P53
  2767. * HP = 0x14, InternalSpeaker = 0x15, mic = 0x19,
  2768. */
  2769. static struct hda_verb alc880_uniwill_p53_init_verbs[] = {
  2770. {0x13, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  2771. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2772. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2773. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2774. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2775. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2776. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2777. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  2778. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  2779. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  2780. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  2781. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  2782. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  2783. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2784. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2785. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2786. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2787. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2788. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2789. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  2790. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_DCVOL_EVENT},
  2791. { }
  2792. };
  2793. static struct hda_verb alc880_beep_init_verbs[] = {
  2794. { 0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(5) },
  2795. { }
  2796. };
  2797. /* auto-toggle front mic */
  2798. static void alc880_uniwill_mic_automute(struct hda_codec *codec)
  2799. {
  2800. unsigned int present;
  2801. unsigned char bits;
  2802. present = snd_hda_jack_detect(codec, 0x18);
  2803. bits = present ? HDA_AMP_MUTE : 0;
  2804. snd_hda_codec_amp_stereo(codec, 0x0b, HDA_INPUT, 1, HDA_AMP_MUTE, bits);
  2805. }
  2806. static void alc880_uniwill_setup(struct hda_codec *codec)
  2807. {
  2808. struct alc_spec *spec = codec->spec;
  2809. spec->autocfg.hp_pins[0] = 0x14;
  2810. spec->autocfg.speaker_pins[0] = 0x15;
  2811. spec->autocfg.speaker_pins[0] = 0x16;
  2812. }
  2813. static void alc880_uniwill_init_hook(struct hda_codec *codec)
  2814. {
  2815. alc_automute_amp(codec);
  2816. alc880_uniwill_mic_automute(codec);
  2817. }
  2818. static void alc880_uniwill_unsol_event(struct hda_codec *codec,
  2819. unsigned int res)
  2820. {
  2821. /* Looks like the unsol event is incompatible with the standard
  2822. * definition. 4bit tag is placed at 28 bit!
  2823. */
  2824. switch (res >> 28) {
  2825. case ALC880_MIC_EVENT:
  2826. alc880_uniwill_mic_automute(codec);
  2827. break;
  2828. default:
  2829. alc_automute_amp_unsol_event(codec, res);
  2830. break;
  2831. }
  2832. }
  2833. static void alc880_uniwill_p53_setup(struct hda_codec *codec)
  2834. {
  2835. struct alc_spec *spec = codec->spec;
  2836. spec->autocfg.hp_pins[0] = 0x14;
  2837. spec->autocfg.speaker_pins[0] = 0x15;
  2838. }
  2839. static void alc880_uniwill_p53_dcvol_automute(struct hda_codec *codec)
  2840. {
  2841. unsigned int present;
  2842. present = snd_hda_codec_read(codec, 0x21, 0,
  2843. AC_VERB_GET_VOLUME_KNOB_CONTROL, 0);
  2844. present &= HDA_AMP_VOLMASK;
  2845. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_OUTPUT, 0,
  2846. HDA_AMP_VOLMASK, present);
  2847. snd_hda_codec_amp_stereo(codec, 0x0d, HDA_OUTPUT, 0,
  2848. HDA_AMP_VOLMASK, present);
  2849. }
  2850. static void alc880_uniwill_p53_unsol_event(struct hda_codec *codec,
  2851. unsigned int res)
  2852. {
  2853. /* Looks like the unsol event is incompatible with the standard
  2854. * definition. 4bit tag is placed at 28 bit!
  2855. */
  2856. if ((res >> 28) == ALC880_DCVOL_EVENT)
  2857. alc880_uniwill_p53_dcvol_automute(codec);
  2858. else
  2859. alc_automute_amp_unsol_event(codec, res);
  2860. }
  2861. /*
  2862. * F1734 pin configuration:
  2863. * HP = 0x14, speaker-out = 0x15, mic = 0x18
  2864. */
  2865. static struct hda_verb alc880_pin_f1734_init_verbs[] = {
  2866. {0x07, AC_VERB_SET_CONNECT_SEL, 0x01},
  2867. {0x10, AC_VERB_SET_CONNECT_SEL, 0x02},
  2868. {0x11, AC_VERB_SET_CONNECT_SEL, 0x00},
  2869. {0x12, AC_VERB_SET_CONNECT_SEL, 0x01},
  2870. {0x13, AC_VERB_SET_CONNECT_SEL, 0x00},
  2871. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2872. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2873. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2874. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2875. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2876. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2877. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
  2878. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2879. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2880. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2881. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2882. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2883. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2884. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_HP_EVENT},
  2885. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_DCVOL_EVENT},
  2886. { }
  2887. };
  2888. /*
  2889. * ASUS pin configuration:
  2890. * HP/front = 0x14, surr = 0x15, clfe = 0x16, mic = 0x18, line = 0x1a
  2891. */
  2892. static struct hda_verb alc880_pin_asus_init_verbs[] = {
  2893. {0x10, AC_VERB_SET_CONNECT_SEL, 0x02},
  2894. {0x11, AC_VERB_SET_CONNECT_SEL, 0x00},
  2895. {0x12, AC_VERB_SET_CONNECT_SEL, 0x01},
  2896. {0x13, AC_VERB_SET_CONNECT_SEL, 0x00},
  2897. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2898. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2899. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2900. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2901. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2902. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2903. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2904. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2905. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2906. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2907. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2908. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2909. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2910. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  2911. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2912. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2913. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2914. { }
  2915. };
  2916. /* Enable GPIO mask and set output */
  2917. #define alc880_gpio1_init_verbs alc_gpio1_init_verbs
  2918. #define alc880_gpio2_init_verbs alc_gpio2_init_verbs
  2919. #define alc880_gpio3_init_verbs alc_gpio3_init_verbs
  2920. /* Clevo m520g init */
  2921. static struct hda_verb alc880_pin_clevo_init_verbs[] = {
  2922. /* headphone output */
  2923. {0x11, AC_VERB_SET_CONNECT_SEL, 0x01},
  2924. /* line-out */
  2925. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2926. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2927. /* Line-in */
  2928. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2929. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2930. /* CD */
  2931. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2932. {0x1c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2933. /* Mic1 (rear panel) */
  2934. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2935. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2936. /* Mic2 (front panel) */
  2937. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2938. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2939. /* headphone */
  2940. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2941. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  2942. /* change to EAPD mode */
  2943. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  2944. {0x20, AC_VERB_SET_PROC_COEF, 0x3060},
  2945. { }
  2946. };
  2947. static struct hda_verb alc880_pin_tcl_S700_init_verbs[] = {
  2948. /* change to EAPD mode */
  2949. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  2950. {0x20, AC_VERB_SET_PROC_COEF, 0x3060},
  2951. /* Headphone output */
  2952. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  2953. /* Front output*/
  2954. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  2955. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  2956. /* Line In pin widget for input */
  2957. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2958. /* CD pin widget for input */
  2959. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  2960. /* Mic1 (rear panel) pin widget for input and vref at 80% */
  2961. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  2962. /* change to EAPD mode */
  2963. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  2964. {0x20, AC_VERB_SET_PROC_COEF, 0x3070},
  2965. { }
  2966. };
  2967. /*
  2968. * LG m1 express dual
  2969. *
  2970. * Pin assignment:
  2971. * Rear Line-In/Out (blue): 0x14
  2972. * Build-in Mic-In: 0x15
  2973. * Speaker-out: 0x17
  2974. * HP-Out (green): 0x1b
  2975. * Mic-In/Out (red): 0x19
  2976. * SPDIF-Out: 0x1e
  2977. */
  2978. /* To make 5.1 output working (green=Front, blue=Surr, red=CLFE) */
  2979. static hda_nid_t alc880_lg_dac_nids[3] = {
  2980. 0x05, 0x02, 0x03
  2981. };
  2982. /* seems analog CD is not working */
  2983. static struct hda_input_mux alc880_lg_capture_source = {
  2984. .num_items = 3,
  2985. .items = {
  2986. { "Mic", 0x1 },
  2987. { "Line", 0x5 },
  2988. { "Internal Mic", 0x6 },
  2989. },
  2990. };
  2991. /* 2,4,6 channel modes */
  2992. static struct hda_verb alc880_lg_ch2_init[] = {
  2993. /* set line-in and mic-in to input */
  2994. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  2995. { 0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  2996. { }
  2997. };
  2998. static struct hda_verb alc880_lg_ch4_init[] = {
  2999. /* set line-in to out and mic-in to input */
  3000. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP },
  3001. { 0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  3002. { }
  3003. };
  3004. static struct hda_verb alc880_lg_ch6_init[] = {
  3005. /* set line-in and mic-in to output */
  3006. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP },
  3007. { 0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP },
  3008. { }
  3009. };
  3010. static struct hda_channel_mode alc880_lg_ch_modes[3] = {
  3011. { 2, alc880_lg_ch2_init },
  3012. { 4, alc880_lg_ch4_init },
  3013. { 6, alc880_lg_ch6_init },
  3014. };
  3015. static struct snd_kcontrol_new alc880_lg_mixer[] = {
  3016. HDA_CODEC_VOLUME("Front Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  3017. HDA_BIND_MUTE("Front Playback Switch", 0x0f, 2, HDA_INPUT),
  3018. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  3019. HDA_BIND_MUTE("Surround Playback Switch", 0x0c, 2, HDA_INPUT),
  3020. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0d, 1, 0x0, HDA_OUTPUT),
  3021. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0d, 2, 0x0, HDA_OUTPUT),
  3022. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0d, 1, 2, HDA_INPUT),
  3023. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0d, 2, 2, HDA_INPUT),
  3024. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  3025. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  3026. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x06, HDA_INPUT),
  3027. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x06, HDA_INPUT),
  3028. HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x07, HDA_INPUT),
  3029. HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x07, HDA_INPUT),
  3030. {
  3031. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  3032. .name = "Channel Mode",
  3033. .info = alc_ch_mode_info,
  3034. .get = alc_ch_mode_get,
  3035. .put = alc_ch_mode_put,
  3036. },
  3037. { } /* end */
  3038. };
  3039. static struct hda_verb alc880_lg_init_verbs[] = {
  3040. /* set capture source to mic-in */
  3041. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  3042. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  3043. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  3044. /* mute all amp mixer inputs */
  3045. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(5)},
  3046. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)},
  3047. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)},
  3048. /* line-in to input */
  3049. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  3050. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3051. /* built-in mic */
  3052. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  3053. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3054. /* speaker-out */
  3055. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  3056. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3057. /* mic-in to input */
  3058. {0x11, AC_VERB_SET_CONNECT_SEL, 0x01},
  3059. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  3060. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3061. /* HP-out */
  3062. {0x13, AC_VERB_SET_CONNECT_SEL, 0x03},
  3063. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  3064. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3065. /* jack sense */
  3066. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  3067. { }
  3068. };
  3069. /* toggle speaker-output according to the hp-jack state */
  3070. static void alc880_lg_setup(struct hda_codec *codec)
  3071. {
  3072. struct alc_spec *spec = codec->spec;
  3073. spec->autocfg.hp_pins[0] = 0x1b;
  3074. spec->autocfg.speaker_pins[0] = 0x17;
  3075. }
  3076. /*
  3077. * LG LW20
  3078. *
  3079. * Pin assignment:
  3080. * Speaker-out: 0x14
  3081. * Mic-In: 0x18
  3082. * Built-in Mic-In: 0x19
  3083. * Line-In: 0x1b
  3084. * HP-Out: 0x1a
  3085. * SPDIF-Out: 0x1e
  3086. */
  3087. static struct hda_input_mux alc880_lg_lw_capture_source = {
  3088. .num_items = 3,
  3089. .items = {
  3090. { "Mic", 0x0 },
  3091. { "Internal Mic", 0x1 },
  3092. { "Line In", 0x2 },
  3093. },
  3094. };
  3095. #define alc880_lg_lw_modes alc880_threestack_modes
  3096. static struct snd_kcontrol_new alc880_lg_lw_mixer[] = {
  3097. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  3098. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  3099. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  3100. HDA_BIND_MUTE("Surround Playback Switch", 0x0f, 2, HDA_INPUT),
  3101. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  3102. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  3103. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  3104. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  3105. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  3106. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  3107. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  3108. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  3109. HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  3110. HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  3111. {
  3112. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  3113. .name = "Channel Mode",
  3114. .info = alc_ch_mode_info,
  3115. .get = alc_ch_mode_get,
  3116. .put = alc_ch_mode_put,
  3117. },
  3118. { } /* end */
  3119. };
  3120. static struct hda_verb alc880_lg_lw_init_verbs[] = {
  3121. {0x13, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  3122. {0x10, AC_VERB_SET_CONNECT_SEL, 0x02}, /* mic/clfe */
  3123. {0x12, AC_VERB_SET_CONNECT_SEL, 0x03}, /* line/surround */
  3124. /* set capture source to mic-in */
  3125. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  3126. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  3127. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  3128. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)},
  3129. /* speaker-out */
  3130. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  3131. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3132. /* HP-out */
  3133. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  3134. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3135. /* mic-in to input */
  3136. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  3137. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3138. /* built-in mic */
  3139. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  3140. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3141. /* jack sense */
  3142. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  3143. { }
  3144. };
  3145. /* toggle speaker-output according to the hp-jack state */
  3146. static void alc880_lg_lw_setup(struct hda_codec *codec)
  3147. {
  3148. struct alc_spec *spec = codec->spec;
  3149. spec->autocfg.hp_pins[0] = 0x1b;
  3150. spec->autocfg.speaker_pins[0] = 0x14;
  3151. }
  3152. static struct snd_kcontrol_new alc880_medion_rim_mixer[] = {
  3153. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  3154. HDA_BIND_MUTE("Master Playback Switch", 0x0c, 2, HDA_INPUT),
  3155. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  3156. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  3157. HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  3158. HDA_CODEC_MUTE("Internal Playback Switch", 0x0b, 0x1, HDA_INPUT),
  3159. { } /* end */
  3160. };
  3161. static struct hda_input_mux alc880_medion_rim_capture_source = {
  3162. .num_items = 2,
  3163. .items = {
  3164. { "Mic", 0x0 },
  3165. { "Internal Mic", 0x1 },
  3166. },
  3167. };
  3168. static struct hda_verb alc880_medion_rim_init_verbs[] = {
  3169. {0x13, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  3170. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  3171. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3172. /* Mic1 (rear panel) pin widget for input and vref at 80% */
  3173. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  3174. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  3175. /* Mic2 (as headphone out) for HP output */
  3176. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  3177. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  3178. /* Internal Speaker */
  3179. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  3180. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3181. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  3182. {0x20, AC_VERB_SET_PROC_COEF, 0x3060},
  3183. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  3184. { }
  3185. };
  3186. /* toggle speaker-output according to the hp-jack state */
  3187. static void alc880_medion_rim_automute(struct hda_codec *codec)
  3188. {
  3189. struct alc_spec *spec = codec->spec;
  3190. alc_automute_amp(codec);
  3191. /* toggle EAPD */
  3192. if (spec->jack_present)
  3193. snd_hda_codec_write(codec, 0x01, 0, AC_VERB_SET_GPIO_DATA, 0);
  3194. else
  3195. snd_hda_codec_write(codec, 0x01, 0, AC_VERB_SET_GPIO_DATA, 2);
  3196. }
  3197. static void alc880_medion_rim_unsol_event(struct hda_codec *codec,
  3198. unsigned int res)
  3199. {
  3200. /* Looks like the unsol event is incompatible with the standard
  3201. * definition. 4bit tag is placed at 28 bit!
  3202. */
  3203. if ((res >> 28) == ALC880_HP_EVENT)
  3204. alc880_medion_rim_automute(codec);
  3205. }
  3206. static void alc880_medion_rim_setup(struct hda_codec *codec)
  3207. {
  3208. struct alc_spec *spec = codec->spec;
  3209. spec->autocfg.hp_pins[0] = 0x14;
  3210. spec->autocfg.speaker_pins[0] = 0x1b;
  3211. }
  3212. #ifdef CONFIG_SND_HDA_POWER_SAVE
  3213. static struct hda_amp_list alc880_loopbacks[] = {
  3214. { 0x0b, HDA_INPUT, 0 },
  3215. { 0x0b, HDA_INPUT, 1 },
  3216. { 0x0b, HDA_INPUT, 2 },
  3217. { 0x0b, HDA_INPUT, 3 },
  3218. { 0x0b, HDA_INPUT, 4 },
  3219. { } /* end */
  3220. };
  3221. static struct hda_amp_list alc880_lg_loopbacks[] = {
  3222. { 0x0b, HDA_INPUT, 1 },
  3223. { 0x0b, HDA_INPUT, 6 },
  3224. { 0x0b, HDA_INPUT, 7 },
  3225. { } /* end */
  3226. };
  3227. #endif
  3228. /*
  3229. * Common callbacks
  3230. */
  3231. static int alc_init(struct hda_codec *codec)
  3232. {
  3233. struct alc_spec *spec = codec->spec;
  3234. unsigned int i;
  3235. alc_fix_pll(codec);
  3236. alc_auto_init_amp(codec, spec->init_amp);
  3237. for (i = 0; i < spec->num_init_verbs; i++)
  3238. snd_hda_sequence_write(codec, spec->init_verbs[i]);
  3239. if (spec->init_hook)
  3240. spec->init_hook(codec);
  3241. #ifdef CONFIG_SND_HDA_POWER_SAVE
  3242. if (codec->patch_ops.check_power_status)
  3243. codec->patch_ops.check_power_status(codec, 0x01);
  3244. #endif
  3245. return 0;
  3246. }
  3247. static void alc_unsol_event(struct hda_codec *codec, unsigned int res)
  3248. {
  3249. struct alc_spec *spec = codec->spec;
  3250. if (spec->unsol_event)
  3251. spec->unsol_event(codec, res);
  3252. }
  3253. #ifdef CONFIG_SND_HDA_POWER_SAVE
  3254. static int alc_check_power_status(struct hda_codec *codec, hda_nid_t nid)
  3255. {
  3256. struct alc_spec *spec = codec->spec;
  3257. return snd_hda_check_amp_list_power(codec, &spec->loopback, nid);
  3258. }
  3259. #endif
  3260. /*
  3261. * Analog playback callbacks
  3262. */
  3263. static int alc880_playback_pcm_open(struct hda_pcm_stream *hinfo,
  3264. struct hda_codec *codec,
  3265. struct snd_pcm_substream *substream)
  3266. {
  3267. struct alc_spec *spec = codec->spec;
  3268. return snd_hda_multi_out_analog_open(codec, &spec->multiout, substream,
  3269. hinfo);
  3270. }
  3271. static int alc880_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
  3272. struct hda_codec *codec,
  3273. unsigned int stream_tag,
  3274. unsigned int format,
  3275. struct snd_pcm_substream *substream)
  3276. {
  3277. struct alc_spec *spec = codec->spec;
  3278. return snd_hda_multi_out_analog_prepare(codec, &spec->multiout,
  3279. stream_tag, format, substream);
  3280. }
  3281. static int alc880_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
  3282. struct hda_codec *codec,
  3283. struct snd_pcm_substream *substream)
  3284. {
  3285. struct alc_spec *spec = codec->spec;
  3286. return snd_hda_multi_out_analog_cleanup(codec, &spec->multiout);
  3287. }
  3288. /*
  3289. * Digital out
  3290. */
  3291. static int alc880_dig_playback_pcm_open(struct hda_pcm_stream *hinfo,
  3292. struct hda_codec *codec,
  3293. struct snd_pcm_substream *substream)
  3294. {
  3295. struct alc_spec *spec = codec->spec;
  3296. return snd_hda_multi_out_dig_open(codec, &spec->multiout);
  3297. }
  3298. static int alc880_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
  3299. struct hda_codec *codec,
  3300. unsigned int stream_tag,
  3301. unsigned int format,
  3302. struct snd_pcm_substream *substream)
  3303. {
  3304. struct alc_spec *spec = codec->spec;
  3305. return snd_hda_multi_out_dig_prepare(codec, &spec->multiout,
  3306. stream_tag, format, substream);
  3307. }
  3308. static int alc880_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
  3309. struct hda_codec *codec,
  3310. struct snd_pcm_substream *substream)
  3311. {
  3312. struct alc_spec *spec = codec->spec;
  3313. return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout);
  3314. }
  3315. static int alc880_dig_playback_pcm_close(struct hda_pcm_stream *hinfo,
  3316. struct hda_codec *codec,
  3317. struct snd_pcm_substream *substream)
  3318. {
  3319. struct alc_spec *spec = codec->spec;
  3320. return snd_hda_multi_out_dig_close(codec, &spec->multiout);
  3321. }
  3322. /*
  3323. * Analog capture
  3324. */
  3325. static int alc880_alt_capture_pcm_prepare(struct hda_pcm_stream *hinfo,
  3326. struct hda_codec *codec,
  3327. unsigned int stream_tag,
  3328. unsigned int format,
  3329. struct snd_pcm_substream *substream)
  3330. {
  3331. struct alc_spec *spec = codec->spec;
  3332. snd_hda_codec_setup_stream(codec, spec->adc_nids[substream->number + 1],
  3333. stream_tag, 0, format);
  3334. return 0;
  3335. }
  3336. static int alc880_alt_capture_pcm_cleanup(struct hda_pcm_stream *hinfo,
  3337. struct hda_codec *codec,
  3338. struct snd_pcm_substream *substream)
  3339. {
  3340. struct alc_spec *spec = codec->spec;
  3341. snd_hda_codec_cleanup_stream(codec,
  3342. spec->adc_nids[substream->number + 1]);
  3343. return 0;
  3344. }
  3345. /* analog capture with dynamic dual-adc changes */
  3346. static int dualmic_capture_pcm_prepare(struct hda_pcm_stream *hinfo,
  3347. struct hda_codec *codec,
  3348. unsigned int stream_tag,
  3349. unsigned int format,
  3350. struct snd_pcm_substream *substream)
  3351. {
  3352. struct alc_spec *spec = codec->spec;
  3353. spec->cur_adc = spec->adc_nids[spec->cur_adc_idx];
  3354. spec->cur_adc_stream_tag = stream_tag;
  3355. spec->cur_adc_format = format;
  3356. snd_hda_codec_setup_stream(codec, spec->cur_adc, stream_tag, 0, format);
  3357. return 0;
  3358. }
  3359. static int dualmic_capture_pcm_cleanup(struct hda_pcm_stream *hinfo,
  3360. struct hda_codec *codec,
  3361. struct snd_pcm_substream *substream)
  3362. {
  3363. struct alc_spec *spec = codec->spec;
  3364. snd_hda_codec_cleanup_stream(codec, spec->cur_adc);
  3365. spec->cur_adc = 0;
  3366. return 0;
  3367. }
  3368. static struct hda_pcm_stream dualmic_pcm_analog_capture = {
  3369. .substreams = 1,
  3370. .channels_min = 2,
  3371. .channels_max = 2,
  3372. .nid = 0, /* fill later */
  3373. .ops = {
  3374. .prepare = dualmic_capture_pcm_prepare,
  3375. .cleanup = dualmic_capture_pcm_cleanup
  3376. },
  3377. };
  3378. /*
  3379. */
  3380. static struct hda_pcm_stream alc880_pcm_analog_playback = {
  3381. .substreams = 1,
  3382. .channels_min = 2,
  3383. .channels_max = 8,
  3384. /* NID is set in alc_build_pcms */
  3385. .ops = {
  3386. .open = alc880_playback_pcm_open,
  3387. .prepare = alc880_playback_pcm_prepare,
  3388. .cleanup = alc880_playback_pcm_cleanup
  3389. },
  3390. };
  3391. static struct hda_pcm_stream alc880_pcm_analog_capture = {
  3392. .substreams = 1,
  3393. .channels_min = 2,
  3394. .channels_max = 2,
  3395. /* NID is set in alc_build_pcms */
  3396. };
  3397. static struct hda_pcm_stream alc880_pcm_analog_alt_playback = {
  3398. .substreams = 1,
  3399. .channels_min = 2,
  3400. .channels_max = 2,
  3401. /* NID is set in alc_build_pcms */
  3402. };
  3403. static struct hda_pcm_stream alc880_pcm_analog_alt_capture = {
  3404. .substreams = 2, /* can be overridden */
  3405. .channels_min = 2,
  3406. .channels_max = 2,
  3407. /* NID is set in alc_build_pcms */
  3408. .ops = {
  3409. .prepare = alc880_alt_capture_pcm_prepare,
  3410. .cleanup = alc880_alt_capture_pcm_cleanup
  3411. },
  3412. };
  3413. static struct hda_pcm_stream alc880_pcm_digital_playback = {
  3414. .substreams = 1,
  3415. .channels_min = 2,
  3416. .channels_max = 2,
  3417. /* NID is set in alc_build_pcms */
  3418. .ops = {
  3419. .open = alc880_dig_playback_pcm_open,
  3420. .close = alc880_dig_playback_pcm_close,
  3421. .prepare = alc880_dig_playback_pcm_prepare,
  3422. .cleanup = alc880_dig_playback_pcm_cleanup
  3423. },
  3424. };
  3425. static struct hda_pcm_stream alc880_pcm_digital_capture = {
  3426. .substreams = 1,
  3427. .channels_min = 2,
  3428. .channels_max = 2,
  3429. /* NID is set in alc_build_pcms */
  3430. };
  3431. /* Used by alc_build_pcms to flag that a PCM has no playback stream */
  3432. static struct hda_pcm_stream alc_pcm_null_stream = {
  3433. .substreams = 0,
  3434. .channels_min = 0,
  3435. .channels_max = 0,
  3436. };
  3437. static int alc_build_pcms(struct hda_codec *codec)
  3438. {
  3439. struct alc_spec *spec = codec->spec;
  3440. struct hda_pcm *info = spec->pcm_rec;
  3441. int i;
  3442. codec->num_pcms = 1;
  3443. codec->pcm_info = info;
  3444. if (spec->no_analog)
  3445. goto skip_analog;
  3446. snprintf(spec->stream_name_analog, sizeof(spec->stream_name_analog),
  3447. "%s Analog", codec->chip_name);
  3448. info->name = spec->stream_name_analog;
  3449. if (spec->stream_analog_playback) {
  3450. if (snd_BUG_ON(!spec->multiout.dac_nids))
  3451. return -EINVAL;
  3452. info->stream[SNDRV_PCM_STREAM_PLAYBACK] = *(spec->stream_analog_playback);
  3453. info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->multiout.dac_nids[0];
  3454. }
  3455. if (spec->stream_analog_capture) {
  3456. if (snd_BUG_ON(!spec->adc_nids))
  3457. return -EINVAL;
  3458. info->stream[SNDRV_PCM_STREAM_CAPTURE] = *(spec->stream_analog_capture);
  3459. info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adc_nids[0];
  3460. }
  3461. if (spec->channel_mode) {
  3462. info->stream[SNDRV_PCM_STREAM_PLAYBACK].channels_max = 0;
  3463. for (i = 0; i < spec->num_channel_mode; i++) {
  3464. if (spec->channel_mode[i].channels > info->stream[SNDRV_PCM_STREAM_PLAYBACK].channels_max) {
  3465. info->stream[SNDRV_PCM_STREAM_PLAYBACK].channels_max = spec->channel_mode[i].channels;
  3466. }
  3467. }
  3468. }
  3469. skip_analog:
  3470. /* SPDIF for stream index #1 */
  3471. if (spec->multiout.dig_out_nid || spec->dig_in_nid) {
  3472. snprintf(spec->stream_name_digital,
  3473. sizeof(spec->stream_name_digital),
  3474. "%s Digital", codec->chip_name);
  3475. codec->num_pcms = 2;
  3476. codec->slave_dig_outs = spec->multiout.slave_dig_outs;
  3477. info = spec->pcm_rec + 1;
  3478. info->name = spec->stream_name_digital;
  3479. if (spec->dig_out_type)
  3480. info->pcm_type = spec->dig_out_type;
  3481. else
  3482. info->pcm_type = HDA_PCM_TYPE_SPDIF;
  3483. if (spec->multiout.dig_out_nid &&
  3484. spec->stream_digital_playback) {
  3485. info->stream[SNDRV_PCM_STREAM_PLAYBACK] = *(spec->stream_digital_playback);
  3486. info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->multiout.dig_out_nid;
  3487. }
  3488. if (spec->dig_in_nid &&
  3489. spec->stream_digital_capture) {
  3490. info->stream[SNDRV_PCM_STREAM_CAPTURE] = *(spec->stream_digital_capture);
  3491. info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in_nid;
  3492. }
  3493. /* FIXME: do we need this for all Realtek codec models? */
  3494. codec->spdif_status_reset = 1;
  3495. }
  3496. if (spec->no_analog)
  3497. return 0;
  3498. /* If the use of more than one ADC is requested for the current
  3499. * model, configure a second analog capture-only PCM.
  3500. */
  3501. /* Additional Analaog capture for index #2 */
  3502. if ((spec->alt_dac_nid && spec->stream_analog_alt_playback) ||
  3503. (spec->num_adc_nids > 1 && spec->stream_analog_alt_capture)) {
  3504. codec->num_pcms = 3;
  3505. info = spec->pcm_rec + 2;
  3506. info->name = spec->stream_name_analog;
  3507. if (spec->alt_dac_nid) {
  3508. info->stream[SNDRV_PCM_STREAM_PLAYBACK] =
  3509. *spec->stream_analog_alt_playback;
  3510. info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid =
  3511. spec->alt_dac_nid;
  3512. } else {
  3513. info->stream[SNDRV_PCM_STREAM_PLAYBACK] =
  3514. alc_pcm_null_stream;
  3515. info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = 0;
  3516. }
  3517. if (spec->num_adc_nids > 1) {
  3518. info->stream[SNDRV_PCM_STREAM_CAPTURE] =
  3519. *spec->stream_analog_alt_capture;
  3520. info->stream[SNDRV_PCM_STREAM_CAPTURE].nid =
  3521. spec->adc_nids[1];
  3522. info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams =
  3523. spec->num_adc_nids - 1;
  3524. } else {
  3525. info->stream[SNDRV_PCM_STREAM_CAPTURE] =
  3526. alc_pcm_null_stream;
  3527. info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = 0;
  3528. }
  3529. }
  3530. return 0;
  3531. }
  3532. static inline void alc_shutup(struct hda_codec *codec)
  3533. {
  3534. snd_hda_shutup_pins(codec);
  3535. }
  3536. static void alc_free_kctls(struct hda_codec *codec)
  3537. {
  3538. struct alc_spec *spec = codec->spec;
  3539. if (spec->kctls.list) {
  3540. struct snd_kcontrol_new *kctl = spec->kctls.list;
  3541. int i;
  3542. for (i = 0; i < spec->kctls.used; i++)
  3543. kfree(kctl[i].name);
  3544. }
  3545. snd_array_free(&spec->kctls);
  3546. }
  3547. static void alc_free(struct hda_codec *codec)
  3548. {
  3549. struct alc_spec *spec = codec->spec;
  3550. if (!spec)
  3551. return;
  3552. alc_shutup(codec);
  3553. alc_free_kctls(codec);
  3554. kfree(spec);
  3555. snd_hda_detach_beep_device(codec);
  3556. }
  3557. #ifdef CONFIG_SND_HDA_POWER_SAVE
  3558. static void alc_power_eapd(struct hda_codec *codec)
  3559. {
  3560. /* We currently only handle front, HP */
  3561. switch (codec->vendor_id) {
  3562. case 0x10ec0260:
  3563. set_eapd(codec, 0x0f, 0);
  3564. set_eapd(codec, 0x10, 0);
  3565. break;
  3566. case 0x10ec0262:
  3567. case 0x10ec0267:
  3568. case 0x10ec0268:
  3569. case 0x10ec0269:
  3570. case 0x10ec0270:
  3571. case 0x10ec0272:
  3572. case 0x10ec0660:
  3573. case 0x10ec0662:
  3574. case 0x10ec0663:
  3575. case 0x10ec0862:
  3576. case 0x10ec0889:
  3577. set_eapd(codec, 0x14, 0);
  3578. set_eapd(codec, 0x15, 0);
  3579. break;
  3580. }
  3581. }
  3582. static int alc_suspend(struct hda_codec *codec, pm_message_t state)
  3583. {
  3584. struct alc_spec *spec = codec->spec;
  3585. alc_shutup(codec);
  3586. if (spec && spec->power_hook)
  3587. spec->power_hook(codec);
  3588. return 0;
  3589. }
  3590. #endif
  3591. #ifdef SND_HDA_NEEDS_RESUME
  3592. static int alc_resume(struct hda_codec *codec)
  3593. {
  3594. codec->patch_ops.init(codec);
  3595. snd_hda_codec_resume_amp(codec);
  3596. snd_hda_codec_resume_cache(codec);
  3597. #ifdef CONFIG_SND_HDA_POWER_SAVE
  3598. if (codec->patch_ops.check_power_status)
  3599. codec->patch_ops.check_power_status(codec, 0x01);
  3600. #endif
  3601. return 0;
  3602. }
  3603. #endif
  3604. /*
  3605. */
  3606. static struct hda_codec_ops alc_patch_ops = {
  3607. .build_controls = alc_build_controls,
  3608. .build_pcms = alc_build_pcms,
  3609. .init = alc_init,
  3610. .free = alc_free,
  3611. .unsol_event = alc_unsol_event,
  3612. #ifdef SND_HDA_NEEDS_RESUME
  3613. .resume = alc_resume,
  3614. #endif
  3615. #ifdef CONFIG_SND_HDA_POWER_SAVE
  3616. .suspend = alc_suspend,
  3617. .check_power_status = alc_check_power_status,
  3618. #endif
  3619. .reboot_notify = alc_shutup,
  3620. };
  3621. /* replace the codec chip_name with the given string */
  3622. static int alc_codec_rename(struct hda_codec *codec, const char *name)
  3623. {
  3624. kfree(codec->chip_name);
  3625. codec->chip_name = kstrdup(name, GFP_KERNEL);
  3626. if (!codec->chip_name) {
  3627. alc_free(codec);
  3628. return -ENOMEM;
  3629. }
  3630. return 0;
  3631. }
  3632. /*
  3633. * Test configuration for debugging
  3634. *
  3635. * Almost all inputs/outputs are enabled. I/O pins can be configured via
  3636. * enum controls.
  3637. */
  3638. #ifdef CONFIG_SND_DEBUG
  3639. static hda_nid_t alc880_test_dac_nids[4] = {
  3640. 0x02, 0x03, 0x04, 0x05
  3641. };
  3642. static struct hda_input_mux alc880_test_capture_source = {
  3643. .num_items = 7,
  3644. .items = {
  3645. { "In-1", 0x0 },
  3646. { "In-2", 0x1 },
  3647. { "In-3", 0x2 },
  3648. { "In-4", 0x3 },
  3649. { "CD", 0x4 },
  3650. { "Front", 0x5 },
  3651. { "Surround", 0x6 },
  3652. },
  3653. };
  3654. static struct hda_channel_mode alc880_test_modes[4] = {
  3655. { 2, NULL },
  3656. { 4, NULL },
  3657. { 6, NULL },
  3658. { 8, NULL },
  3659. };
  3660. static int alc_test_pin_ctl_info(struct snd_kcontrol *kcontrol,
  3661. struct snd_ctl_elem_info *uinfo)
  3662. {
  3663. static char *texts[] = {
  3664. "N/A", "Line Out", "HP Out",
  3665. "In Hi-Z", "In 50%", "In Grd", "In 80%", "In 100%"
  3666. };
  3667. uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
  3668. uinfo->count = 1;
  3669. uinfo->value.enumerated.items = 8;
  3670. if (uinfo->value.enumerated.item >= 8)
  3671. uinfo->value.enumerated.item = 7;
  3672. strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
  3673. return 0;
  3674. }
  3675. static int alc_test_pin_ctl_get(struct snd_kcontrol *kcontrol,
  3676. struct snd_ctl_elem_value *ucontrol)
  3677. {
  3678. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  3679. hda_nid_t nid = (hda_nid_t)kcontrol->private_value;
  3680. unsigned int pin_ctl, item = 0;
  3681. pin_ctl = snd_hda_codec_read(codec, nid, 0,
  3682. AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
  3683. if (pin_ctl & AC_PINCTL_OUT_EN) {
  3684. if (pin_ctl & AC_PINCTL_HP_EN)
  3685. item = 2;
  3686. else
  3687. item = 1;
  3688. } else if (pin_ctl & AC_PINCTL_IN_EN) {
  3689. switch (pin_ctl & AC_PINCTL_VREFEN) {
  3690. case AC_PINCTL_VREF_HIZ: item = 3; break;
  3691. case AC_PINCTL_VREF_50: item = 4; break;
  3692. case AC_PINCTL_VREF_GRD: item = 5; break;
  3693. case AC_PINCTL_VREF_80: item = 6; break;
  3694. case AC_PINCTL_VREF_100: item = 7; break;
  3695. }
  3696. }
  3697. ucontrol->value.enumerated.item[0] = item;
  3698. return 0;
  3699. }
  3700. static int alc_test_pin_ctl_put(struct snd_kcontrol *kcontrol,
  3701. struct snd_ctl_elem_value *ucontrol)
  3702. {
  3703. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  3704. hda_nid_t nid = (hda_nid_t)kcontrol->private_value;
  3705. static unsigned int ctls[] = {
  3706. 0, AC_PINCTL_OUT_EN, AC_PINCTL_OUT_EN | AC_PINCTL_HP_EN,
  3707. AC_PINCTL_IN_EN | AC_PINCTL_VREF_HIZ,
  3708. AC_PINCTL_IN_EN | AC_PINCTL_VREF_50,
  3709. AC_PINCTL_IN_EN | AC_PINCTL_VREF_GRD,
  3710. AC_PINCTL_IN_EN | AC_PINCTL_VREF_80,
  3711. AC_PINCTL_IN_EN | AC_PINCTL_VREF_100,
  3712. };
  3713. unsigned int old_ctl, new_ctl;
  3714. old_ctl = snd_hda_codec_read(codec, nid, 0,
  3715. AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
  3716. new_ctl = ctls[ucontrol->value.enumerated.item[0]];
  3717. if (old_ctl != new_ctl) {
  3718. int val;
  3719. snd_hda_codec_write_cache(codec, nid, 0,
  3720. AC_VERB_SET_PIN_WIDGET_CONTROL,
  3721. new_ctl);
  3722. val = ucontrol->value.enumerated.item[0] >= 3 ?
  3723. HDA_AMP_MUTE : 0;
  3724. snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0,
  3725. HDA_AMP_MUTE, val);
  3726. return 1;
  3727. }
  3728. return 0;
  3729. }
  3730. static int alc_test_pin_src_info(struct snd_kcontrol *kcontrol,
  3731. struct snd_ctl_elem_info *uinfo)
  3732. {
  3733. static char *texts[] = {
  3734. "Front", "Surround", "CLFE", "Side"
  3735. };
  3736. uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
  3737. uinfo->count = 1;
  3738. uinfo->value.enumerated.items = 4;
  3739. if (uinfo->value.enumerated.item >= 4)
  3740. uinfo->value.enumerated.item = 3;
  3741. strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);
  3742. return 0;
  3743. }
  3744. static int alc_test_pin_src_get(struct snd_kcontrol *kcontrol,
  3745. struct snd_ctl_elem_value *ucontrol)
  3746. {
  3747. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  3748. hda_nid_t nid = (hda_nid_t)kcontrol->private_value;
  3749. unsigned int sel;
  3750. sel = snd_hda_codec_read(codec, nid, 0, AC_VERB_GET_CONNECT_SEL, 0);
  3751. ucontrol->value.enumerated.item[0] = sel & 3;
  3752. return 0;
  3753. }
  3754. static int alc_test_pin_src_put(struct snd_kcontrol *kcontrol,
  3755. struct snd_ctl_elem_value *ucontrol)
  3756. {
  3757. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  3758. hda_nid_t nid = (hda_nid_t)kcontrol->private_value;
  3759. unsigned int sel;
  3760. sel = snd_hda_codec_read(codec, nid, 0, AC_VERB_GET_CONNECT_SEL, 0) & 3;
  3761. if (ucontrol->value.enumerated.item[0] != sel) {
  3762. sel = ucontrol->value.enumerated.item[0] & 3;
  3763. snd_hda_codec_write_cache(codec, nid, 0,
  3764. AC_VERB_SET_CONNECT_SEL, sel);
  3765. return 1;
  3766. }
  3767. return 0;
  3768. }
  3769. #define PIN_CTL_TEST(xname,nid) { \
  3770. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  3771. .name = xname, \
  3772. .subdevice = HDA_SUBDEV_NID_FLAG | nid, \
  3773. .info = alc_test_pin_ctl_info, \
  3774. .get = alc_test_pin_ctl_get, \
  3775. .put = alc_test_pin_ctl_put, \
  3776. .private_value = nid \
  3777. }
  3778. #define PIN_SRC_TEST(xname,nid) { \
  3779. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  3780. .name = xname, \
  3781. .subdevice = HDA_SUBDEV_NID_FLAG | nid, \
  3782. .info = alc_test_pin_src_info, \
  3783. .get = alc_test_pin_src_get, \
  3784. .put = alc_test_pin_src_put, \
  3785. .private_value = nid \
  3786. }
  3787. static struct snd_kcontrol_new alc880_test_mixer[] = {
  3788. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  3789. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  3790. HDA_CODEC_VOLUME("CLFE Playback Volume", 0x0e, 0x0, HDA_OUTPUT),
  3791. HDA_CODEC_VOLUME("Side Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  3792. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  3793. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  3794. HDA_BIND_MUTE("CLFE Playback Switch", 0x0e, 2, HDA_INPUT),
  3795. HDA_BIND_MUTE("Side Playback Switch", 0x0f, 2, HDA_INPUT),
  3796. PIN_CTL_TEST("Front Pin Mode", 0x14),
  3797. PIN_CTL_TEST("Surround Pin Mode", 0x15),
  3798. PIN_CTL_TEST("CLFE Pin Mode", 0x16),
  3799. PIN_CTL_TEST("Side Pin Mode", 0x17),
  3800. PIN_CTL_TEST("In-1 Pin Mode", 0x18),
  3801. PIN_CTL_TEST("In-2 Pin Mode", 0x19),
  3802. PIN_CTL_TEST("In-3 Pin Mode", 0x1a),
  3803. PIN_CTL_TEST("In-4 Pin Mode", 0x1b),
  3804. PIN_SRC_TEST("In-1 Pin Source", 0x18),
  3805. PIN_SRC_TEST("In-2 Pin Source", 0x19),
  3806. PIN_SRC_TEST("In-3 Pin Source", 0x1a),
  3807. PIN_SRC_TEST("In-4 Pin Source", 0x1b),
  3808. HDA_CODEC_VOLUME("In-1 Playback Volume", 0x0b, 0x0, HDA_INPUT),
  3809. HDA_CODEC_MUTE("In-1 Playback Switch", 0x0b, 0x0, HDA_INPUT),
  3810. HDA_CODEC_VOLUME("In-2 Playback Volume", 0x0b, 0x1, HDA_INPUT),
  3811. HDA_CODEC_MUTE("In-2 Playback Switch", 0x0b, 0x1, HDA_INPUT),
  3812. HDA_CODEC_VOLUME("In-3 Playback Volume", 0x0b, 0x2, HDA_INPUT),
  3813. HDA_CODEC_MUTE("In-3 Playback Switch", 0x0b, 0x2, HDA_INPUT),
  3814. HDA_CODEC_VOLUME("In-4 Playback Volume", 0x0b, 0x3, HDA_INPUT),
  3815. HDA_CODEC_MUTE("In-4 Playback Switch", 0x0b, 0x3, HDA_INPUT),
  3816. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x4, HDA_INPUT),
  3817. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x4, HDA_INPUT),
  3818. {
  3819. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  3820. .name = "Channel Mode",
  3821. .info = alc_ch_mode_info,
  3822. .get = alc_ch_mode_get,
  3823. .put = alc_ch_mode_put,
  3824. },
  3825. { } /* end */
  3826. };
  3827. static struct hda_verb alc880_test_init_verbs[] = {
  3828. /* Unmute inputs of 0x0c - 0x0f */
  3829. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  3830. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  3831. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  3832. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  3833. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  3834. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  3835. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  3836. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  3837. /* Vol output for 0x0c-0x0f */
  3838. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  3839. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  3840. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  3841. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  3842. /* Set output pins 0x14-0x17 */
  3843. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  3844. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  3845. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  3846. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  3847. /* Unmute output pins 0x14-0x17 */
  3848. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3849. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3850. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3851. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  3852. /* Set input pins 0x18-0x1c */
  3853. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  3854. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  3855. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  3856. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  3857. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  3858. /* Mute input pins 0x18-0x1b */
  3859. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  3860. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  3861. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  3862. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  3863. /* ADC set up */
  3864. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  3865. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  3866. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  3867. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  3868. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  3869. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  3870. /* Analog input/passthru */
  3871. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  3872. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  3873. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  3874. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  3875. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  3876. { }
  3877. };
  3878. #endif
  3879. /*
  3880. */
  3881. static const char *alc880_models[ALC880_MODEL_LAST] = {
  3882. [ALC880_3ST] = "3stack",
  3883. [ALC880_TCL_S700] = "tcl",
  3884. [ALC880_3ST_DIG] = "3stack-digout",
  3885. [ALC880_CLEVO] = "clevo",
  3886. [ALC880_5ST] = "5stack",
  3887. [ALC880_5ST_DIG] = "5stack-digout",
  3888. [ALC880_W810] = "w810",
  3889. [ALC880_Z71V] = "z71v",
  3890. [ALC880_6ST] = "6stack",
  3891. [ALC880_6ST_DIG] = "6stack-digout",
  3892. [ALC880_ASUS] = "asus",
  3893. [ALC880_ASUS_W1V] = "asus-w1v",
  3894. [ALC880_ASUS_DIG] = "asus-dig",
  3895. [ALC880_ASUS_DIG2] = "asus-dig2",
  3896. [ALC880_UNIWILL_DIG] = "uniwill",
  3897. [ALC880_UNIWILL_P53] = "uniwill-p53",
  3898. [ALC880_FUJITSU] = "fujitsu",
  3899. [ALC880_F1734] = "F1734",
  3900. [ALC880_LG] = "lg",
  3901. [ALC880_LG_LW] = "lg-lw",
  3902. [ALC880_MEDION_RIM] = "medion",
  3903. #ifdef CONFIG_SND_DEBUG
  3904. [ALC880_TEST] = "test",
  3905. #endif
  3906. [ALC880_AUTO] = "auto",
  3907. };
  3908. static struct snd_pci_quirk alc880_cfg_tbl[] = {
  3909. SND_PCI_QUIRK(0x1019, 0x0f69, "Coeus G610P", ALC880_W810),
  3910. SND_PCI_QUIRK(0x1019, 0xa880, "ECS", ALC880_5ST_DIG),
  3911. SND_PCI_QUIRK(0x1019, 0xa884, "Acer APFV", ALC880_6ST),
  3912. SND_PCI_QUIRK(0x1025, 0x0070, "ULI", ALC880_3ST_DIG),
  3913. SND_PCI_QUIRK(0x1025, 0x0077, "ULI", ALC880_6ST_DIG),
  3914. SND_PCI_QUIRK(0x1025, 0x0078, "ULI", ALC880_6ST_DIG),
  3915. SND_PCI_QUIRK(0x1025, 0x0087, "ULI", ALC880_6ST_DIG),
  3916. SND_PCI_QUIRK(0x1025, 0xe309, "ULI", ALC880_3ST_DIG),
  3917. SND_PCI_QUIRK(0x1025, 0xe310, "ULI", ALC880_3ST),
  3918. SND_PCI_QUIRK(0x1039, 0x1234, NULL, ALC880_6ST_DIG),
  3919. SND_PCI_QUIRK(0x103c, 0x2a09, "HP", ALC880_5ST),
  3920. SND_PCI_QUIRK(0x1043, 0x10b3, "ASUS W1V", ALC880_ASUS_W1V),
  3921. SND_PCI_QUIRK(0x1043, 0x10c2, "ASUS W6A", ALC880_ASUS_DIG),
  3922. SND_PCI_QUIRK(0x1043, 0x10c3, "ASUS Wxx", ALC880_ASUS_DIG),
  3923. SND_PCI_QUIRK(0x1043, 0x1113, "ASUS", ALC880_ASUS_DIG),
  3924. SND_PCI_QUIRK(0x1043, 0x1123, "ASUS", ALC880_ASUS_DIG),
  3925. SND_PCI_QUIRK(0x1043, 0x1173, "ASUS", ALC880_ASUS_DIG),
  3926. SND_PCI_QUIRK(0x1043, 0x1964, "ASUS Z71V", ALC880_Z71V),
  3927. /* SND_PCI_QUIRK(0x1043, 0x1964, "ASUS", ALC880_ASUS_DIG), */
  3928. SND_PCI_QUIRK(0x1043, 0x1973, "ASUS", ALC880_ASUS_DIG),
  3929. SND_PCI_QUIRK(0x1043, 0x19b3, "ASUS", ALC880_ASUS_DIG),
  3930. SND_PCI_QUIRK(0x1043, 0x814e, "ASUS P5GD1 w/SPDIF", ALC880_6ST_DIG),
  3931. SND_PCI_QUIRK(0x1043, 0x8181, "ASUS P4GPL", ALC880_ASUS_DIG),
  3932. SND_PCI_QUIRK(0x1043, 0x8196, "ASUS P5GD1", ALC880_6ST),
  3933. SND_PCI_QUIRK(0x1043, 0x81b4, "ASUS", ALC880_6ST),
  3934. SND_PCI_QUIRK_VENDOR(0x1043, "ASUS", ALC880_ASUS), /* default ASUS */
  3935. SND_PCI_QUIRK(0x104d, 0x81a0, "Sony", ALC880_3ST),
  3936. SND_PCI_QUIRK(0x104d, 0x81d6, "Sony", ALC880_3ST),
  3937. SND_PCI_QUIRK(0x107b, 0x3032, "Gateway", ALC880_5ST),
  3938. SND_PCI_QUIRK(0x107b, 0x3033, "Gateway", ALC880_5ST),
  3939. SND_PCI_QUIRK(0x107b, 0x4039, "Gateway", ALC880_5ST),
  3940. SND_PCI_QUIRK(0x1297, 0xc790, "Shuttle ST20G5", ALC880_6ST_DIG),
  3941. SND_PCI_QUIRK(0x1458, 0xa102, "Gigabyte K8", ALC880_6ST_DIG),
  3942. SND_PCI_QUIRK(0x1462, 0x1150, "MSI", ALC880_6ST_DIG),
  3943. SND_PCI_QUIRK(0x1509, 0x925d, "FIC P4M", ALC880_6ST_DIG),
  3944. SND_PCI_QUIRK(0x1558, 0x0520, "Clevo m520G", ALC880_CLEVO),
  3945. SND_PCI_QUIRK(0x1558, 0x0660, "Clevo m655n", ALC880_CLEVO),
  3946. SND_PCI_QUIRK(0x1558, 0x5401, "ASUS", ALC880_ASUS_DIG2),
  3947. SND_PCI_QUIRK(0x1565, 0x8202, "Biostar", ALC880_5ST_DIG),
  3948. SND_PCI_QUIRK(0x1584, 0x9050, "Uniwill", ALC880_UNIWILL_DIG),
  3949. SND_PCI_QUIRK(0x1584, 0x9054, "Uniwlll", ALC880_F1734),
  3950. SND_PCI_QUIRK(0x1584, 0x9070, "Uniwill", ALC880_UNIWILL),
  3951. SND_PCI_QUIRK(0x1584, 0x9077, "Uniwill P53", ALC880_UNIWILL_P53),
  3952. SND_PCI_QUIRK(0x161f, 0x203d, "W810", ALC880_W810),
  3953. SND_PCI_QUIRK(0x161f, 0x205d, "Medion Rim 2150", ALC880_MEDION_RIM),
  3954. SND_PCI_QUIRK(0x1695, 0x400d, "EPoX", ALC880_5ST_DIG),
  3955. SND_PCI_QUIRK(0x1695, 0x4012, "EPox EP-5LDA", ALC880_5ST_DIG),
  3956. SND_PCI_QUIRK(0x1734, 0x107c, "FSC F1734", ALC880_F1734),
  3957. SND_PCI_QUIRK(0x1734, 0x1094, "FSC Amilo M1451G", ALC880_FUJITSU),
  3958. SND_PCI_QUIRK(0x1734, 0x10ac, "FSC AMILO Xi 1526", ALC880_F1734),
  3959. SND_PCI_QUIRK(0x1734, 0x10b0, "Fujitsu", ALC880_FUJITSU),
  3960. SND_PCI_QUIRK(0x1854, 0x0018, "LG LW20", ALC880_LG_LW),
  3961. SND_PCI_QUIRK(0x1854, 0x003b, "LG", ALC880_LG),
  3962. SND_PCI_QUIRK(0x1854, 0x0068, "LG w1", ALC880_LG),
  3963. SND_PCI_QUIRK(0x1854, 0x0077, "LG LW25", ALC880_LG_LW),
  3964. SND_PCI_QUIRK(0x19db, 0x4188, "TCL S700", ALC880_TCL_S700),
  3965. SND_PCI_QUIRK(0x2668, 0x8086, NULL, ALC880_6ST_DIG), /* broken BIOS */
  3966. SND_PCI_QUIRK(0x8086, 0x2668, NULL, ALC880_6ST_DIG),
  3967. SND_PCI_QUIRK(0x8086, 0xa100, "Intel mobo", ALC880_5ST_DIG),
  3968. SND_PCI_QUIRK(0x8086, 0xd400, "Intel mobo", ALC880_5ST_DIG),
  3969. SND_PCI_QUIRK(0x8086, 0xd401, "Intel mobo", ALC880_5ST_DIG),
  3970. SND_PCI_QUIRK(0x8086, 0xd402, "Intel mobo", ALC880_3ST_DIG),
  3971. SND_PCI_QUIRK(0x8086, 0xe224, "Intel mobo", ALC880_5ST_DIG),
  3972. SND_PCI_QUIRK(0x8086, 0xe305, "Intel mobo", ALC880_3ST_DIG),
  3973. SND_PCI_QUIRK(0x8086, 0xe308, "Intel mobo", ALC880_3ST_DIG),
  3974. SND_PCI_QUIRK(0x8086, 0xe400, "Intel mobo", ALC880_5ST_DIG),
  3975. SND_PCI_QUIRK(0x8086, 0xe401, "Intel mobo", ALC880_5ST_DIG),
  3976. SND_PCI_QUIRK(0x8086, 0xe402, "Intel mobo", ALC880_5ST_DIG),
  3977. /* default Intel */
  3978. SND_PCI_QUIRK_VENDOR(0x8086, "Intel mobo", ALC880_3ST),
  3979. SND_PCI_QUIRK(0xa0a0, 0x0560, "AOpen i915GMm-HFS", ALC880_5ST_DIG),
  3980. SND_PCI_QUIRK(0xe803, 0x1019, NULL, ALC880_6ST_DIG),
  3981. {}
  3982. };
  3983. /*
  3984. * ALC880 codec presets
  3985. */
  3986. static struct alc_config_preset alc880_presets[] = {
  3987. [ALC880_3ST] = {
  3988. .mixers = { alc880_three_stack_mixer },
  3989. .init_verbs = { alc880_volume_init_verbs,
  3990. alc880_pin_3stack_init_verbs },
  3991. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  3992. .dac_nids = alc880_dac_nids,
  3993. .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes),
  3994. .channel_mode = alc880_threestack_modes,
  3995. .need_dac_fix = 1,
  3996. .input_mux = &alc880_capture_source,
  3997. },
  3998. [ALC880_3ST_DIG] = {
  3999. .mixers = { alc880_three_stack_mixer },
  4000. .init_verbs = { alc880_volume_init_verbs,
  4001. alc880_pin_3stack_init_verbs },
  4002. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4003. .dac_nids = alc880_dac_nids,
  4004. .dig_out_nid = ALC880_DIGOUT_NID,
  4005. .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes),
  4006. .channel_mode = alc880_threestack_modes,
  4007. .need_dac_fix = 1,
  4008. .input_mux = &alc880_capture_source,
  4009. },
  4010. [ALC880_TCL_S700] = {
  4011. .mixers = { alc880_tcl_s700_mixer },
  4012. .init_verbs = { alc880_volume_init_verbs,
  4013. alc880_pin_tcl_S700_init_verbs,
  4014. alc880_gpio2_init_verbs },
  4015. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4016. .dac_nids = alc880_dac_nids,
  4017. .adc_nids = alc880_adc_nids_alt, /* FIXME: correct? */
  4018. .num_adc_nids = 1, /* single ADC */
  4019. .hp_nid = 0x03,
  4020. .num_channel_mode = ARRAY_SIZE(alc880_2_jack_modes),
  4021. .channel_mode = alc880_2_jack_modes,
  4022. .input_mux = &alc880_capture_source,
  4023. },
  4024. [ALC880_5ST] = {
  4025. .mixers = { alc880_three_stack_mixer,
  4026. alc880_five_stack_mixer},
  4027. .init_verbs = { alc880_volume_init_verbs,
  4028. alc880_pin_5stack_init_verbs },
  4029. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4030. .dac_nids = alc880_dac_nids,
  4031. .num_channel_mode = ARRAY_SIZE(alc880_fivestack_modes),
  4032. .channel_mode = alc880_fivestack_modes,
  4033. .input_mux = &alc880_capture_source,
  4034. },
  4035. [ALC880_5ST_DIG] = {
  4036. .mixers = { alc880_three_stack_mixer,
  4037. alc880_five_stack_mixer },
  4038. .init_verbs = { alc880_volume_init_verbs,
  4039. alc880_pin_5stack_init_verbs },
  4040. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4041. .dac_nids = alc880_dac_nids,
  4042. .dig_out_nid = ALC880_DIGOUT_NID,
  4043. .num_channel_mode = ARRAY_SIZE(alc880_fivestack_modes),
  4044. .channel_mode = alc880_fivestack_modes,
  4045. .input_mux = &alc880_capture_source,
  4046. },
  4047. [ALC880_6ST] = {
  4048. .mixers = { alc880_six_stack_mixer },
  4049. .init_verbs = { alc880_volume_init_verbs,
  4050. alc880_pin_6stack_init_verbs },
  4051. .num_dacs = ARRAY_SIZE(alc880_6st_dac_nids),
  4052. .dac_nids = alc880_6st_dac_nids,
  4053. .num_channel_mode = ARRAY_SIZE(alc880_sixstack_modes),
  4054. .channel_mode = alc880_sixstack_modes,
  4055. .input_mux = &alc880_6stack_capture_source,
  4056. },
  4057. [ALC880_6ST_DIG] = {
  4058. .mixers = { alc880_six_stack_mixer },
  4059. .init_verbs = { alc880_volume_init_verbs,
  4060. alc880_pin_6stack_init_verbs },
  4061. .num_dacs = ARRAY_SIZE(alc880_6st_dac_nids),
  4062. .dac_nids = alc880_6st_dac_nids,
  4063. .dig_out_nid = ALC880_DIGOUT_NID,
  4064. .num_channel_mode = ARRAY_SIZE(alc880_sixstack_modes),
  4065. .channel_mode = alc880_sixstack_modes,
  4066. .input_mux = &alc880_6stack_capture_source,
  4067. },
  4068. [ALC880_W810] = {
  4069. .mixers = { alc880_w810_base_mixer },
  4070. .init_verbs = { alc880_volume_init_verbs,
  4071. alc880_pin_w810_init_verbs,
  4072. alc880_gpio2_init_verbs },
  4073. .num_dacs = ARRAY_SIZE(alc880_w810_dac_nids),
  4074. .dac_nids = alc880_w810_dac_nids,
  4075. .dig_out_nid = ALC880_DIGOUT_NID,
  4076. .num_channel_mode = ARRAY_SIZE(alc880_w810_modes),
  4077. .channel_mode = alc880_w810_modes,
  4078. .input_mux = &alc880_capture_source,
  4079. },
  4080. [ALC880_Z71V] = {
  4081. .mixers = { alc880_z71v_mixer },
  4082. .init_verbs = { alc880_volume_init_verbs,
  4083. alc880_pin_z71v_init_verbs },
  4084. .num_dacs = ARRAY_SIZE(alc880_z71v_dac_nids),
  4085. .dac_nids = alc880_z71v_dac_nids,
  4086. .dig_out_nid = ALC880_DIGOUT_NID,
  4087. .hp_nid = 0x03,
  4088. .num_channel_mode = ARRAY_SIZE(alc880_2_jack_modes),
  4089. .channel_mode = alc880_2_jack_modes,
  4090. .input_mux = &alc880_capture_source,
  4091. },
  4092. [ALC880_F1734] = {
  4093. .mixers = { alc880_f1734_mixer },
  4094. .init_verbs = { alc880_volume_init_verbs,
  4095. alc880_pin_f1734_init_verbs },
  4096. .num_dacs = ARRAY_SIZE(alc880_f1734_dac_nids),
  4097. .dac_nids = alc880_f1734_dac_nids,
  4098. .hp_nid = 0x02,
  4099. .num_channel_mode = ARRAY_SIZE(alc880_2_jack_modes),
  4100. .channel_mode = alc880_2_jack_modes,
  4101. .input_mux = &alc880_f1734_capture_source,
  4102. .unsol_event = alc880_uniwill_p53_unsol_event,
  4103. .setup = alc880_uniwill_p53_setup,
  4104. .init_hook = alc_automute_amp,
  4105. },
  4106. [ALC880_ASUS] = {
  4107. .mixers = { alc880_asus_mixer },
  4108. .init_verbs = { alc880_volume_init_verbs,
  4109. alc880_pin_asus_init_verbs,
  4110. alc880_gpio1_init_verbs },
  4111. .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids),
  4112. .dac_nids = alc880_asus_dac_nids,
  4113. .num_channel_mode = ARRAY_SIZE(alc880_asus_modes),
  4114. .channel_mode = alc880_asus_modes,
  4115. .need_dac_fix = 1,
  4116. .input_mux = &alc880_capture_source,
  4117. },
  4118. [ALC880_ASUS_DIG] = {
  4119. .mixers = { alc880_asus_mixer },
  4120. .init_verbs = { alc880_volume_init_verbs,
  4121. alc880_pin_asus_init_verbs,
  4122. alc880_gpio1_init_verbs },
  4123. .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids),
  4124. .dac_nids = alc880_asus_dac_nids,
  4125. .dig_out_nid = ALC880_DIGOUT_NID,
  4126. .num_channel_mode = ARRAY_SIZE(alc880_asus_modes),
  4127. .channel_mode = alc880_asus_modes,
  4128. .need_dac_fix = 1,
  4129. .input_mux = &alc880_capture_source,
  4130. },
  4131. [ALC880_ASUS_DIG2] = {
  4132. .mixers = { alc880_asus_mixer },
  4133. .init_verbs = { alc880_volume_init_verbs,
  4134. alc880_pin_asus_init_verbs,
  4135. alc880_gpio2_init_verbs }, /* use GPIO2 */
  4136. .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids),
  4137. .dac_nids = alc880_asus_dac_nids,
  4138. .dig_out_nid = ALC880_DIGOUT_NID,
  4139. .num_channel_mode = ARRAY_SIZE(alc880_asus_modes),
  4140. .channel_mode = alc880_asus_modes,
  4141. .need_dac_fix = 1,
  4142. .input_mux = &alc880_capture_source,
  4143. },
  4144. [ALC880_ASUS_W1V] = {
  4145. .mixers = { alc880_asus_mixer, alc880_asus_w1v_mixer },
  4146. .init_verbs = { alc880_volume_init_verbs,
  4147. alc880_pin_asus_init_verbs,
  4148. alc880_gpio1_init_verbs },
  4149. .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids),
  4150. .dac_nids = alc880_asus_dac_nids,
  4151. .dig_out_nid = ALC880_DIGOUT_NID,
  4152. .num_channel_mode = ARRAY_SIZE(alc880_asus_modes),
  4153. .channel_mode = alc880_asus_modes,
  4154. .need_dac_fix = 1,
  4155. .input_mux = &alc880_capture_source,
  4156. },
  4157. [ALC880_UNIWILL_DIG] = {
  4158. .mixers = { alc880_asus_mixer },
  4159. .init_verbs = { alc880_volume_init_verbs,
  4160. alc880_pin_asus_init_verbs },
  4161. .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids),
  4162. .dac_nids = alc880_asus_dac_nids,
  4163. .dig_out_nid = ALC880_DIGOUT_NID,
  4164. .num_channel_mode = ARRAY_SIZE(alc880_asus_modes),
  4165. .channel_mode = alc880_asus_modes,
  4166. .need_dac_fix = 1,
  4167. .input_mux = &alc880_capture_source,
  4168. },
  4169. [ALC880_UNIWILL] = {
  4170. .mixers = { alc880_uniwill_mixer },
  4171. .init_verbs = { alc880_volume_init_verbs,
  4172. alc880_uniwill_init_verbs },
  4173. .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids),
  4174. .dac_nids = alc880_asus_dac_nids,
  4175. .dig_out_nid = ALC880_DIGOUT_NID,
  4176. .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes),
  4177. .channel_mode = alc880_threestack_modes,
  4178. .need_dac_fix = 1,
  4179. .input_mux = &alc880_capture_source,
  4180. .unsol_event = alc880_uniwill_unsol_event,
  4181. .setup = alc880_uniwill_setup,
  4182. .init_hook = alc880_uniwill_init_hook,
  4183. },
  4184. [ALC880_UNIWILL_P53] = {
  4185. .mixers = { alc880_uniwill_p53_mixer },
  4186. .init_verbs = { alc880_volume_init_verbs,
  4187. alc880_uniwill_p53_init_verbs },
  4188. .num_dacs = ARRAY_SIZE(alc880_asus_dac_nids),
  4189. .dac_nids = alc880_asus_dac_nids,
  4190. .num_channel_mode = ARRAY_SIZE(alc880_w810_modes),
  4191. .channel_mode = alc880_threestack_modes,
  4192. .input_mux = &alc880_capture_source,
  4193. .unsol_event = alc880_uniwill_p53_unsol_event,
  4194. .setup = alc880_uniwill_p53_setup,
  4195. .init_hook = alc_automute_amp,
  4196. },
  4197. [ALC880_FUJITSU] = {
  4198. .mixers = { alc880_fujitsu_mixer },
  4199. .init_verbs = { alc880_volume_init_verbs,
  4200. alc880_uniwill_p53_init_verbs,
  4201. alc880_beep_init_verbs },
  4202. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4203. .dac_nids = alc880_dac_nids,
  4204. .dig_out_nid = ALC880_DIGOUT_NID,
  4205. .num_channel_mode = ARRAY_SIZE(alc880_2_jack_modes),
  4206. .channel_mode = alc880_2_jack_modes,
  4207. .input_mux = &alc880_capture_source,
  4208. .unsol_event = alc880_uniwill_p53_unsol_event,
  4209. .setup = alc880_uniwill_p53_setup,
  4210. .init_hook = alc_automute_amp,
  4211. },
  4212. [ALC880_CLEVO] = {
  4213. .mixers = { alc880_three_stack_mixer },
  4214. .init_verbs = { alc880_volume_init_verbs,
  4215. alc880_pin_clevo_init_verbs },
  4216. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4217. .dac_nids = alc880_dac_nids,
  4218. .hp_nid = 0x03,
  4219. .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes),
  4220. .channel_mode = alc880_threestack_modes,
  4221. .need_dac_fix = 1,
  4222. .input_mux = &alc880_capture_source,
  4223. },
  4224. [ALC880_LG] = {
  4225. .mixers = { alc880_lg_mixer },
  4226. .init_verbs = { alc880_volume_init_verbs,
  4227. alc880_lg_init_verbs },
  4228. .num_dacs = ARRAY_SIZE(alc880_lg_dac_nids),
  4229. .dac_nids = alc880_lg_dac_nids,
  4230. .dig_out_nid = ALC880_DIGOUT_NID,
  4231. .num_channel_mode = ARRAY_SIZE(alc880_lg_ch_modes),
  4232. .channel_mode = alc880_lg_ch_modes,
  4233. .need_dac_fix = 1,
  4234. .input_mux = &alc880_lg_capture_source,
  4235. .unsol_event = alc_automute_amp_unsol_event,
  4236. .setup = alc880_lg_setup,
  4237. .init_hook = alc_automute_amp,
  4238. #ifdef CONFIG_SND_HDA_POWER_SAVE
  4239. .loopbacks = alc880_lg_loopbacks,
  4240. #endif
  4241. },
  4242. [ALC880_LG_LW] = {
  4243. .mixers = { alc880_lg_lw_mixer },
  4244. .init_verbs = { alc880_volume_init_verbs,
  4245. alc880_lg_lw_init_verbs },
  4246. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4247. .dac_nids = alc880_dac_nids,
  4248. .dig_out_nid = ALC880_DIGOUT_NID,
  4249. .num_channel_mode = ARRAY_SIZE(alc880_lg_lw_modes),
  4250. .channel_mode = alc880_lg_lw_modes,
  4251. .input_mux = &alc880_lg_lw_capture_source,
  4252. .unsol_event = alc_automute_amp_unsol_event,
  4253. .setup = alc880_lg_lw_setup,
  4254. .init_hook = alc_automute_amp,
  4255. },
  4256. [ALC880_MEDION_RIM] = {
  4257. .mixers = { alc880_medion_rim_mixer },
  4258. .init_verbs = { alc880_volume_init_verbs,
  4259. alc880_medion_rim_init_verbs,
  4260. alc_gpio2_init_verbs },
  4261. .num_dacs = ARRAY_SIZE(alc880_dac_nids),
  4262. .dac_nids = alc880_dac_nids,
  4263. .dig_out_nid = ALC880_DIGOUT_NID,
  4264. .num_channel_mode = ARRAY_SIZE(alc880_2_jack_modes),
  4265. .channel_mode = alc880_2_jack_modes,
  4266. .input_mux = &alc880_medion_rim_capture_source,
  4267. .unsol_event = alc880_medion_rim_unsol_event,
  4268. .setup = alc880_medion_rim_setup,
  4269. .init_hook = alc880_medion_rim_automute,
  4270. },
  4271. #ifdef CONFIG_SND_DEBUG
  4272. [ALC880_TEST] = {
  4273. .mixers = { alc880_test_mixer },
  4274. .init_verbs = { alc880_test_init_verbs },
  4275. .num_dacs = ARRAY_SIZE(alc880_test_dac_nids),
  4276. .dac_nids = alc880_test_dac_nids,
  4277. .dig_out_nid = ALC880_DIGOUT_NID,
  4278. .num_channel_mode = ARRAY_SIZE(alc880_test_modes),
  4279. .channel_mode = alc880_test_modes,
  4280. .input_mux = &alc880_test_capture_source,
  4281. },
  4282. #endif
  4283. };
  4284. /*
  4285. * Automatic parse of I/O pins from the BIOS configuration
  4286. */
  4287. enum {
  4288. ALC_CTL_WIDGET_VOL,
  4289. ALC_CTL_WIDGET_MUTE,
  4290. ALC_CTL_BIND_MUTE,
  4291. };
  4292. static struct snd_kcontrol_new alc880_control_templates[] = {
  4293. HDA_CODEC_VOLUME(NULL, 0, 0, 0),
  4294. HDA_CODEC_MUTE(NULL, 0, 0, 0),
  4295. HDA_BIND_MUTE(NULL, 0, 0, 0),
  4296. };
  4297. /* add dynamic controls */
  4298. static int add_control(struct alc_spec *spec, int type, const char *name,
  4299. unsigned long val)
  4300. {
  4301. struct snd_kcontrol_new *knew;
  4302. snd_array_init(&spec->kctls, sizeof(*knew), 32);
  4303. knew = snd_array_new(&spec->kctls);
  4304. if (!knew)
  4305. return -ENOMEM;
  4306. *knew = alc880_control_templates[type];
  4307. knew->name = kstrdup(name, GFP_KERNEL);
  4308. if (!knew->name)
  4309. return -ENOMEM;
  4310. if (get_amp_nid_(val))
  4311. knew->subdevice = HDA_SUBDEV_AMP_FLAG;
  4312. knew->private_value = val;
  4313. return 0;
  4314. }
  4315. static int add_control_with_pfx(struct alc_spec *spec, int type,
  4316. const char *pfx, const char *dir,
  4317. const char *sfx, unsigned long val)
  4318. {
  4319. char name[32];
  4320. snprintf(name, sizeof(name), "%s %s %s", pfx, dir, sfx);
  4321. return add_control(spec, type, name, val);
  4322. }
  4323. #define add_pb_vol_ctrl(spec, type, pfx, val) \
  4324. add_control_with_pfx(spec, type, pfx, "Playback", "Volume", val)
  4325. #define add_pb_sw_ctrl(spec, type, pfx, val) \
  4326. add_control_with_pfx(spec, type, pfx, "Playback", "Switch", val)
  4327. #define alc880_is_fixed_pin(nid) ((nid) >= 0x14 && (nid) <= 0x17)
  4328. #define alc880_fixed_pin_idx(nid) ((nid) - 0x14)
  4329. #define alc880_is_multi_pin(nid) ((nid) >= 0x18)
  4330. #define alc880_multi_pin_idx(nid) ((nid) - 0x18)
  4331. #define alc880_idx_to_dac(nid) ((nid) + 0x02)
  4332. #define alc880_dac_to_idx(nid) ((nid) - 0x02)
  4333. #define alc880_idx_to_mixer(nid) ((nid) + 0x0c)
  4334. #define alc880_idx_to_selector(nid) ((nid) + 0x10)
  4335. #define ALC880_PIN_CD_NID 0x1c
  4336. /* fill in the dac_nids table from the parsed pin configuration */
  4337. static int alc880_auto_fill_dac_nids(struct alc_spec *spec,
  4338. const struct auto_pin_cfg *cfg)
  4339. {
  4340. hda_nid_t nid;
  4341. int assigned[4];
  4342. int i, j;
  4343. memset(assigned, 0, sizeof(assigned));
  4344. spec->multiout.dac_nids = spec->private_dac_nids;
  4345. /* check the pins hardwired to audio widget */
  4346. for (i = 0; i < cfg->line_outs; i++) {
  4347. nid = cfg->line_out_pins[i];
  4348. if (alc880_is_fixed_pin(nid)) {
  4349. int idx = alc880_fixed_pin_idx(nid);
  4350. spec->multiout.dac_nids[i] = alc880_idx_to_dac(idx);
  4351. assigned[idx] = 1;
  4352. }
  4353. }
  4354. /* left pins can be connect to any audio widget */
  4355. for (i = 0; i < cfg->line_outs; i++) {
  4356. nid = cfg->line_out_pins[i];
  4357. if (alc880_is_fixed_pin(nid))
  4358. continue;
  4359. /* search for an empty channel */
  4360. for (j = 0; j < cfg->line_outs; j++) {
  4361. if (!assigned[j]) {
  4362. spec->multiout.dac_nids[i] =
  4363. alc880_idx_to_dac(j);
  4364. assigned[j] = 1;
  4365. break;
  4366. }
  4367. }
  4368. }
  4369. spec->multiout.num_dacs = cfg->line_outs;
  4370. return 0;
  4371. }
  4372. /* add playback controls from the parsed DAC table */
  4373. static int alc880_auto_create_multi_out_ctls(struct alc_spec *spec,
  4374. const struct auto_pin_cfg *cfg)
  4375. {
  4376. static const char *chname[4] = {
  4377. "Front", "Surround", NULL /*CLFE*/, "Side"
  4378. };
  4379. hda_nid_t nid;
  4380. int i, err;
  4381. for (i = 0; i < cfg->line_outs; i++) {
  4382. if (!spec->multiout.dac_nids[i])
  4383. continue;
  4384. nid = alc880_idx_to_mixer(alc880_dac_to_idx(spec->multiout.dac_nids[i]));
  4385. if (i == 2) {
  4386. /* Center/LFE */
  4387. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL,
  4388. "Center",
  4389. HDA_COMPOSE_AMP_VAL(nid, 1, 0,
  4390. HDA_OUTPUT));
  4391. if (err < 0)
  4392. return err;
  4393. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL,
  4394. "LFE",
  4395. HDA_COMPOSE_AMP_VAL(nid, 2, 0,
  4396. HDA_OUTPUT));
  4397. if (err < 0)
  4398. return err;
  4399. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE,
  4400. "Center",
  4401. HDA_COMPOSE_AMP_VAL(nid, 1, 2,
  4402. HDA_INPUT));
  4403. if (err < 0)
  4404. return err;
  4405. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE,
  4406. "LFE",
  4407. HDA_COMPOSE_AMP_VAL(nid, 2, 2,
  4408. HDA_INPUT));
  4409. if (err < 0)
  4410. return err;
  4411. } else {
  4412. const char *pfx;
  4413. if (cfg->line_outs == 1 &&
  4414. cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  4415. pfx = "Speaker";
  4416. else
  4417. pfx = chname[i];
  4418. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, pfx,
  4419. HDA_COMPOSE_AMP_VAL(nid, 3, 0,
  4420. HDA_OUTPUT));
  4421. if (err < 0)
  4422. return err;
  4423. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE, pfx,
  4424. HDA_COMPOSE_AMP_VAL(nid, 3, 2,
  4425. HDA_INPUT));
  4426. if (err < 0)
  4427. return err;
  4428. }
  4429. }
  4430. return 0;
  4431. }
  4432. /* add playback controls for speaker and HP outputs */
  4433. static int alc880_auto_create_extra_out(struct alc_spec *spec, hda_nid_t pin,
  4434. const char *pfx)
  4435. {
  4436. hda_nid_t nid;
  4437. int err;
  4438. if (!pin)
  4439. return 0;
  4440. if (alc880_is_fixed_pin(pin)) {
  4441. nid = alc880_idx_to_dac(alc880_fixed_pin_idx(pin));
  4442. /* specify the DAC as the extra output */
  4443. if (!spec->multiout.hp_nid)
  4444. spec->multiout.hp_nid = nid;
  4445. else
  4446. spec->multiout.extra_out_nid[0] = nid;
  4447. /* control HP volume/switch on the output mixer amp */
  4448. nid = alc880_idx_to_mixer(alc880_fixed_pin_idx(pin));
  4449. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, pfx,
  4450. HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT));
  4451. if (err < 0)
  4452. return err;
  4453. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE, pfx,
  4454. HDA_COMPOSE_AMP_VAL(nid, 3, 2, HDA_INPUT));
  4455. if (err < 0)
  4456. return err;
  4457. } else if (alc880_is_multi_pin(pin)) {
  4458. /* set manual connection */
  4459. /* we have only a switch on HP-out PIN */
  4460. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, pfx,
  4461. HDA_COMPOSE_AMP_VAL(pin, 3, 0, HDA_OUTPUT));
  4462. if (err < 0)
  4463. return err;
  4464. }
  4465. return 0;
  4466. }
  4467. /* create input playback/capture controls for the given pin */
  4468. static int new_analog_input(struct alc_spec *spec, hda_nid_t pin,
  4469. const char *ctlname,
  4470. int idx, hda_nid_t mix_nid)
  4471. {
  4472. int err;
  4473. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, ctlname,
  4474. HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT));
  4475. if (err < 0)
  4476. return err;
  4477. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, ctlname,
  4478. HDA_COMPOSE_AMP_VAL(mix_nid, 3, idx, HDA_INPUT));
  4479. if (err < 0)
  4480. return err;
  4481. return 0;
  4482. }
  4483. static int alc_is_input_pin(struct hda_codec *codec, hda_nid_t nid)
  4484. {
  4485. unsigned int pincap = snd_hda_query_pin_caps(codec, nid);
  4486. return (pincap & AC_PINCAP_IN) != 0;
  4487. }
  4488. /* create playback/capture controls for input pins */
  4489. static int alc_auto_create_input_ctls(struct hda_codec *codec,
  4490. const struct auto_pin_cfg *cfg,
  4491. hda_nid_t mixer,
  4492. hda_nid_t cap1, hda_nid_t cap2)
  4493. {
  4494. struct alc_spec *spec = codec->spec;
  4495. struct hda_input_mux *imux = &spec->private_imux[0];
  4496. int i, err, idx;
  4497. for (i = 0; i < AUTO_PIN_LAST; i++) {
  4498. hda_nid_t pin;
  4499. pin = cfg->input_pins[i];
  4500. if (!alc_is_input_pin(codec, pin))
  4501. continue;
  4502. if (mixer) {
  4503. idx = get_connection_index(codec, mixer, pin);
  4504. if (idx >= 0) {
  4505. err = new_analog_input(spec, pin,
  4506. auto_pin_cfg_labels[i],
  4507. idx, mixer);
  4508. if (err < 0)
  4509. return err;
  4510. }
  4511. }
  4512. if (!cap1)
  4513. continue;
  4514. idx = get_connection_index(codec, cap1, pin);
  4515. if (idx < 0 && cap2)
  4516. idx = get_connection_index(codec, cap2, pin);
  4517. if (idx >= 0) {
  4518. imux->items[imux->num_items].label =
  4519. auto_pin_cfg_labels[i];
  4520. imux->items[imux->num_items].index = idx;
  4521. imux->num_items++;
  4522. }
  4523. }
  4524. return 0;
  4525. }
  4526. static int alc880_auto_create_input_ctls(struct hda_codec *codec,
  4527. const struct auto_pin_cfg *cfg)
  4528. {
  4529. return alc_auto_create_input_ctls(codec, cfg, 0x0b, 0x08, 0x09);
  4530. }
  4531. static void alc_set_pin_output(struct hda_codec *codec, hda_nid_t nid,
  4532. unsigned int pin_type)
  4533. {
  4534. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  4535. pin_type);
  4536. /* unmute pin */
  4537. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_AMP_GAIN_MUTE,
  4538. AMP_OUT_UNMUTE);
  4539. }
  4540. static void alc880_auto_set_output_and_unmute(struct hda_codec *codec,
  4541. hda_nid_t nid, int pin_type,
  4542. int dac_idx)
  4543. {
  4544. alc_set_pin_output(codec, nid, pin_type);
  4545. /* need the manual connection? */
  4546. if (alc880_is_multi_pin(nid)) {
  4547. struct alc_spec *spec = codec->spec;
  4548. int idx = alc880_multi_pin_idx(nid);
  4549. snd_hda_codec_write(codec, alc880_idx_to_selector(idx), 0,
  4550. AC_VERB_SET_CONNECT_SEL,
  4551. alc880_dac_to_idx(spec->multiout.dac_nids[dac_idx]));
  4552. }
  4553. }
  4554. static int get_pin_type(int line_out_type)
  4555. {
  4556. if (line_out_type == AUTO_PIN_HP_OUT)
  4557. return PIN_HP;
  4558. else
  4559. return PIN_OUT;
  4560. }
  4561. static void alc880_auto_init_multi_out(struct hda_codec *codec)
  4562. {
  4563. struct alc_spec *spec = codec->spec;
  4564. int i;
  4565. for (i = 0; i < spec->autocfg.line_outs; i++) {
  4566. hda_nid_t nid = spec->autocfg.line_out_pins[i];
  4567. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  4568. alc880_auto_set_output_and_unmute(codec, nid, pin_type, i);
  4569. }
  4570. }
  4571. static void alc880_auto_init_extra_out(struct hda_codec *codec)
  4572. {
  4573. struct alc_spec *spec = codec->spec;
  4574. hda_nid_t pin;
  4575. pin = spec->autocfg.speaker_pins[0];
  4576. if (pin) /* connect to front */
  4577. alc880_auto_set_output_and_unmute(codec, pin, PIN_OUT, 0);
  4578. pin = spec->autocfg.hp_pins[0];
  4579. if (pin) /* connect to front */
  4580. alc880_auto_set_output_and_unmute(codec, pin, PIN_HP, 0);
  4581. }
  4582. static void alc880_auto_init_analog_input(struct hda_codec *codec)
  4583. {
  4584. struct alc_spec *spec = codec->spec;
  4585. int i;
  4586. for (i = 0; i < AUTO_PIN_LAST; i++) {
  4587. hda_nid_t nid = spec->autocfg.input_pins[i];
  4588. if (alc_is_input_pin(codec, nid)) {
  4589. alc_set_input_pin(codec, nid, i);
  4590. if (nid != ALC880_PIN_CD_NID &&
  4591. (get_wcaps(codec, nid) & AC_WCAP_OUT_AMP))
  4592. snd_hda_codec_write(codec, nid, 0,
  4593. AC_VERB_SET_AMP_GAIN_MUTE,
  4594. AMP_OUT_MUTE);
  4595. }
  4596. }
  4597. }
  4598. static void alc880_auto_init_input_src(struct hda_codec *codec)
  4599. {
  4600. struct alc_spec *spec = codec->spec;
  4601. int c;
  4602. for (c = 0; c < spec->num_adc_nids; c++) {
  4603. unsigned int mux_idx;
  4604. const struct hda_input_mux *imux;
  4605. mux_idx = c >= spec->num_mux_defs ? 0 : c;
  4606. imux = &spec->input_mux[mux_idx];
  4607. if (!imux->num_items && mux_idx > 0)
  4608. imux = &spec->input_mux[0];
  4609. if (imux)
  4610. snd_hda_codec_write(codec, spec->adc_nids[c], 0,
  4611. AC_VERB_SET_CONNECT_SEL,
  4612. imux->items[0].index);
  4613. }
  4614. }
  4615. /* parse the BIOS configuration and set up the alc_spec */
  4616. /* return 1 if successful, 0 if the proper config is not found,
  4617. * or a negative error code
  4618. */
  4619. static int alc880_parse_auto_config(struct hda_codec *codec)
  4620. {
  4621. struct alc_spec *spec = codec->spec;
  4622. int err;
  4623. static hda_nid_t alc880_ignore[] = { 0x1d, 0 };
  4624. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  4625. alc880_ignore);
  4626. if (err < 0)
  4627. return err;
  4628. if (!spec->autocfg.line_outs)
  4629. return 0; /* can't find valid BIOS pin config */
  4630. err = alc880_auto_fill_dac_nids(spec, &spec->autocfg);
  4631. if (err < 0)
  4632. return err;
  4633. err = alc880_auto_create_multi_out_ctls(spec, &spec->autocfg);
  4634. if (err < 0)
  4635. return err;
  4636. err = alc880_auto_create_extra_out(spec,
  4637. spec->autocfg.speaker_pins[0],
  4638. "Speaker");
  4639. if (err < 0)
  4640. return err;
  4641. err = alc880_auto_create_extra_out(spec, spec->autocfg.hp_pins[0],
  4642. "Headphone");
  4643. if (err < 0)
  4644. return err;
  4645. err = alc880_auto_create_input_ctls(codec, &spec->autocfg);
  4646. if (err < 0)
  4647. return err;
  4648. spec->multiout.max_channels = spec->multiout.num_dacs * 2;
  4649. alc_auto_parse_digital(codec);
  4650. if (spec->kctls.list)
  4651. add_mixer(spec, spec->kctls.list);
  4652. add_verb(spec, alc880_volume_init_verbs);
  4653. spec->num_mux_defs = 1;
  4654. spec->input_mux = &spec->private_imux[0];
  4655. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
  4656. return 1;
  4657. }
  4658. /* additional initialization for auto-configuration model */
  4659. static void alc880_auto_init(struct hda_codec *codec)
  4660. {
  4661. struct alc_spec *spec = codec->spec;
  4662. alc880_auto_init_multi_out(codec);
  4663. alc880_auto_init_extra_out(codec);
  4664. alc880_auto_init_analog_input(codec);
  4665. alc880_auto_init_input_src(codec);
  4666. alc_auto_init_digital(codec);
  4667. if (spec->unsol_event)
  4668. alc_inithook(codec);
  4669. }
  4670. /* check the ADC/MUX contains all input pins; some ADC/MUX contains only
  4671. * one of two digital mic pins, e.g. on ALC272
  4672. */
  4673. static void fixup_automic_adc(struct hda_codec *codec)
  4674. {
  4675. struct alc_spec *spec = codec->spec;
  4676. int i;
  4677. for (i = 0; i < spec->num_adc_nids; i++) {
  4678. hda_nid_t cap = spec->capsrc_nids ?
  4679. spec->capsrc_nids[i] : spec->adc_nids[i];
  4680. int iidx, eidx;
  4681. iidx = get_connection_index(codec, cap, spec->int_mic.pin);
  4682. if (iidx < 0)
  4683. continue;
  4684. eidx = get_connection_index(codec, cap, spec->ext_mic.pin);
  4685. if (eidx < 0)
  4686. continue;
  4687. spec->int_mic.mux_idx = iidx;
  4688. spec->ext_mic.mux_idx = eidx;
  4689. if (spec->capsrc_nids)
  4690. spec->capsrc_nids += i;
  4691. spec->adc_nids += i;
  4692. spec->num_adc_nids = 1;
  4693. return;
  4694. }
  4695. snd_printd(KERN_INFO "hda_codec: %s: "
  4696. "No ADC/MUX containing both 0x%x and 0x%x pins\n",
  4697. codec->chip_name, spec->int_mic.pin, spec->ext_mic.pin);
  4698. spec->auto_mic = 0; /* disable auto-mic to be sure */
  4699. }
  4700. /* select or unmute the given capsrc route */
  4701. static void select_or_unmute_capsrc(struct hda_codec *codec, hda_nid_t cap,
  4702. int idx)
  4703. {
  4704. if (get_wcaps_type(get_wcaps(codec, cap)) == AC_WID_AUD_MIX) {
  4705. snd_hda_codec_amp_stereo(codec, cap, HDA_INPUT, idx,
  4706. HDA_AMP_MUTE, 0);
  4707. } else {
  4708. snd_hda_codec_write_cache(codec, cap, 0,
  4709. AC_VERB_SET_CONNECT_SEL, idx);
  4710. }
  4711. }
  4712. /* set the default connection to that pin */
  4713. static int init_capsrc_for_pin(struct hda_codec *codec, hda_nid_t pin)
  4714. {
  4715. struct alc_spec *spec = codec->spec;
  4716. int i;
  4717. for (i = 0; i < spec->num_adc_nids; i++) {
  4718. hda_nid_t cap = spec->capsrc_nids ?
  4719. spec->capsrc_nids[i] : spec->adc_nids[i];
  4720. int idx;
  4721. idx = get_connection_index(codec, cap, pin);
  4722. if (idx < 0)
  4723. continue;
  4724. select_or_unmute_capsrc(codec, cap, idx);
  4725. return i; /* return the found index */
  4726. }
  4727. return -1; /* not found */
  4728. }
  4729. /* choose the ADC/MUX containing the input pin and initialize the setup */
  4730. static void fixup_single_adc(struct hda_codec *codec)
  4731. {
  4732. struct alc_spec *spec = codec->spec;
  4733. hda_nid_t pin = 0;
  4734. int i;
  4735. /* search for the input pin; there must be only one */
  4736. for (i = 0; i < AUTO_PIN_LAST; i++) {
  4737. if (spec->autocfg.input_pins[i]) {
  4738. pin = spec->autocfg.input_pins[i];
  4739. break;
  4740. }
  4741. }
  4742. if (!pin)
  4743. return;
  4744. i = init_capsrc_for_pin(codec, pin);
  4745. if (i >= 0) {
  4746. /* use only this ADC */
  4747. if (spec->capsrc_nids)
  4748. spec->capsrc_nids += i;
  4749. spec->adc_nids += i;
  4750. spec->num_adc_nids = 1;
  4751. }
  4752. }
  4753. /* initialize dual adcs */
  4754. static void fixup_dual_adc_switch(struct hda_codec *codec)
  4755. {
  4756. struct alc_spec *spec = codec->spec;
  4757. init_capsrc_for_pin(codec, spec->ext_mic.pin);
  4758. init_capsrc_for_pin(codec, spec->int_mic.pin);
  4759. }
  4760. static void set_capture_mixer(struct hda_codec *codec)
  4761. {
  4762. struct alc_spec *spec = codec->spec;
  4763. static struct snd_kcontrol_new *caps[2][3] = {
  4764. { alc_capture_mixer_nosrc1,
  4765. alc_capture_mixer_nosrc2,
  4766. alc_capture_mixer_nosrc3 },
  4767. { alc_capture_mixer1,
  4768. alc_capture_mixer2,
  4769. alc_capture_mixer3 },
  4770. };
  4771. if (spec->num_adc_nids > 0 && spec->num_adc_nids <= 3) {
  4772. int mux = 0;
  4773. int num_adcs = spec->num_adc_nids;
  4774. if (spec->dual_adc_switch)
  4775. fixup_dual_adc_switch(codec);
  4776. else if (spec->auto_mic)
  4777. fixup_automic_adc(codec);
  4778. else if (spec->input_mux) {
  4779. if (spec->input_mux->num_items > 1)
  4780. mux = 1;
  4781. else if (spec->input_mux->num_items == 1)
  4782. fixup_single_adc(codec);
  4783. }
  4784. if (spec->dual_adc_switch)
  4785. num_adcs = 1;
  4786. spec->cap_mixer = caps[mux][num_adcs - 1];
  4787. }
  4788. }
  4789. /* fill adc_nids (and capsrc_nids) containing all active input pins */
  4790. static void fillup_priv_adc_nids(struct hda_codec *codec, hda_nid_t *nids,
  4791. int num_nids)
  4792. {
  4793. struct alc_spec *spec = codec->spec;
  4794. int n;
  4795. hda_nid_t fallback_adc = 0, fallback_cap = 0;
  4796. for (n = 0; n < num_nids; n++) {
  4797. hda_nid_t adc, cap;
  4798. hda_nid_t conn[HDA_MAX_NUM_INPUTS];
  4799. int nconns, i, j;
  4800. adc = nids[n];
  4801. if (get_wcaps_type(get_wcaps(codec, adc)) != AC_WID_AUD_IN)
  4802. continue;
  4803. cap = adc;
  4804. nconns = snd_hda_get_connections(codec, cap, conn,
  4805. ARRAY_SIZE(conn));
  4806. if (nconns == 1) {
  4807. cap = conn[0];
  4808. nconns = snd_hda_get_connections(codec, cap, conn,
  4809. ARRAY_SIZE(conn));
  4810. }
  4811. if (nconns <= 0)
  4812. continue;
  4813. if (!fallback_adc) {
  4814. fallback_adc = adc;
  4815. fallback_cap = cap;
  4816. }
  4817. for (i = 0; i < AUTO_PIN_LAST; i++) {
  4818. hda_nid_t nid = spec->autocfg.input_pins[i];
  4819. if (!nid)
  4820. continue;
  4821. for (j = 0; j < nconns; j++) {
  4822. if (conn[j] == nid)
  4823. break;
  4824. }
  4825. if (j >= nconns)
  4826. break;
  4827. }
  4828. if (i >= AUTO_PIN_LAST) {
  4829. int num_adcs = spec->num_adc_nids;
  4830. spec->private_adc_nids[num_adcs] = adc;
  4831. spec->private_capsrc_nids[num_adcs] = cap;
  4832. spec->num_adc_nids++;
  4833. spec->adc_nids = spec->private_adc_nids;
  4834. if (adc != cap)
  4835. spec->capsrc_nids = spec->private_capsrc_nids;
  4836. }
  4837. }
  4838. if (!spec->num_adc_nids) {
  4839. printk(KERN_WARNING "hda_codec: %s: no valid ADC found;"
  4840. " using fallback 0x%x\n",
  4841. codec->chip_name, fallback_adc);
  4842. spec->private_adc_nids[0] = fallback_adc;
  4843. spec->adc_nids = spec->private_adc_nids;
  4844. if (fallback_adc != fallback_cap) {
  4845. spec->private_capsrc_nids[0] = fallback_cap;
  4846. spec->capsrc_nids = spec->private_adc_nids;
  4847. }
  4848. }
  4849. }
  4850. #ifdef CONFIG_SND_HDA_INPUT_BEEP
  4851. #define set_beep_amp(spec, nid, idx, dir) \
  4852. ((spec)->beep_amp = HDA_COMPOSE_AMP_VAL(nid, 3, idx, dir))
  4853. static struct snd_pci_quirk beep_white_list[] = {
  4854. SND_PCI_QUIRK(0x1043, 0x829f, "ASUS", 1),
  4855. SND_PCI_QUIRK(0x1043, 0x83ce, "EeePC", 1),
  4856. SND_PCI_QUIRK(0x8086, 0xd613, "Intel", 1),
  4857. {}
  4858. };
  4859. static inline int has_cdefine_beep(struct hda_codec *codec)
  4860. {
  4861. struct alc_spec *spec = codec->spec;
  4862. const struct snd_pci_quirk *q;
  4863. q = snd_pci_quirk_lookup(codec->bus->pci, beep_white_list);
  4864. if (q)
  4865. return q->value;
  4866. return spec->cdefine.enable_pcbeep;
  4867. }
  4868. #else
  4869. #define set_beep_amp(spec, nid, idx, dir) /* NOP */
  4870. #define has_cdefine_beep(codec) 0
  4871. #endif
  4872. /*
  4873. * OK, here we have finally the patch for ALC880
  4874. */
  4875. static int patch_alc880(struct hda_codec *codec)
  4876. {
  4877. struct alc_spec *spec;
  4878. int board_config;
  4879. int err;
  4880. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  4881. if (spec == NULL)
  4882. return -ENOMEM;
  4883. codec->spec = spec;
  4884. board_config = snd_hda_check_board_config(codec, ALC880_MODEL_LAST,
  4885. alc880_models,
  4886. alc880_cfg_tbl);
  4887. if (board_config < 0) {
  4888. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  4889. codec->chip_name);
  4890. board_config = ALC880_AUTO;
  4891. }
  4892. if (board_config == ALC880_AUTO) {
  4893. /* automatic parse from the BIOS config */
  4894. err = alc880_parse_auto_config(codec);
  4895. if (err < 0) {
  4896. alc_free(codec);
  4897. return err;
  4898. } else if (!err) {
  4899. printk(KERN_INFO
  4900. "hda_codec: Cannot set up configuration "
  4901. "from BIOS. Using 3-stack mode...\n");
  4902. board_config = ALC880_3ST;
  4903. }
  4904. }
  4905. err = snd_hda_attach_beep_device(codec, 0x1);
  4906. if (err < 0) {
  4907. alc_free(codec);
  4908. return err;
  4909. }
  4910. if (board_config != ALC880_AUTO)
  4911. setup_preset(codec, &alc880_presets[board_config]);
  4912. spec->stream_analog_playback = &alc880_pcm_analog_playback;
  4913. spec->stream_analog_capture = &alc880_pcm_analog_capture;
  4914. spec->stream_analog_alt_capture = &alc880_pcm_analog_alt_capture;
  4915. spec->stream_digital_playback = &alc880_pcm_digital_playback;
  4916. spec->stream_digital_capture = &alc880_pcm_digital_capture;
  4917. if (!spec->adc_nids && spec->input_mux) {
  4918. /* check whether NID 0x07 is valid */
  4919. unsigned int wcap = get_wcaps(codec, alc880_adc_nids[0]);
  4920. /* get type */
  4921. wcap = get_wcaps_type(wcap);
  4922. if (wcap != AC_WID_AUD_IN) {
  4923. spec->adc_nids = alc880_adc_nids_alt;
  4924. spec->num_adc_nids = ARRAY_SIZE(alc880_adc_nids_alt);
  4925. } else {
  4926. spec->adc_nids = alc880_adc_nids;
  4927. spec->num_adc_nids = ARRAY_SIZE(alc880_adc_nids);
  4928. }
  4929. }
  4930. set_capture_mixer(codec);
  4931. set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT);
  4932. spec->vmaster_nid = 0x0c;
  4933. codec->patch_ops = alc_patch_ops;
  4934. if (board_config == ALC880_AUTO)
  4935. spec->init_hook = alc880_auto_init;
  4936. #ifdef CONFIG_SND_HDA_POWER_SAVE
  4937. if (!spec->loopback.amplist)
  4938. spec->loopback.amplist = alc880_loopbacks;
  4939. #endif
  4940. return 0;
  4941. }
  4942. /*
  4943. * ALC260 support
  4944. */
  4945. static hda_nid_t alc260_dac_nids[1] = {
  4946. /* front */
  4947. 0x02,
  4948. };
  4949. static hda_nid_t alc260_adc_nids[1] = {
  4950. /* ADC0 */
  4951. 0x04,
  4952. };
  4953. static hda_nid_t alc260_adc_nids_alt[1] = {
  4954. /* ADC1 */
  4955. 0x05,
  4956. };
  4957. /* NIDs used when simultaneous access to both ADCs makes sense. Note that
  4958. * alc260_capture_mixer assumes ADC0 (nid 0x04) is the first ADC.
  4959. */
  4960. static hda_nid_t alc260_dual_adc_nids[2] = {
  4961. /* ADC0, ADC1 */
  4962. 0x04, 0x05
  4963. };
  4964. #define ALC260_DIGOUT_NID 0x03
  4965. #define ALC260_DIGIN_NID 0x06
  4966. static struct hda_input_mux alc260_capture_source = {
  4967. .num_items = 4,
  4968. .items = {
  4969. { "Mic", 0x0 },
  4970. { "Front Mic", 0x1 },
  4971. { "Line", 0x2 },
  4972. { "CD", 0x4 },
  4973. },
  4974. };
  4975. /* On Fujitsu S702x laptops capture only makes sense from Mic/LineIn jack,
  4976. * headphone jack and the internal CD lines since these are the only pins at
  4977. * which audio can appear. For flexibility, also allow the option of
  4978. * recording the mixer output on the second ADC (ADC0 doesn't have a
  4979. * connection to the mixer output).
  4980. */
  4981. static struct hda_input_mux alc260_fujitsu_capture_sources[2] = {
  4982. {
  4983. .num_items = 3,
  4984. .items = {
  4985. { "Mic/Line", 0x0 },
  4986. { "CD", 0x4 },
  4987. { "Headphone", 0x2 },
  4988. },
  4989. },
  4990. {
  4991. .num_items = 4,
  4992. .items = {
  4993. { "Mic/Line", 0x0 },
  4994. { "CD", 0x4 },
  4995. { "Headphone", 0x2 },
  4996. { "Mixer", 0x5 },
  4997. },
  4998. },
  4999. };
  5000. /* Acer TravelMate(/Extensa/Aspire) notebooks have similar configuration to
  5001. * the Fujitsu S702x, but jacks are marked differently.
  5002. */
  5003. static struct hda_input_mux alc260_acer_capture_sources[2] = {
  5004. {
  5005. .num_items = 4,
  5006. .items = {
  5007. { "Mic", 0x0 },
  5008. { "Line", 0x2 },
  5009. { "CD", 0x4 },
  5010. { "Headphone", 0x5 },
  5011. },
  5012. },
  5013. {
  5014. .num_items = 5,
  5015. .items = {
  5016. { "Mic", 0x0 },
  5017. { "Line", 0x2 },
  5018. { "CD", 0x4 },
  5019. { "Headphone", 0x6 },
  5020. { "Mixer", 0x5 },
  5021. },
  5022. },
  5023. };
  5024. /* Maxdata Favorit 100XS */
  5025. static struct hda_input_mux alc260_favorit100_capture_sources[2] = {
  5026. {
  5027. .num_items = 2,
  5028. .items = {
  5029. { "Line/Mic", 0x0 },
  5030. { "CD", 0x4 },
  5031. },
  5032. },
  5033. {
  5034. .num_items = 3,
  5035. .items = {
  5036. { "Line/Mic", 0x0 },
  5037. { "CD", 0x4 },
  5038. { "Mixer", 0x5 },
  5039. },
  5040. },
  5041. };
  5042. /*
  5043. * This is just place-holder, so there's something for alc_build_pcms to look
  5044. * at when it calculates the maximum number of channels. ALC260 has no mixer
  5045. * element which allows changing the channel mode, so the verb list is
  5046. * never used.
  5047. */
  5048. static struct hda_channel_mode alc260_modes[1] = {
  5049. { 2, NULL },
  5050. };
  5051. /* Mixer combinations
  5052. *
  5053. * basic: base_output + input + pc_beep + capture
  5054. * HP: base_output + input + capture_alt
  5055. * HP_3013: hp_3013 + input + capture
  5056. * fujitsu: fujitsu + capture
  5057. * acer: acer + capture
  5058. */
  5059. static struct snd_kcontrol_new alc260_base_output_mixer[] = {
  5060. HDA_CODEC_VOLUME("Front Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5061. HDA_BIND_MUTE("Front Playback Switch", 0x08, 2, HDA_INPUT),
  5062. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x09, 0x0, HDA_OUTPUT),
  5063. HDA_BIND_MUTE("Headphone Playback Switch", 0x09, 2, HDA_INPUT),
  5064. HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x0a, 1, 0x0, HDA_OUTPUT),
  5065. HDA_BIND_MUTE_MONO("Mono Playback Switch", 0x0a, 1, 2, HDA_INPUT),
  5066. { } /* end */
  5067. };
  5068. static struct snd_kcontrol_new alc260_input_mixer[] = {
  5069. HDA_CODEC_VOLUME("CD Playback Volume", 0x07, 0x04, HDA_INPUT),
  5070. HDA_CODEC_MUTE("CD Playback Switch", 0x07, 0x04, HDA_INPUT),
  5071. HDA_CODEC_VOLUME("Line Playback Volume", 0x07, 0x02, HDA_INPUT),
  5072. HDA_CODEC_MUTE("Line Playback Switch", 0x07, 0x02, HDA_INPUT),
  5073. HDA_CODEC_VOLUME("Mic Playback Volume", 0x07, 0x0, HDA_INPUT),
  5074. HDA_CODEC_MUTE("Mic Playback Switch", 0x07, 0x0, HDA_INPUT),
  5075. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x07, 0x01, HDA_INPUT),
  5076. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x07, 0x01, HDA_INPUT),
  5077. { } /* end */
  5078. };
  5079. /* update HP, line and mono out pins according to the master switch */
  5080. static void alc260_hp_master_update(struct hda_codec *codec,
  5081. hda_nid_t hp, hda_nid_t line,
  5082. hda_nid_t mono)
  5083. {
  5084. struct alc_spec *spec = codec->spec;
  5085. unsigned int val = spec->master_sw ? PIN_HP : 0;
  5086. /* change HP and line-out pins */
  5087. snd_hda_codec_write(codec, hp, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  5088. val);
  5089. snd_hda_codec_write(codec, line, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  5090. val);
  5091. /* mono (speaker) depending on the HP jack sense */
  5092. val = (val && !spec->jack_present) ? PIN_OUT : 0;
  5093. snd_hda_codec_write(codec, mono, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  5094. val);
  5095. }
  5096. static int alc260_hp_master_sw_get(struct snd_kcontrol *kcontrol,
  5097. struct snd_ctl_elem_value *ucontrol)
  5098. {
  5099. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  5100. struct alc_spec *spec = codec->spec;
  5101. *ucontrol->value.integer.value = spec->master_sw;
  5102. return 0;
  5103. }
  5104. static int alc260_hp_master_sw_put(struct snd_kcontrol *kcontrol,
  5105. struct snd_ctl_elem_value *ucontrol)
  5106. {
  5107. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  5108. struct alc_spec *spec = codec->spec;
  5109. int val = !!*ucontrol->value.integer.value;
  5110. hda_nid_t hp, line, mono;
  5111. if (val == spec->master_sw)
  5112. return 0;
  5113. spec->master_sw = val;
  5114. hp = (kcontrol->private_value >> 16) & 0xff;
  5115. line = (kcontrol->private_value >> 8) & 0xff;
  5116. mono = kcontrol->private_value & 0xff;
  5117. alc260_hp_master_update(codec, hp, line, mono);
  5118. return 1;
  5119. }
  5120. static struct snd_kcontrol_new alc260_hp_output_mixer[] = {
  5121. {
  5122. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  5123. .name = "Master Playback Switch",
  5124. .subdevice = HDA_SUBDEV_NID_FLAG | 0x11,
  5125. .info = snd_ctl_boolean_mono_info,
  5126. .get = alc260_hp_master_sw_get,
  5127. .put = alc260_hp_master_sw_put,
  5128. .private_value = (0x0f << 16) | (0x10 << 8) | 0x11
  5129. },
  5130. HDA_CODEC_VOLUME("Front Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5131. HDA_BIND_MUTE("Front Playback Switch", 0x08, 2, HDA_INPUT),
  5132. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x09, 0x0, HDA_OUTPUT),
  5133. HDA_BIND_MUTE("Headphone Playback Switch", 0x09, 2, HDA_INPUT),
  5134. HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0a, 1, 0x0,
  5135. HDA_OUTPUT),
  5136. HDA_BIND_MUTE_MONO("Speaker Playback Switch", 0x0a, 1, 2, HDA_INPUT),
  5137. { } /* end */
  5138. };
  5139. static struct hda_verb alc260_hp_unsol_verbs[] = {
  5140. {0x10, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  5141. {},
  5142. };
  5143. static void alc260_hp_automute(struct hda_codec *codec)
  5144. {
  5145. struct alc_spec *spec = codec->spec;
  5146. spec->jack_present = snd_hda_jack_detect(codec, 0x10);
  5147. alc260_hp_master_update(codec, 0x0f, 0x10, 0x11);
  5148. }
  5149. static void alc260_hp_unsol_event(struct hda_codec *codec, unsigned int res)
  5150. {
  5151. if ((res >> 26) == ALC880_HP_EVENT)
  5152. alc260_hp_automute(codec);
  5153. }
  5154. static struct snd_kcontrol_new alc260_hp_3013_mixer[] = {
  5155. {
  5156. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  5157. .name = "Master Playback Switch",
  5158. .subdevice = HDA_SUBDEV_NID_FLAG | 0x11,
  5159. .info = snd_ctl_boolean_mono_info,
  5160. .get = alc260_hp_master_sw_get,
  5161. .put = alc260_hp_master_sw_put,
  5162. .private_value = (0x15 << 16) | (0x10 << 8) | 0x11
  5163. },
  5164. HDA_CODEC_VOLUME("Front Playback Volume", 0x09, 0x0, HDA_OUTPUT),
  5165. HDA_CODEC_MUTE("Front Playback Switch", 0x10, 0x0, HDA_OUTPUT),
  5166. HDA_CODEC_VOLUME("Aux-In Playback Volume", 0x07, 0x06, HDA_INPUT),
  5167. HDA_CODEC_MUTE("Aux-In Playback Switch", 0x07, 0x06, HDA_INPUT),
  5168. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5169. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  5170. HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0a, 1, 0x0, HDA_OUTPUT),
  5171. HDA_CODEC_MUTE_MONO("Speaker Playback Switch", 0x11, 1, 0x0, HDA_OUTPUT),
  5172. { } /* end */
  5173. };
  5174. static struct hda_bind_ctls alc260_dc7600_bind_master_vol = {
  5175. .ops = &snd_hda_bind_vol,
  5176. .values = {
  5177. HDA_COMPOSE_AMP_VAL(0x08, 3, 0, HDA_OUTPUT),
  5178. HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_OUTPUT),
  5179. HDA_COMPOSE_AMP_VAL(0x0a, 3, 0, HDA_OUTPUT),
  5180. 0
  5181. },
  5182. };
  5183. static struct hda_bind_ctls alc260_dc7600_bind_switch = {
  5184. .ops = &snd_hda_bind_sw,
  5185. .values = {
  5186. HDA_COMPOSE_AMP_VAL(0x11, 3, 0, HDA_OUTPUT),
  5187. HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
  5188. 0
  5189. },
  5190. };
  5191. static struct snd_kcontrol_new alc260_hp_dc7600_mixer[] = {
  5192. HDA_BIND_VOL("Master Playback Volume", &alc260_dc7600_bind_master_vol),
  5193. HDA_BIND_SW("LineOut Playback Switch", &alc260_dc7600_bind_switch),
  5194. HDA_CODEC_MUTE("Speaker Playback Switch", 0x0f, 0x0, HDA_OUTPUT),
  5195. HDA_CODEC_MUTE("Headphone Playback Switch", 0x10, 0x0, HDA_OUTPUT),
  5196. { } /* end */
  5197. };
  5198. static struct hda_verb alc260_hp_3013_unsol_verbs[] = {
  5199. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  5200. {},
  5201. };
  5202. static void alc260_hp_3013_automute(struct hda_codec *codec)
  5203. {
  5204. struct alc_spec *spec = codec->spec;
  5205. spec->jack_present = snd_hda_jack_detect(codec, 0x15);
  5206. alc260_hp_master_update(codec, 0x15, 0x10, 0x11);
  5207. }
  5208. static void alc260_hp_3013_unsol_event(struct hda_codec *codec,
  5209. unsigned int res)
  5210. {
  5211. if ((res >> 26) == ALC880_HP_EVENT)
  5212. alc260_hp_3013_automute(codec);
  5213. }
  5214. static void alc260_hp_3012_automute(struct hda_codec *codec)
  5215. {
  5216. unsigned int bits = snd_hda_jack_detect(codec, 0x10) ? 0 : PIN_OUT;
  5217. snd_hda_codec_write(codec, 0x0f, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  5218. bits);
  5219. snd_hda_codec_write(codec, 0x11, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  5220. bits);
  5221. snd_hda_codec_write(codec, 0x15, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  5222. bits);
  5223. }
  5224. static void alc260_hp_3012_unsol_event(struct hda_codec *codec,
  5225. unsigned int res)
  5226. {
  5227. if ((res >> 26) == ALC880_HP_EVENT)
  5228. alc260_hp_3012_automute(codec);
  5229. }
  5230. /* Fujitsu S702x series laptops. ALC260 pin usage: Mic/Line jack = 0x12,
  5231. * HP jack = 0x14, CD audio = 0x16, internal speaker = 0x10.
  5232. */
  5233. static struct snd_kcontrol_new alc260_fujitsu_mixer[] = {
  5234. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5235. HDA_BIND_MUTE("Headphone Playback Switch", 0x08, 2, HDA_INPUT),
  5236. ALC_PIN_MODE("Headphone Jack Mode", 0x14, ALC_PIN_DIR_INOUT),
  5237. HDA_CODEC_VOLUME("CD Playback Volume", 0x07, 0x04, HDA_INPUT),
  5238. HDA_CODEC_MUTE("CD Playback Switch", 0x07, 0x04, HDA_INPUT),
  5239. HDA_CODEC_VOLUME("Mic/Line Playback Volume", 0x07, 0x0, HDA_INPUT),
  5240. HDA_CODEC_MUTE("Mic/Line Playback Switch", 0x07, 0x0, HDA_INPUT),
  5241. ALC_PIN_MODE("Mic/Line Jack Mode", 0x12, ALC_PIN_DIR_IN),
  5242. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x09, 0x0, HDA_OUTPUT),
  5243. HDA_BIND_MUTE("Speaker Playback Switch", 0x09, 2, HDA_INPUT),
  5244. { } /* end */
  5245. };
  5246. /* Mixer for Acer TravelMate(/Extensa/Aspire) notebooks. Note that current
  5247. * versions of the ALC260 don't act on requests to enable mic bias from NID
  5248. * 0x0f (used to drive the headphone jack in these laptops). The ALC260
  5249. * datasheet doesn't mention this restriction. At this stage it's not clear
  5250. * whether this behaviour is intentional or is a hardware bug in chip
  5251. * revisions available in early 2006. Therefore for now allow the
  5252. * "Headphone Jack Mode" control to span all choices, but if it turns out
  5253. * that the lack of mic bias for this NID is intentional we could change the
  5254. * mode from ALC_PIN_DIR_INOUT to ALC_PIN_DIR_INOUT_NOMICBIAS.
  5255. *
  5256. * In addition, Acer TravelMate(/Extensa/Aspire) notebooks in early 2006
  5257. * don't appear to make the mic bias available from the "line" jack, even
  5258. * though the NID used for this jack (0x14) can supply it. The theory is
  5259. * that perhaps Acer have included blocking capacitors between the ALC260
  5260. * and the output jack. If this turns out to be the case for all such
  5261. * models the "Line Jack Mode" mode could be changed from ALC_PIN_DIR_INOUT
  5262. * to ALC_PIN_DIR_INOUT_NOMICBIAS.
  5263. *
  5264. * The C20x Tablet series have a mono internal speaker which is controlled
  5265. * via the chip's Mono sum widget and pin complex, so include the necessary
  5266. * controls for such models. On models without a "mono speaker" the control
  5267. * won't do anything.
  5268. */
  5269. static struct snd_kcontrol_new alc260_acer_mixer[] = {
  5270. HDA_CODEC_VOLUME("Master Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5271. HDA_BIND_MUTE("Master Playback Switch", 0x08, 2, HDA_INPUT),
  5272. ALC_PIN_MODE("Headphone Jack Mode", 0x0f, ALC_PIN_DIR_INOUT),
  5273. HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0a, 1, 0x0,
  5274. HDA_OUTPUT),
  5275. HDA_BIND_MUTE_MONO("Speaker Playback Switch", 0x0a, 1, 2,
  5276. HDA_INPUT),
  5277. HDA_CODEC_VOLUME("CD Playback Volume", 0x07, 0x04, HDA_INPUT),
  5278. HDA_CODEC_MUTE("CD Playback Switch", 0x07, 0x04, HDA_INPUT),
  5279. HDA_CODEC_VOLUME("Mic Playback Volume", 0x07, 0x0, HDA_INPUT),
  5280. HDA_CODEC_MUTE("Mic Playback Switch", 0x07, 0x0, HDA_INPUT),
  5281. ALC_PIN_MODE("Mic Jack Mode", 0x12, ALC_PIN_DIR_IN),
  5282. HDA_CODEC_VOLUME("Line Playback Volume", 0x07, 0x02, HDA_INPUT),
  5283. HDA_CODEC_MUTE("Line Playback Switch", 0x07, 0x02, HDA_INPUT),
  5284. ALC_PIN_MODE("Line Jack Mode", 0x14, ALC_PIN_DIR_INOUT),
  5285. { } /* end */
  5286. };
  5287. /* Maxdata Favorit 100XS: one output and one input (0x12) jack
  5288. */
  5289. static struct snd_kcontrol_new alc260_favorit100_mixer[] = {
  5290. HDA_CODEC_VOLUME("Master Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5291. HDA_BIND_MUTE("Master Playback Switch", 0x08, 2, HDA_INPUT),
  5292. ALC_PIN_MODE("Output Jack Mode", 0x0f, ALC_PIN_DIR_INOUT),
  5293. HDA_CODEC_VOLUME("Line/Mic Playback Volume", 0x07, 0x0, HDA_INPUT),
  5294. HDA_CODEC_MUTE("Line/Mic Playback Switch", 0x07, 0x0, HDA_INPUT),
  5295. ALC_PIN_MODE("Line/Mic Jack Mode", 0x12, ALC_PIN_DIR_IN),
  5296. { } /* end */
  5297. };
  5298. /* Packard bell V7900 ALC260 pin usage: HP = 0x0f, Mic jack = 0x12,
  5299. * Line In jack = 0x14, CD audio = 0x16, pc beep = 0x17.
  5300. */
  5301. static struct snd_kcontrol_new alc260_will_mixer[] = {
  5302. HDA_CODEC_VOLUME("Master Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5303. HDA_BIND_MUTE("Master Playback Switch", 0x08, 0x2, HDA_INPUT),
  5304. HDA_CODEC_VOLUME("Mic Playback Volume", 0x07, 0x0, HDA_INPUT),
  5305. HDA_CODEC_MUTE("Mic Playback Switch", 0x07, 0x0, HDA_INPUT),
  5306. ALC_PIN_MODE("Mic Jack Mode", 0x12, ALC_PIN_DIR_IN),
  5307. HDA_CODEC_VOLUME("Line Playback Volume", 0x07, 0x02, HDA_INPUT),
  5308. HDA_CODEC_MUTE("Line Playback Switch", 0x07, 0x02, HDA_INPUT),
  5309. ALC_PIN_MODE("Line Jack Mode", 0x14, ALC_PIN_DIR_INOUT),
  5310. HDA_CODEC_VOLUME("CD Playback Volume", 0x07, 0x04, HDA_INPUT),
  5311. HDA_CODEC_MUTE("CD Playback Switch", 0x07, 0x04, HDA_INPUT),
  5312. { } /* end */
  5313. };
  5314. /* Replacer 672V ALC260 pin usage: Mic jack = 0x12,
  5315. * Line In jack = 0x14, ATAPI Mic = 0x13, speaker = 0x0f.
  5316. */
  5317. static struct snd_kcontrol_new alc260_replacer_672v_mixer[] = {
  5318. HDA_CODEC_VOLUME("Master Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5319. HDA_BIND_MUTE("Master Playback Switch", 0x08, 0x2, HDA_INPUT),
  5320. HDA_CODEC_VOLUME("Mic Playback Volume", 0x07, 0x0, HDA_INPUT),
  5321. HDA_CODEC_MUTE("Mic Playback Switch", 0x07, 0x0, HDA_INPUT),
  5322. ALC_PIN_MODE("Mic Jack Mode", 0x12, ALC_PIN_DIR_IN),
  5323. HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x07, 0x1, HDA_INPUT),
  5324. HDA_CODEC_MUTE("ATATI Mic Playback Switch", 0x07, 0x1, HDA_INPUT),
  5325. HDA_CODEC_VOLUME("Line Playback Volume", 0x07, 0x02, HDA_INPUT),
  5326. HDA_CODEC_MUTE("Line Playback Switch", 0x07, 0x02, HDA_INPUT),
  5327. ALC_PIN_MODE("Line Jack Mode", 0x14, ALC_PIN_DIR_INOUT),
  5328. { } /* end */
  5329. };
  5330. /*
  5331. * initialization verbs
  5332. */
  5333. static struct hda_verb alc260_init_verbs[] = {
  5334. /* Line In pin widget for input */
  5335. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  5336. /* CD pin widget for input */
  5337. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  5338. /* Mic1 (rear panel) pin widget for input and vref at 80% */
  5339. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  5340. /* Mic2 (front panel) pin widget for input and vref at 80% */
  5341. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  5342. /* LINE-2 is used for line-out in rear */
  5343. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5344. /* select line-out */
  5345. {0x0e, AC_VERB_SET_CONNECT_SEL, 0x00},
  5346. /* LINE-OUT pin */
  5347. {0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5348. /* enable HP */
  5349. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  5350. /* enable Mono */
  5351. {0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5352. /* mute capture amp left and right */
  5353. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  5354. /* set connection select to line in (default select for this ADC) */
  5355. {0x04, AC_VERB_SET_CONNECT_SEL, 0x02},
  5356. /* mute capture amp left and right */
  5357. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  5358. /* set connection select to line in (default select for this ADC) */
  5359. {0x05, AC_VERB_SET_CONNECT_SEL, 0x02},
  5360. /* set vol=0 Line-Out mixer amp left and right */
  5361. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5362. /* unmute pin widget amp left and right (no gain on this amp) */
  5363. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5364. /* set vol=0 HP mixer amp left and right */
  5365. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5366. /* unmute pin widget amp left and right (no gain on this amp) */
  5367. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5368. /* set vol=0 Mono mixer amp left and right */
  5369. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5370. /* unmute pin widget amp left and right (no gain on this amp) */
  5371. {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5372. /* unmute LINE-2 out pin */
  5373. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5374. /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 &
  5375. * Line In 2 = 0x03
  5376. */
  5377. /* mute analog inputs */
  5378. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5379. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5380. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  5381. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  5382. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  5383. /* Amp Indexes: DAC = 0x01 & mixer = 0x00 */
  5384. /* mute Front out path */
  5385. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5386. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5387. /* mute Headphone out path */
  5388. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5389. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5390. /* mute Mono out path */
  5391. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5392. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5393. { }
  5394. };
  5395. #if 0 /* should be identical with alc260_init_verbs? */
  5396. static struct hda_verb alc260_hp_init_verbs[] = {
  5397. /* Headphone and output */
  5398. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  5399. /* mono output */
  5400. {0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  5401. /* Mic1 (rear panel) pin widget for input and vref at 80% */
  5402. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  5403. /* Mic2 (front panel) pin widget for input and vref at 80% */
  5404. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  5405. /* Line In pin widget for input */
  5406. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  5407. /* Line-2 pin widget for output */
  5408. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  5409. /* CD pin widget for input */
  5410. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  5411. /* unmute amp left and right */
  5412. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000},
  5413. /* set connection select to line in (default select for this ADC) */
  5414. {0x04, AC_VERB_SET_CONNECT_SEL, 0x02},
  5415. /* unmute Line-Out mixer amp left and right (volume = 0) */
  5416. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
  5417. /* mute pin widget amp left and right (no gain on this amp) */
  5418. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  5419. /* unmute HP mixer amp left and right (volume = 0) */
  5420. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
  5421. /* mute pin widget amp left and right (no gain on this amp) */
  5422. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  5423. /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 &
  5424. * Line In 2 = 0x03
  5425. */
  5426. /* mute analog inputs */
  5427. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5428. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5429. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  5430. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  5431. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  5432. /* Amp Indexes: DAC = 0x01 & mixer = 0x00 */
  5433. /* Unmute Front out path */
  5434. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  5435. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  5436. /* Unmute Headphone out path */
  5437. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  5438. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  5439. /* Unmute Mono out path */
  5440. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  5441. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  5442. { }
  5443. };
  5444. #endif
  5445. static struct hda_verb alc260_hp_3013_init_verbs[] = {
  5446. /* Line out and output */
  5447. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  5448. /* mono output */
  5449. {0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  5450. /* Mic1 (rear panel) pin widget for input and vref at 80% */
  5451. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  5452. /* Mic2 (front panel) pin widget for input and vref at 80% */
  5453. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  5454. /* Line In pin widget for input */
  5455. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  5456. /* Headphone pin widget for output */
  5457. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  5458. /* CD pin widget for input */
  5459. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  5460. /* unmute amp left and right */
  5461. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000},
  5462. /* set connection select to line in (default select for this ADC) */
  5463. {0x04, AC_VERB_SET_CONNECT_SEL, 0x02},
  5464. /* unmute Line-Out mixer amp left and right (volume = 0) */
  5465. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
  5466. /* mute pin widget amp left and right (no gain on this amp) */
  5467. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  5468. /* unmute HP mixer amp left and right (volume = 0) */
  5469. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
  5470. /* mute pin widget amp left and right (no gain on this amp) */
  5471. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  5472. /* Amp Indexes: CD = 0x04, Line In 1 = 0x02, Mic 1 = 0x00 &
  5473. * Line In 2 = 0x03
  5474. */
  5475. /* mute analog inputs */
  5476. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5477. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5478. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  5479. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  5480. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  5481. /* Amp Indexes: DAC = 0x01 & mixer = 0x00 */
  5482. /* Unmute Front out path */
  5483. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  5484. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  5485. /* Unmute Headphone out path */
  5486. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  5487. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  5488. /* Unmute Mono out path */
  5489. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  5490. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  5491. { }
  5492. };
  5493. /* Initialisation sequence for ALC260 as configured in Fujitsu S702x
  5494. * laptops. ALC260 pin usage: Mic/Line jack = 0x12, HP jack = 0x14, CD
  5495. * audio = 0x16, internal speaker = 0x10.
  5496. */
  5497. static struct hda_verb alc260_fujitsu_init_verbs[] = {
  5498. /* Disable all GPIOs */
  5499. {0x01, AC_VERB_SET_GPIO_MASK, 0},
  5500. /* Internal speaker is connected to headphone pin */
  5501. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  5502. /* Headphone/Line-out jack connects to Line1 pin; make it an output */
  5503. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5504. /* Mic/Line-in jack is connected to mic1 pin, so make it an input */
  5505. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  5506. /* Ensure all other unused pins are disabled and muted. */
  5507. {0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5508. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5509. {0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5510. {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5511. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5512. {0x13, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5513. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5514. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5515. /* Disable digital (SPDIF) pins */
  5516. {0x03, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5517. {0x06, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5518. /* Ensure Line1 pin widget takes its input from the OUT1 sum bus
  5519. * when acting as an output.
  5520. */
  5521. {0x0d, AC_VERB_SET_CONNECT_SEL, 0},
  5522. /* Start with output sum widgets muted and their output gains at min */
  5523. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5524. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5525. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5526. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5527. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5528. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5529. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5530. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5531. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5532. /* Unmute HP pin widget amp left and right (no equiv mixer ctrl) */
  5533. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5534. /* Unmute Line1 pin widget output buffer since it starts as an output.
  5535. * If the pin mode is changed by the user the pin mode control will
  5536. * take care of enabling the pin's input/output buffers as needed.
  5537. * Therefore there's no need to enable the input buffer at this
  5538. * stage.
  5539. */
  5540. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5541. /* Unmute input buffer of pin widget used for Line-in (no equiv
  5542. * mixer ctrl)
  5543. */
  5544. {0x12, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  5545. /* Mute capture amp left and right */
  5546. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5547. /* Set ADC connection select to match default mixer setting - line
  5548. * in (on mic1 pin)
  5549. */
  5550. {0x04, AC_VERB_SET_CONNECT_SEL, 0x00},
  5551. /* Do the same for the second ADC: mute capture input amp and
  5552. * set ADC connection to line in (on mic1 pin)
  5553. */
  5554. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5555. {0x05, AC_VERB_SET_CONNECT_SEL, 0x00},
  5556. /* Mute all inputs to mixer widget (even unconnected ones) */
  5557. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, /* mic1 pin */
  5558. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, /* mic2 pin */
  5559. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)}, /* line1 pin */
  5560. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)}, /* line2 pin */
  5561. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)}, /* CD pin */
  5562. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)}, /* Beep-gen pin */
  5563. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)}, /* Line-out pin */
  5564. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)}, /* HP-pin pin */
  5565. { }
  5566. };
  5567. /* Initialisation sequence for ALC260 as configured in Acer TravelMate and
  5568. * similar laptops (adapted from Fujitsu init verbs).
  5569. */
  5570. static struct hda_verb alc260_acer_init_verbs[] = {
  5571. /* On TravelMate laptops, GPIO 0 enables the internal speaker and
  5572. * the headphone jack. Turn this on and rely on the standard mute
  5573. * methods whenever the user wants to turn these outputs off.
  5574. */
  5575. {0x01, AC_VERB_SET_GPIO_MASK, 0x01},
  5576. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x01},
  5577. {0x01, AC_VERB_SET_GPIO_DATA, 0x01},
  5578. /* Internal speaker/Headphone jack is connected to Line-out pin */
  5579. {0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  5580. /* Internal microphone/Mic jack is connected to Mic1 pin */
  5581. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
  5582. /* Line In jack is connected to Line1 pin */
  5583. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  5584. /* Some Acers (eg: C20x Tablets) use Mono pin for internal speaker */
  5585. {0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  5586. /* Ensure all other unused pins are disabled and muted. */
  5587. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5588. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5589. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5590. {0x13, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5591. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5592. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5593. /* Disable digital (SPDIF) pins */
  5594. {0x03, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5595. {0x06, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5596. /* Ensure Mic1 and Line1 pin widgets take input from the OUT1 sum
  5597. * bus when acting as outputs.
  5598. */
  5599. {0x0b, AC_VERB_SET_CONNECT_SEL, 0},
  5600. {0x0d, AC_VERB_SET_CONNECT_SEL, 0},
  5601. /* Start with output sum widgets muted and their output gains at min */
  5602. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5603. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5604. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5605. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5606. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5607. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5608. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5609. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5610. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5611. /* Unmute Line-out pin widget amp left and right
  5612. * (no equiv mixer ctrl)
  5613. */
  5614. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5615. /* Unmute mono pin widget amp output (no equiv mixer ctrl) */
  5616. {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5617. /* Unmute Mic1 and Line1 pin widget input buffers since they start as
  5618. * inputs. If the pin mode is changed by the user the pin mode control
  5619. * will take care of enabling the pin's input/output buffers as needed.
  5620. * Therefore there's no need to enable the input buffer at this
  5621. * stage.
  5622. */
  5623. {0x12, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  5624. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  5625. /* Mute capture amp left and right */
  5626. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5627. /* Set ADC connection select to match default mixer setting - mic
  5628. * (on mic1 pin)
  5629. */
  5630. {0x04, AC_VERB_SET_CONNECT_SEL, 0x00},
  5631. /* Do similar with the second ADC: mute capture input amp and
  5632. * set ADC connection to mic to match ALSA's default state.
  5633. */
  5634. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5635. {0x05, AC_VERB_SET_CONNECT_SEL, 0x00},
  5636. /* Mute all inputs to mixer widget (even unconnected ones) */
  5637. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, /* mic1 pin */
  5638. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, /* mic2 pin */
  5639. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)}, /* line1 pin */
  5640. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)}, /* line2 pin */
  5641. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)}, /* CD pin */
  5642. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)}, /* Beep-gen pin */
  5643. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)}, /* Line-out pin */
  5644. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)}, /* HP-pin pin */
  5645. { }
  5646. };
  5647. /* Initialisation sequence for Maxdata Favorit 100XS
  5648. * (adapted from Acer init verbs).
  5649. */
  5650. static struct hda_verb alc260_favorit100_init_verbs[] = {
  5651. /* GPIO 0 enables the output jack.
  5652. * Turn this on and rely on the standard mute
  5653. * methods whenever the user wants to turn these outputs off.
  5654. */
  5655. {0x01, AC_VERB_SET_GPIO_MASK, 0x01},
  5656. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x01},
  5657. {0x01, AC_VERB_SET_GPIO_DATA, 0x01},
  5658. /* Line/Mic input jack is connected to Mic1 pin */
  5659. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
  5660. /* Ensure all other unused pins are disabled and muted. */
  5661. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5662. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5663. {0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5664. {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5665. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5666. {0x13, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5667. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5668. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5669. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0},
  5670. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5671. /* Disable digital (SPDIF) pins */
  5672. {0x03, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5673. {0x06, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5674. /* Ensure Mic1 and Line1 pin widgets take input from the OUT1 sum
  5675. * bus when acting as outputs.
  5676. */
  5677. {0x0b, AC_VERB_SET_CONNECT_SEL, 0},
  5678. {0x0d, AC_VERB_SET_CONNECT_SEL, 0},
  5679. /* Start with output sum widgets muted and their output gains at min */
  5680. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5681. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5682. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5683. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5684. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5685. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5686. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5687. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5688. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5689. /* Unmute Line-out pin widget amp left and right
  5690. * (no equiv mixer ctrl)
  5691. */
  5692. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5693. /* Unmute Mic1 and Line1 pin widget input buffers since they start as
  5694. * inputs. If the pin mode is changed by the user the pin mode control
  5695. * will take care of enabling the pin's input/output buffers as needed.
  5696. * Therefore there's no need to enable the input buffer at this
  5697. * stage.
  5698. */
  5699. {0x12, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  5700. /* Mute capture amp left and right */
  5701. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5702. /* Set ADC connection select to match default mixer setting - mic
  5703. * (on mic1 pin)
  5704. */
  5705. {0x04, AC_VERB_SET_CONNECT_SEL, 0x00},
  5706. /* Do similar with the second ADC: mute capture input amp and
  5707. * set ADC connection to mic to match ALSA's default state.
  5708. */
  5709. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5710. {0x05, AC_VERB_SET_CONNECT_SEL, 0x00},
  5711. /* Mute all inputs to mixer widget (even unconnected ones) */
  5712. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, /* mic1 pin */
  5713. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, /* mic2 pin */
  5714. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)}, /* line1 pin */
  5715. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)}, /* line2 pin */
  5716. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)}, /* CD pin */
  5717. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)}, /* Beep-gen pin */
  5718. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)}, /* Line-out pin */
  5719. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)}, /* HP-pin pin */
  5720. { }
  5721. };
  5722. static struct hda_verb alc260_will_verbs[] = {
  5723. {0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  5724. {0x0b, AC_VERB_SET_CONNECT_SEL, 0x00},
  5725. {0x0d, AC_VERB_SET_CONNECT_SEL, 0x00},
  5726. {0x0f, AC_VERB_SET_EAPD_BTLENABLE, 0x02},
  5727. {0x1a, AC_VERB_SET_COEF_INDEX, 0x07},
  5728. {0x1a, AC_VERB_SET_PROC_COEF, 0x3040},
  5729. {}
  5730. };
  5731. static struct hda_verb alc260_replacer_672v_verbs[] = {
  5732. {0x0f, AC_VERB_SET_EAPD_BTLENABLE, 0x02},
  5733. {0x1a, AC_VERB_SET_COEF_INDEX, 0x07},
  5734. {0x1a, AC_VERB_SET_PROC_COEF, 0x3050},
  5735. {0x01, AC_VERB_SET_GPIO_MASK, 0x01},
  5736. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x01},
  5737. {0x01, AC_VERB_SET_GPIO_DATA, 0x00},
  5738. {0x0f, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  5739. {}
  5740. };
  5741. /* toggle speaker-output according to the hp-jack state */
  5742. static void alc260_replacer_672v_automute(struct hda_codec *codec)
  5743. {
  5744. unsigned int present;
  5745. /* speaker --> GPIO Data 0, hp or spdif --> GPIO data 1 */
  5746. present = snd_hda_jack_detect(codec, 0x0f);
  5747. if (present) {
  5748. snd_hda_codec_write_cache(codec, 0x01, 0,
  5749. AC_VERB_SET_GPIO_DATA, 1);
  5750. snd_hda_codec_write_cache(codec, 0x0f, 0,
  5751. AC_VERB_SET_PIN_WIDGET_CONTROL,
  5752. PIN_HP);
  5753. } else {
  5754. snd_hda_codec_write_cache(codec, 0x01, 0,
  5755. AC_VERB_SET_GPIO_DATA, 0);
  5756. snd_hda_codec_write_cache(codec, 0x0f, 0,
  5757. AC_VERB_SET_PIN_WIDGET_CONTROL,
  5758. PIN_OUT);
  5759. }
  5760. }
  5761. static void alc260_replacer_672v_unsol_event(struct hda_codec *codec,
  5762. unsigned int res)
  5763. {
  5764. if ((res >> 26) == ALC880_HP_EVENT)
  5765. alc260_replacer_672v_automute(codec);
  5766. }
  5767. static struct hda_verb alc260_hp_dc7600_verbs[] = {
  5768. {0x05, AC_VERB_SET_CONNECT_SEL, 0x01},
  5769. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  5770. {0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5771. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  5772. {0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5773. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5774. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  5775. {0x10, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  5776. {0x11, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  5777. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  5778. {}
  5779. };
  5780. /* Test configuration for debugging, modelled after the ALC880 test
  5781. * configuration.
  5782. */
  5783. #ifdef CONFIG_SND_DEBUG
  5784. static hda_nid_t alc260_test_dac_nids[1] = {
  5785. 0x02,
  5786. };
  5787. static hda_nid_t alc260_test_adc_nids[2] = {
  5788. 0x04, 0x05,
  5789. };
  5790. /* For testing the ALC260, each input MUX needs its own definition since
  5791. * the signal assignments are different. This assumes that the first ADC
  5792. * is NID 0x04.
  5793. */
  5794. static struct hda_input_mux alc260_test_capture_sources[2] = {
  5795. {
  5796. .num_items = 7,
  5797. .items = {
  5798. { "MIC1 pin", 0x0 },
  5799. { "MIC2 pin", 0x1 },
  5800. { "LINE1 pin", 0x2 },
  5801. { "LINE2 pin", 0x3 },
  5802. { "CD pin", 0x4 },
  5803. { "LINE-OUT pin", 0x5 },
  5804. { "HP-OUT pin", 0x6 },
  5805. },
  5806. },
  5807. {
  5808. .num_items = 8,
  5809. .items = {
  5810. { "MIC1 pin", 0x0 },
  5811. { "MIC2 pin", 0x1 },
  5812. { "LINE1 pin", 0x2 },
  5813. { "LINE2 pin", 0x3 },
  5814. { "CD pin", 0x4 },
  5815. { "Mixer", 0x5 },
  5816. { "LINE-OUT pin", 0x6 },
  5817. { "HP-OUT pin", 0x7 },
  5818. },
  5819. },
  5820. };
  5821. static struct snd_kcontrol_new alc260_test_mixer[] = {
  5822. /* Output driver widgets */
  5823. HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x0a, 1, 0x0, HDA_OUTPUT),
  5824. HDA_BIND_MUTE_MONO("Mono Playback Switch", 0x0a, 1, 2, HDA_INPUT),
  5825. HDA_CODEC_VOLUME("LOUT2 Playback Volume", 0x09, 0x0, HDA_OUTPUT),
  5826. HDA_BIND_MUTE("LOUT2 Playback Switch", 0x09, 2, HDA_INPUT),
  5827. HDA_CODEC_VOLUME("LOUT1 Playback Volume", 0x08, 0x0, HDA_OUTPUT),
  5828. HDA_BIND_MUTE("LOUT1 Playback Switch", 0x08, 2, HDA_INPUT),
  5829. /* Modes for retasking pin widgets
  5830. * Note: the ALC260 doesn't seem to act on requests to enable mic
  5831. * bias from NIDs 0x0f and 0x10. The ALC260 datasheet doesn't
  5832. * mention this restriction. At this stage it's not clear whether
  5833. * this behaviour is intentional or is a hardware bug in chip
  5834. * revisions available at least up until early 2006. Therefore for
  5835. * now allow the "HP-OUT" and "LINE-OUT" Mode controls to span all
  5836. * choices, but if it turns out that the lack of mic bias for these
  5837. * NIDs is intentional we could change their modes from
  5838. * ALC_PIN_DIR_INOUT to ALC_PIN_DIR_INOUT_NOMICBIAS.
  5839. */
  5840. ALC_PIN_MODE("HP-OUT pin mode", 0x10, ALC_PIN_DIR_INOUT),
  5841. ALC_PIN_MODE("LINE-OUT pin mode", 0x0f, ALC_PIN_DIR_INOUT),
  5842. ALC_PIN_MODE("LINE2 pin mode", 0x15, ALC_PIN_DIR_INOUT),
  5843. ALC_PIN_MODE("LINE1 pin mode", 0x14, ALC_PIN_DIR_INOUT),
  5844. ALC_PIN_MODE("MIC2 pin mode", 0x13, ALC_PIN_DIR_INOUT),
  5845. ALC_PIN_MODE("MIC1 pin mode", 0x12, ALC_PIN_DIR_INOUT),
  5846. /* Loopback mixer controls */
  5847. HDA_CODEC_VOLUME("MIC1 Playback Volume", 0x07, 0x00, HDA_INPUT),
  5848. HDA_CODEC_MUTE("MIC1 Playback Switch", 0x07, 0x00, HDA_INPUT),
  5849. HDA_CODEC_VOLUME("MIC2 Playback Volume", 0x07, 0x01, HDA_INPUT),
  5850. HDA_CODEC_MUTE("MIC2 Playback Switch", 0x07, 0x01, HDA_INPUT),
  5851. HDA_CODEC_VOLUME("LINE1 Playback Volume", 0x07, 0x02, HDA_INPUT),
  5852. HDA_CODEC_MUTE("LINE1 Playback Switch", 0x07, 0x02, HDA_INPUT),
  5853. HDA_CODEC_VOLUME("LINE2 Playback Volume", 0x07, 0x03, HDA_INPUT),
  5854. HDA_CODEC_MUTE("LINE2 Playback Switch", 0x07, 0x03, HDA_INPUT),
  5855. HDA_CODEC_VOLUME("CD Playback Volume", 0x07, 0x04, HDA_INPUT),
  5856. HDA_CODEC_MUTE("CD Playback Switch", 0x07, 0x04, HDA_INPUT),
  5857. HDA_CODEC_VOLUME("LINE-OUT loopback Playback Volume", 0x07, 0x06, HDA_INPUT),
  5858. HDA_CODEC_MUTE("LINE-OUT loopback Playback Switch", 0x07, 0x06, HDA_INPUT),
  5859. HDA_CODEC_VOLUME("HP-OUT loopback Playback Volume", 0x07, 0x7, HDA_INPUT),
  5860. HDA_CODEC_MUTE("HP-OUT loopback Playback Switch", 0x07, 0x7, HDA_INPUT),
  5861. /* Controls for GPIO pins, assuming they are configured as outputs */
  5862. ALC_GPIO_DATA_SWITCH("GPIO pin 0", 0x01, 0x01),
  5863. ALC_GPIO_DATA_SWITCH("GPIO pin 1", 0x01, 0x02),
  5864. ALC_GPIO_DATA_SWITCH("GPIO pin 2", 0x01, 0x04),
  5865. ALC_GPIO_DATA_SWITCH("GPIO pin 3", 0x01, 0x08),
  5866. /* Switches to allow the digital IO pins to be enabled. The datasheet
  5867. * is ambigious as to which NID is which; testing on laptops which
  5868. * make this output available should provide clarification.
  5869. */
  5870. ALC_SPDIF_CTRL_SWITCH("SPDIF Playback Switch", 0x03, 0x01),
  5871. ALC_SPDIF_CTRL_SWITCH("SPDIF Capture Switch", 0x06, 0x01),
  5872. /* A switch allowing EAPD to be enabled. Some laptops seem to use
  5873. * this output to turn on an external amplifier.
  5874. */
  5875. ALC_EAPD_CTRL_SWITCH("LINE-OUT EAPD Enable Switch", 0x0f, 0x02),
  5876. ALC_EAPD_CTRL_SWITCH("HP-OUT EAPD Enable Switch", 0x10, 0x02),
  5877. { } /* end */
  5878. };
  5879. static struct hda_verb alc260_test_init_verbs[] = {
  5880. /* Enable all GPIOs as outputs with an initial value of 0 */
  5881. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x0f},
  5882. {0x01, AC_VERB_SET_GPIO_DATA, 0x00},
  5883. {0x01, AC_VERB_SET_GPIO_MASK, 0x0f},
  5884. /* Enable retasking pins as output, initially without power amp */
  5885. {0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5886. {0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5887. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5888. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5889. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5890. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  5891. /* Disable digital (SPDIF) pins initially, but users can enable
  5892. * them via a mixer switch. In the case of SPDIF-out, this initverb
  5893. * payload also sets the generation to 0, output to be in "consumer"
  5894. * PCM format, copyright asserted, no pre-emphasis and no validity
  5895. * control.
  5896. */
  5897. {0x03, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5898. {0x06, AC_VERB_SET_DIGI_CONVERT_1, 0},
  5899. /* Ensure mic1, mic2, line1 and line2 pin widgets take input from the
  5900. * OUT1 sum bus when acting as an output.
  5901. */
  5902. {0x0b, AC_VERB_SET_CONNECT_SEL, 0},
  5903. {0x0c, AC_VERB_SET_CONNECT_SEL, 0},
  5904. {0x0d, AC_VERB_SET_CONNECT_SEL, 0},
  5905. {0x0e, AC_VERB_SET_CONNECT_SEL, 0},
  5906. /* Start with output sum widgets muted and their output gains at min */
  5907. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5908. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5909. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5910. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5911. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5912. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5913. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5914. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  5915. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  5916. /* Unmute retasking pin widget output buffers since the default
  5917. * state appears to be output. As the pin mode is changed by the
  5918. * user the pin mode control will take care of enabling the pin's
  5919. * input/output buffers as needed.
  5920. */
  5921. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5922. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5923. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5924. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5925. {0x13, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5926. {0x12, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5927. /* Also unmute the mono-out pin widget */
  5928. {0x11, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  5929. /* Mute capture amp left and right */
  5930. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5931. /* Set ADC connection select to match default mixer setting (mic1
  5932. * pin)
  5933. */
  5934. {0x04, AC_VERB_SET_CONNECT_SEL, 0x00},
  5935. /* Do the same for the second ADC: mute capture input amp and
  5936. * set ADC connection to mic1 pin
  5937. */
  5938. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  5939. {0x05, AC_VERB_SET_CONNECT_SEL, 0x00},
  5940. /* Mute all inputs to mixer widget (even unconnected ones) */
  5941. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, /* mic1 pin */
  5942. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, /* mic2 pin */
  5943. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)}, /* line1 pin */
  5944. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)}, /* line2 pin */
  5945. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)}, /* CD pin */
  5946. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)}, /* Beep-gen pin */
  5947. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)}, /* Line-out pin */
  5948. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)}, /* HP-pin pin */
  5949. { }
  5950. };
  5951. #endif
  5952. #define alc260_pcm_analog_playback alc880_pcm_analog_alt_playback
  5953. #define alc260_pcm_analog_capture alc880_pcm_analog_capture
  5954. #define alc260_pcm_digital_playback alc880_pcm_digital_playback
  5955. #define alc260_pcm_digital_capture alc880_pcm_digital_capture
  5956. /*
  5957. * for BIOS auto-configuration
  5958. */
  5959. static int alc260_add_playback_controls(struct alc_spec *spec, hda_nid_t nid,
  5960. const char *pfx, int *vol_bits)
  5961. {
  5962. hda_nid_t nid_vol;
  5963. unsigned long vol_val, sw_val;
  5964. int err;
  5965. if (nid >= 0x0f && nid < 0x11) {
  5966. nid_vol = nid - 0x7;
  5967. vol_val = HDA_COMPOSE_AMP_VAL(nid_vol, 3, 0, HDA_OUTPUT);
  5968. sw_val = HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT);
  5969. } else if (nid == 0x11) {
  5970. nid_vol = nid - 0x7;
  5971. vol_val = HDA_COMPOSE_AMP_VAL(nid_vol, 2, 0, HDA_OUTPUT);
  5972. sw_val = HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT);
  5973. } else if (nid >= 0x12 && nid <= 0x15) {
  5974. nid_vol = 0x08;
  5975. vol_val = HDA_COMPOSE_AMP_VAL(nid_vol, 3, 0, HDA_OUTPUT);
  5976. sw_val = HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT);
  5977. } else
  5978. return 0; /* N/A */
  5979. if (!(*vol_bits & (1 << nid_vol))) {
  5980. /* first control for the volume widget */
  5981. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, pfx, vol_val);
  5982. if (err < 0)
  5983. return err;
  5984. *vol_bits |= (1 << nid_vol);
  5985. }
  5986. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, pfx, sw_val);
  5987. if (err < 0)
  5988. return err;
  5989. return 1;
  5990. }
  5991. /* add playback controls from the parsed DAC table */
  5992. static int alc260_auto_create_multi_out_ctls(struct alc_spec *spec,
  5993. const struct auto_pin_cfg *cfg)
  5994. {
  5995. hda_nid_t nid;
  5996. int err;
  5997. int vols = 0;
  5998. spec->multiout.num_dacs = 1;
  5999. spec->multiout.dac_nids = spec->private_dac_nids;
  6000. spec->multiout.dac_nids[0] = 0x02;
  6001. nid = cfg->line_out_pins[0];
  6002. if (nid) {
  6003. const char *pfx;
  6004. if (!cfg->speaker_pins[0] && !cfg->hp_pins[0])
  6005. pfx = "Master";
  6006. else if (cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  6007. pfx = "Speaker";
  6008. else
  6009. pfx = "Front";
  6010. err = alc260_add_playback_controls(spec, nid, pfx, &vols);
  6011. if (err < 0)
  6012. return err;
  6013. }
  6014. nid = cfg->speaker_pins[0];
  6015. if (nid) {
  6016. err = alc260_add_playback_controls(spec, nid, "Speaker", &vols);
  6017. if (err < 0)
  6018. return err;
  6019. }
  6020. nid = cfg->hp_pins[0];
  6021. if (nid) {
  6022. err = alc260_add_playback_controls(spec, nid, "Headphone",
  6023. &vols);
  6024. if (err < 0)
  6025. return err;
  6026. }
  6027. return 0;
  6028. }
  6029. /* create playback/capture controls for input pins */
  6030. static int alc260_auto_create_input_ctls(struct hda_codec *codec,
  6031. const struct auto_pin_cfg *cfg)
  6032. {
  6033. return alc_auto_create_input_ctls(codec, cfg, 0x07, 0x04, 0x05);
  6034. }
  6035. static void alc260_auto_set_output_and_unmute(struct hda_codec *codec,
  6036. hda_nid_t nid, int pin_type,
  6037. int sel_idx)
  6038. {
  6039. alc_set_pin_output(codec, nid, pin_type);
  6040. /* need the manual connection? */
  6041. if (nid >= 0x12) {
  6042. int idx = nid - 0x12;
  6043. snd_hda_codec_write(codec, idx + 0x0b, 0,
  6044. AC_VERB_SET_CONNECT_SEL, sel_idx);
  6045. }
  6046. }
  6047. static void alc260_auto_init_multi_out(struct hda_codec *codec)
  6048. {
  6049. struct alc_spec *spec = codec->spec;
  6050. hda_nid_t nid;
  6051. nid = spec->autocfg.line_out_pins[0];
  6052. if (nid) {
  6053. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  6054. alc260_auto_set_output_and_unmute(codec, nid, pin_type, 0);
  6055. }
  6056. nid = spec->autocfg.speaker_pins[0];
  6057. if (nid)
  6058. alc260_auto_set_output_and_unmute(codec, nid, PIN_OUT, 0);
  6059. nid = spec->autocfg.hp_pins[0];
  6060. if (nid)
  6061. alc260_auto_set_output_and_unmute(codec, nid, PIN_HP, 0);
  6062. }
  6063. #define ALC260_PIN_CD_NID 0x16
  6064. static void alc260_auto_init_analog_input(struct hda_codec *codec)
  6065. {
  6066. struct alc_spec *spec = codec->spec;
  6067. int i;
  6068. for (i = 0; i < AUTO_PIN_LAST; i++) {
  6069. hda_nid_t nid = spec->autocfg.input_pins[i];
  6070. if (nid >= 0x12) {
  6071. alc_set_input_pin(codec, nid, i);
  6072. if (nid != ALC260_PIN_CD_NID &&
  6073. (get_wcaps(codec, nid) & AC_WCAP_OUT_AMP))
  6074. snd_hda_codec_write(codec, nid, 0,
  6075. AC_VERB_SET_AMP_GAIN_MUTE,
  6076. AMP_OUT_MUTE);
  6077. }
  6078. }
  6079. }
  6080. #define alc260_auto_init_input_src alc880_auto_init_input_src
  6081. /*
  6082. * generic initialization of ADC, input mixers and output mixers
  6083. */
  6084. static struct hda_verb alc260_volume_init_verbs[] = {
  6085. /*
  6086. * Unmute ADC0-1 and set the default input to mic-in
  6087. */
  6088. {0x04, AC_VERB_SET_CONNECT_SEL, 0x00},
  6089. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  6090. {0x05, AC_VERB_SET_CONNECT_SEL, 0x00},
  6091. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  6092. /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
  6093. * mixer widget
  6094. * Note: PASD motherboards uses the Line In 2 as the input for
  6095. * front panel mic (mic 2)
  6096. */
  6097. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  6098. /* mute analog inputs */
  6099. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  6100. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  6101. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  6102. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  6103. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  6104. /*
  6105. * Set up output mixers (0x08 - 0x0a)
  6106. */
  6107. /* set vol=0 to output mixers */
  6108. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  6109. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  6110. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  6111. /* set up input amps for analog loopback */
  6112. /* Amp Indices: DAC = 0, mixer = 1 */
  6113. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  6114. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  6115. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  6116. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  6117. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  6118. {0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  6119. { }
  6120. };
  6121. static int alc260_parse_auto_config(struct hda_codec *codec)
  6122. {
  6123. struct alc_spec *spec = codec->spec;
  6124. int err;
  6125. static hda_nid_t alc260_ignore[] = { 0x17, 0 };
  6126. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  6127. alc260_ignore);
  6128. if (err < 0)
  6129. return err;
  6130. err = alc260_auto_create_multi_out_ctls(spec, &spec->autocfg);
  6131. if (err < 0)
  6132. return err;
  6133. if (!spec->kctls.list)
  6134. return 0; /* can't find valid BIOS pin config */
  6135. err = alc260_auto_create_input_ctls(codec, &spec->autocfg);
  6136. if (err < 0)
  6137. return err;
  6138. spec->multiout.max_channels = 2;
  6139. if (spec->autocfg.dig_outs)
  6140. spec->multiout.dig_out_nid = ALC260_DIGOUT_NID;
  6141. if (spec->kctls.list)
  6142. add_mixer(spec, spec->kctls.list);
  6143. add_verb(spec, alc260_volume_init_verbs);
  6144. spec->num_mux_defs = 1;
  6145. spec->input_mux = &spec->private_imux[0];
  6146. alc_ssid_check(codec, 0x10, 0x15, 0x0f, 0);
  6147. return 1;
  6148. }
  6149. /* additional initialization for auto-configuration model */
  6150. static void alc260_auto_init(struct hda_codec *codec)
  6151. {
  6152. struct alc_spec *spec = codec->spec;
  6153. alc260_auto_init_multi_out(codec);
  6154. alc260_auto_init_analog_input(codec);
  6155. alc260_auto_init_input_src(codec);
  6156. alc_auto_init_digital(codec);
  6157. if (spec->unsol_event)
  6158. alc_inithook(codec);
  6159. }
  6160. #ifdef CONFIG_SND_HDA_POWER_SAVE
  6161. static struct hda_amp_list alc260_loopbacks[] = {
  6162. { 0x07, HDA_INPUT, 0 },
  6163. { 0x07, HDA_INPUT, 1 },
  6164. { 0x07, HDA_INPUT, 2 },
  6165. { 0x07, HDA_INPUT, 3 },
  6166. { 0x07, HDA_INPUT, 4 },
  6167. { } /* end */
  6168. };
  6169. #endif
  6170. /*
  6171. * Pin config fixes
  6172. */
  6173. enum {
  6174. PINFIX_HP_DC5750,
  6175. };
  6176. static struct alc_pincfg alc260_hp_dc5750_pinfix[] = {
  6177. { 0x11, 0x90130110 }, /* speaker */
  6178. { }
  6179. };
  6180. static const struct alc_fixup alc260_fixups[] = {
  6181. [PINFIX_HP_DC5750] = {
  6182. .pins = alc260_hp_dc5750_pinfix
  6183. },
  6184. };
  6185. static struct snd_pci_quirk alc260_fixup_tbl[] = {
  6186. SND_PCI_QUIRK(0x103c, 0x280a, "HP dc5750", PINFIX_HP_DC5750),
  6187. {}
  6188. };
  6189. /*
  6190. * ALC260 configurations
  6191. */
  6192. static const char *alc260_models[ALC260_MODEL_LAST] = {
  6193. [ALC260_BASIC] = "basic",
  6194. [ALC260_HP] = "hp",
  6195. [ALC260_HP_3013] = "hp-3013",
  6196. [ALC260_HP_DC7600] = "hp-dc7600",
  6197. [ALC260_FUJITSU_S702X] = "fujitsu",
  6198. [ALC260_ACER] = "acer",
  6199. [ALC260_WILL] = "will",
  6200. [ALC260_REPLACER_672V] = "replacer",
  6201. [ALC260_FAVORIT100] = "favorit100",
  6202. #ifdef CONFIG_SND_DEBUG
  6203. [ALC260_TEST] = "test",
  6204. #endif
  6205. [ALC260_AUTO] = "auto",
  6206. };
  6207. static struct snd_pci_quirk alc260_cfg_tbl[] = {
  6208. SND_PCI_QUIRK(0x1025, 0x007b, "Acer C20x", ALC260_ACER),
  6209. SND_PCI_QUIRK(0x1025, 0x007f, "Acer", ALC260_WILL),
  6210. SND_PCI_QUIRK(0x1025, 0x008f, "Acer", ALC260_ACER),
  6211. SND_PCI_QUIRK(0x1509, 0x4540, "Favorit 100XS", ALC260_FAVORIT100),
  6212. SND_PCI_QUIRK(0x103c, 0x2808, "HP d5700", ALC260_HP_3013),
  6213. SND_PCI_QUIRK(0x103c, 0x280a, "HP d5750", ALC260_AUTO), /* no quirk */
  6214. SND_PCI_QUIRK(0x103c, 0x3010, "HP", ALC260_HP_3013),
  6215. SND_PCI_QUIRK(0x103c, 0x3011, "HP", ALC260_HP_3013),
  6216. SND_PCI_QUIRK(0x103c, 0x3012, "HP", ALC260_HP_DC7600),
  6217. SND_PCI_QUIRK(0x103c, 0x3013, "HP", ALC260_HP_3013),
  6218. SND_PCI_QUIRK(0x103c, 0x3014, "HP", ALC260_HP),
  6219. SND_PCI_QUIRK(0x103c, 0x3015, "HP", ALC260_HP),
  6220. SND_PCI_QUIRK(0x103c, 0x3016, "HP", ALC260_HP),
  6221. SND_PCI_QUIRK(0x104d, 0x81bb, "Sony VAIO", ALC260_BASIC),
  6222. SND_PCI_QUIRK(0x104d, 0x81cc, "Sony VAIO", ALC260_BASIC),
  6223. SND_PCI_QUIRK(0x104d, 0x81cd, "Sony VAIO", ALC260_BASIC),
  6224. SND_PCI_QUIRK(0x10cf, 0x1326, "Fujitsu S702X", ALC260_FUJITSU_S702X),
  6225. SND_PCI_QUIRK(0x152d, 0x0729, "CTL U553W", ALC260_BASIC),
  6226. SND_PCI_QUIRK(0x161f, 0x2057, "Replacer 672V", ALC260_REPLACER_672V),
  6227. SND_PCI_QUIRK(0x1631, 0xc017, "PB V7900", ALC260_WILL),
  6228. {}
  6229. };
  6230. static struct alc_config_preset alc260_presets[] = {
  6231. [ALC260_BASIC] = {
  6232. .mixers = { alc260_base_output_mixer,
  6233. alc260_input_mixer },
  6234. .init_verbs = { alc260_init_verbs },
  6235. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6236. .dac_nids = alc260_dac_nids,
  6237. .num_adc_nids = ARRAY_SIZE(alc260_dual_adc_nids),
  6238. .adc_nids = alc260_dual_adc_nids,
  6239. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6240. .channel_mode = alc260_modes,
  6241. .input_mux = &alc260_capture_source,
  6242. },
  6243. [ALC260_HP] = {
  6244. .mixers = { alc260_hp_output_mixer,
  6245. alc260_input_mixer },
  6246. .init_verbs = { alc260_init_verbs,
  6247. alc260_hp_unsol_verbs },
  6248. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6249. .dac_nids = alc260_dac_nids,
  6250. .num_adc_nids = ARRAY_SIZE(alc260_adc_nids_alt),
  6251. .adc_nids = alc260_adc_nids_alt,
  6252. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6253. .channel_mode = alc260_modes,
  6254. .input_mux = &alc260_capture_source,
  6255. .unsol_event = alc260_hp_unsol_event,
  6256. .init_hook = alc260_hp_automute,
  6257. },
  6258. [ALC260_HP_DC7600] = {
  6259. .mixers = { alc260_hp_dc7600_mixer,
  6260. alc260_input_mixer },
  6261. .init_verbs = { alc260_init_verbs,
  6262. alc260_hp_dc7600_verbs },
  6263. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6264. .dac_nids = alc260_dac_nids,
  6265. .num_adc_nids = ARRAY_SIZE(alc260_adc_nids_alt),
  6266. .adc_nids = alc260_adc_nids_alt,
  6267. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6268. .channel_mode = alc260_modes,
  6269. .input_mux = &alc260_capture_source,
  6270. .unsol_event = alc260_hp_3012_unsol_event,
  6271. .init_hook = alc260_hp_3012_automute,
  6272. },
  6273. [ALC260_HP_3013] = {
  6274. .mixers = { alc260_hp_3013_mixer,
  6275. alc260_input_mixer },
  6276. .init_verbs = { alc260_hp_3013_init_verbs,
  6277. alc260_hp_3013_unsol_verbs },
  6278. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6279. .dac_nids = alc260_dac_nids,
  6280. .num_adc_nids = ARRAY_SIZE(alc260_adc_nids_alt),
  6281. .adc_nids = alc260_adc_nids_alt,
  6282. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6283. .channel_mode = alc260_modes,
  6284. .input_mux = &alc260_capture_source,
  6285. .unsol_event = alc260_hp_3013_unsol_event,
  6286. .init_hook = alc260_hp_3013_automute,
  6287. },
  6288. [ALC260_FUJITSU_S702X] = {
  6289. .mixers = { alc260_fujitsu_mixer },
  6290. .init_verbs = { alc260_fujitsu_init_verbs },
  6291. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6292. .dac_nids = alc260_dac_nids,
  6293. .num_adc_nids = ARRAY_SIZE(alc260_dual_adc_nids),
  6294. .adc_nids = alc260_dual_adc_nids,
  6295. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6296. .channel_mode = alc260_modes,
  6297. .num_mux_defs = ARRAY_SIZE(alc260_fujitsu_capture_sources),
  6298. .input_mux = alc260_fujitsu_capture_sources,
  6299. },
  6300. [ALC260_ACER] = {
  6301. .mixers = { alc260_acer_mixer },
  6302. .init_verbs = { alc260_acer_init_verbs },
  6303. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6304. .dac_nids = alc260_dac_nids,
  6305. .num_adc_nids = ARRAY_SIZE(alc260_dual_adc_nids),
  6306. .adc_nids = alc260_dual_adc_nids,
  6307. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6308. .channel_mode = alc260_modes,
  6309. .num_mux_defs = ARRAY_SIZE(alc260_acer_capture_sources),
  6310. .input_mux = alc260_acer_capture_sources,
  6311. },
  6312. [ALC260_FAVORIT100] = {
  6313. .mixers = { alc260_favorit100_mixer },
  6314. .init_verbs = { alc260_favorit100_init_verbs },
  6315. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6316. .dac_nids = alc260_dac_nids,
  6317. .num_adc_nids = ARRAY_SIZE(alc260_dual_adc_nids),
  6318. .adc_nids = alc260_dual_adc_nids,
  6319. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6320. .channel_mode = alc260_modes,
  6321. .num_mux_defs = ARRAY_SIZE(alc260_favorit100_capture_sources),
  6322. .input_mux = alc260_favorit100_capture_sources,
  6323. },
  6324. [ALC260_WILL] = {
  6325. .mixers = { alc260_will_mixer },
  6326. .init_verbs = { alc260_init_verbs, alc260_will_verbs },
  6327. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6328. .dac_nids = alc260_dac_nids,
  6329. .num_adc_nids = ARRAY_SIZE(alc260_adc_nids),
  6330. .adc_nids = alc260_adc_nids,
  6331. .dig_out_nid = ALC260_DIGOUT_NID,
  6332. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6333. .channel_mode = alc260_modes,
  6334. .input_mux = &alc260_capture_source,
  6335. },
  6336. [ALC260_REPLACER_672V] = {
  6337. .mixers = { alc260_replacer_672v_mixer },
  6338. .init_verbs = { alc260_init_verbs, alc260_replacer_672v_verbs },
  6339. .num_dacs = ARRAY_SIZE(alc260_dac_nids),
  6340. .dac_nids = alc260_dac_nids,
  6341. .num_adc_nids = ARRAY_SIZE(alc260_adc_nids),
  6342. .adc_nids = alc260_adc_nids,
  6343. .dig_out_nid = ALC260_DIGOUT_NID,
  6344. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6345. .channel_mode = alc260_modes,
  6346. .input_mux = &alc260_capture_source,
  6347. .unsol_event = alc260_replacer_672v_unsol_event,
  6348. .init_hook = alc260_replacer_672v_automute,
  6349. },
  6350. #ifdef CONFIG_SND_DEBUG
  6351. [ALC260_TEST] = {
  6352. .mixers = { alc260_test_mixer },
  6353. .init_verbs = { alc260_test_init_verbs },
  6354. .num_dacs = ARRAY_SIZE(alc260_test_dac_nids),
  6355. .dac_nids = alc260_test_dac_nids,
  6356. .num_adc_nids = ARRAY_SIZE(alc260_test_adc_nids),
  6357. .adc_nids = alc260_test_adc_nids,
  6358. .num_channel_mode = ARRAY_SIZE(alc260_modes),
  6359. .channel_mode = alc260_modes,
  6360. .num_mux_defs = ARRAY_SIZE(alc260_test_capture_sources),
  6361. .input_mux = alc260_test_capture_sources,
  6362. },
  6363. #endif
  6364. };
  6365. static int patch_alc260(struct hda_codec *codec)
  6366. {
  6367. struct alc_spec *spec;
  6368. int err, board_config;
  6369. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  6370. if (spec == NULL)
  6371. return -ENOMEM;
  6372. codec->spec = spec;
  6373. board_config = snd_hda_check_board_config(codec, ALC260_MODEL_LAST,
  6374. alc260_models,
  6375. alc260_cfg_tbl);
  6376. if (board_config < 0) {
  6377. snd_printd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  6378. codec->chip_name);
  6379. board_config = ALC260_AUTO;
  6380. }
  6381. if (board_config == ALC260_AUTO)
  6382. alc_pick_fixup(codec, alc260_fixup_tbl, alc260_fixups, 1);
  6383. if (board_config == ALC260_AUTO) {
  6384. /* automatic parse from the BIOS config */
  6385. err = alc260_parse_auto_config(codec);
  6386. if (err < 0) {
  6387. alc_free(codec);
  6388. return err;
  6389. } else if (!err) {
  6390. printk(KERN_INFO
  6391. "hda_codec: Cannot set up configuration "
  6392. "from BIOS. Using base mode...\n");
  6393. board_config = ALC260_BASIC;
  6394. }
  6395. }
  6396. err = snd_hda_attach_beep_device(codec, 0x1);
  6397. if (err < 0) {
  6398. alc_free(codec);
  6399. return err;
  6400. }
  6401. if (board_config != ALC260_AUTO)
  6402. setup_preset(codec, &alc260_presets[board_config]);
  6403. spec->stream_analog_playback = &alc260_pcm_analog_playback;
  6404. spec->stream_analog_capture = &alc260_pcm_analog_capture;
  6405. spec->stream_analog_alt_capture = &alc260_pcm_analog_capture;
  6406. spec->stream_digital_playback = &alc260_pcm_digital_playback;
  6407. spec->stream_digital_capture = &alc260_pcm_digital_capture;
  6408. if (!spec->adc_nids && spec->input_mux) {
  6409. /* check whether NID 0x04 is valid */
  6410. unsigned int wcap = get_wcaps(codec, 0x04);
  6411. wcap = get_wcaps_type(wcap);
  6412. /* get type */
  6413. if (wcap != AC_WID_AUD_IN || spec->input_mux->num_items == 1) {
  6414. spec->adc_nids = alc260_adc_nids_alt;
  6415. spec->num_adc_nids = ARRAY_SIZE(alc260_adc_nids_alt);
  6416. } else {
  6417. spec->adc_nids = alc260_adc_nids;
  6418. spec->num_adc_nids = ARRAY_SIZE(alc260_adc_nids);
  6419. }
  6420. }
  6421. set_capture_mixer(codec);
  6422. set_beep_amp(spec, 0x07, 0x05, HDA_INPUT);
  6423. if (board_config == ALC260_AUTO)
  6424. alc_pick_fixup(codec, alc260_fixup_tbl, alc260_fixups, 0);
  6425. spec->vmaster_nid = 0x08;
  6426. codec->patch_ops = alc_patch_ops;
  6427. if (board_config == ALC260_AUTO)
  6428. spec->init_hook = alc260_auto_init;
  6429. #ifdef CONFIG_SND_HDA_POWER_SAVE
  6430. if (!spec->loopback.amplist)
  6431. spec->loopback.amplist = alc260_loopbacks;
  6432. #endif
  6433. return 0;
  6434. }
  6435. /*
  6436. * ALC882/883/885/888/889 support
  6437. *
  6438. * ALC882 is almost identical with ALC880 but has cleaner and more flexible
  6439. * configuration. Each pin widget can choose any input DACs and a mixer.
  6440. * Each ADC is connected from a mixer of all inputs. This makes possible
  6441. * 6-channel independent captures.
  6442. *
  6443. * In addition, an independent DAC for the multi-playback (not used in this
  6444. * driver yet).
  6445. */
  6446. #define ALC882_DIGOUT_NID 0x06
  6447. #define ALC882_DIGIN_NID 0x0a
  6448. #define ALC883_DIGOUT_NID ALC882_DIGOUT_NID
  6449. #define ALC883_DIGIN_NID ALC882_DIGIN_NID
  6450. #define ALC1200_DIGOUT_NID 0x10
  6451. static struct hda_channel_mode alc882_ch_modes[1] = {
  6452. { 8, NULL }
  6453. };
  6454. /* DACs */
  6455. static hda_nid_t alc882_dac_nids[4] = {
  6456. /* front, rear, clfe, rear_surr */
  6457. 0x02, 0x03, 0x04, 0x05
  6458. };
  6459. #define alc883_dac_nids alc882_dac_nids
  6460. /* ADCs */
  6461. #define alc882_adc_nids alc880_adc_nids
  6462. #define alc882_adc_nids_alt alc880_adc_nids_alt
  6463. #define alc883_adc_nids alc882_adc_nids_alt
  6464. static hda_nid_t alc883_adc_nids_alt[1] = { 0x08 };
  6465. static hda_nid_t alc883_adc_nids_rev[2] = { 0x09, 0x08 };
  6466. #define alc889_adc_nids alc880_adc_nids
  6467. static hda_nid_t alc882_capsrc_nids[3] = { 0x24, 0x23, 0x22 };
  6468. static hda_nid_t alc882_capsrc_nids_alt[2] = { 0x23, 0x22 };
  6469. #define alc883_capsrc_nids alc882_capsrc_nids_alt
  6470. static hda_nid_t alc883_capsrc_nids_rev[2] = { 0x22, 0x23 };
  6471. #define alc889_capsrc_nids alc882_capsrc_nids
  6472. /* input MUX */
  6473. /* FIXME: should be a matrix-type input source selection */
  6474. static struct hda_input_mux alc882_capture_source = {
  6475. .num_items = 4,
  6476. .items = {
  6477. { "Mic", 0x0 },
  6478. { "Front Mic", 0x1 },
  6479. { "Line", 0x2 },
  6480. { "CD", 0x4 },
  6481. },
  6482. };
  6483. #define alc883_capture_source alc882_capture_source
  6484. static struct hda_input_mux alc889_capture_source = {
  6485. .num_items = 3,
  6486. .items = {
  6487. { "Front Mic", 0x0 },
  6488. { "Mic", 0x3 },
  6489. { "Line", 0x2 },
  6490. },
  6491. };
  6492. static struct hda_input_mux mb5_capture_source = {
  6493. .num_items = 3,
  6494. .items = {
  6495. { "Mic", 0x1 },
  6496. { "Line", 0x7 },
  6497. { "CD", 0x4 },
  6498. },
  6499. };
  6500. static struct hda_input_mux macmini3_capture_source = {
  6501. .num_items = 2,
  6502. .items = {
  6503. { "Line", 0x2 },
  6504. { "CD", 0x4 },
  6505. },
  6506. };
  6507. static struct hda_input_mux alc883_3stack_6ch_intel = {
  6508. .num_items = 4,
  6509. .items = {
  6510. { "Mic", 0x1 },
  6511. { "Front Mic", 0x0 },
  6512. { "Line", 0x2 },
  6513. { "CD", 0x4 },
  6514. },
  6515. };
  6516. static struct hda_input_mux alc883_lenovo_101e_capture_source = {
  6517. .num_items = 2,
  6518. .items = {
  6519. { "Mic", 0x1 },
  6520. { "Line", 0x2 },
  6521. },
  6522. };
  6523. static struct hda_input_mux alc883_lenovo_nb0763_capture_source = {
  6524. .num_items = 4,
  6525. .items = {
  6526. { "Mic", 0x0 },
  6527. { "Int Mic", 0x1 },
  6528. { "Line", 0x2 },
  6529. { "CD", 0x4 },
  6530. },
  6531. };
  6532. static struct hda_input_mux alc883_fujitsu_pi2515_capture_source = {
  6533. .num_items = 2,
  6534. .items = {
  6535. { "Mic", 0x0 },
  6536. { "Int Mic", 0x1 },
  6537. },
  6538. };
  6539. static struct hda_input_mux alc883_lenovo_sky_capture_source = {
  6540. .num_items = 3,
  6541. .items = {
  6542. { "Mic", 0x0 },
  6543. { "Front Mic", 0x1 },
  6544. { "Line", 0x4 },
  6545. },
  6546. };
  6547. static struct hda_input_mux alc883_asus_eee1601_capture_source = {
  6548. .num_items = 2,
  6549. .items = {
  6550. { "Mic", 0x0 },
  6551. { "Line", 0x2 },
  6552. },
  6553. };
  6554. static struct hda_input_mux alc889A_mb31_capture_source = {
  6555. .num_items = 2,
  6556. .items = {
  6557. { "Mic", 0x0 },
  6558. /* Front Mic (0x01) unused */
  6559. { "Line", 0x2 },
  6560. /* Line 2 (0x03) unused */
  6561. /* CD (0x04) unused? */
  6562. },
  6563. };
  6564. static struct hda_input_mux alc889A_imac91_capture_source = {
  6565. .num_items = 2,
  6566. .items = {
  6567. { "Mic", 0x01 },
  6568. { "Line", 0x2 }, /* Not sure! */
  6569. },
  6570. };
  6571. /*
  6572. * 2ch mode
  6573. */
  6574. static struct hda_channel_mode alc883_3ST_2ch_modes[1] = {
  6575. { 2, NULL }
  6576. };
  6577. /*
  6578. * 2ch mode
  6579. */
  6580. static struct hda_verb alc882_3ST_ch2_init[] = {
  6581. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6582. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6583. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  6584. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6585. { } /* end */
  6586. };
  6587. /*
  6588. * 4ch mode
  6589. */
  6590. static struct hda_verb alc882_3ST_ch4_init[] = {
  6591. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6592. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6593. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6594. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6595. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6596. { } /* end */
  6597. };
  6598. /*
  6599. * 6ch mode
  6600. */
  6601. static struct hda_verb alc882_3ST_ch6_init[] = {
  6602. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6603. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6604. { 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
  6605. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6606. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6607. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6608. { } /* end */
  6609. };
  6610. static struct hda_channel_mode alc882_3ST_6ch_modes[3] = {
  6611. { 2, alc882_3ST_ch2_init },
  6612. { 4, alc882_3ST_ch4_init },
  6613. { 6, alc882_3ST_ch6_init },
  6614. };
  6615. #define alc883_3ST_6ch_modes alc882_3ST_6ch_modes
  6616. /*
  6617. * 2ch mode
  6618. */
  6619. static struct hda_verb alc883_3ST_ch2_clevo_init[] = {
  6620. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP },
  6621. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6622. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6623. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  6624. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6625. { } /* end */
  6626. };
  6627. /*
  6628. * 4ch mode
  6629. */
  6630. static struct hda_verb alc883_3ST_ch4_clevo_init[] = {
  6631. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6632. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6633. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6634. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6635. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6636. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6637. { } /* end */
  6638. };
  6639. /*
  6640. * 6ch mode
  6641. */
  6642. static struct hda_verb alc883_3ST_ch6_clevo_init[] = {
  6643. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6644. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6645. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6646. { 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
  6647. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6648. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6649. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6650. { } /* end */
  6651. };
  6652. static struct hda_channel_mode alc883_3ST_6ch_clevo_modes[3] = {
  6653. { 2, alc883_3ST_ch2_clevo_init },
  6654. { 4, alc883_3ST_ch4_clevo_init },
  6655. { 6, alc883_3ST_ch6_clevo_init },
  6656. };
  6657. /*
  6658. * 6ch mode
  6659. */
  6660. static struct hda_verb alc882_sixstack_ch6_init[] = {
  6661. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  6662. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6663. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6664. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6665. { } /* end */
  6666. };
  6667. /*
  6668. * 8ch mode
  6669. */
  6670. static struct hda_verb alc882_sixstack_ch8_init[] = {
  6671. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6672. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6673. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6674. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6675. { } /* end */
  6676. };
  6677. static struct hda_channel_mode alc882_sixstack_modes[2] = {
  6678. { 6, alc882_sixstack_ch6_init },
  6679. { 8, alc882_sixstack_ch8_init },
  6680. };
  6681. /* Macbook Air 2,1 */
  6682. static struct hda_channel_mode alc885_mba21_ch_modes[1] = {
  6683. { 2, NULL },
  6684. };
  6685. /*
  6686. * macbook pro ALC885 can switch LineIn to LineOut without losing Mic
  6687. */
  6688. /*
  6689. * 2ch mode
  6690. */
  6691. static struct hda_verb alc885_mbp_ch2_init[] = {
  6692. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  6693. { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  6694. { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  6695. { } /* end */
  6696. };
  6697. /*
  6698. * 4ch mode
  6699. */
  6700. static struct hda_verb alc885_mbp_ch4_init[] = {
  6701. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6702. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  6703. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6704. { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  6705. { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  6706. { } /* end */
  6707. };
  6708. static struct hda_channel_mode alc885_mbp_4ch_modes[2] = {
  6709. { 2, alc885_mbp_ch2_init },
  6710. { 4, alc885_mbp_ch4_init },
  6711. };
  6712. /*
  6713. * 2ch
  6714. * Speakers/Woofer/HP = Front
  6715. * LineIn = Input
  6716. */
  6717. static struct hda_verb alc885_mb5_ch2_init[] = {
  6718. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  6719. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  6720. { } /* end */
  6721. };
  6722. /*
  6723. * 6ch mode
  6724. * Speakers/HP = Front
  6725. * Woofer = LFE
  6726. * LineIn = Surround
  6727. */
  6728. static struct hda_verb alc885_mb5_ch6_init[] = {
  6729. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  6730. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  6731. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  6732. { } /* end */
  6733. };
  6734. static struct hda_channel_mode alc885_mb5_6ch_modes[2] = {
  6735. { 2, alc885_mb5_ch2_init },
  6736. { 6, alc885_mb5_ch6_init },
  6737. };
  6738. #define alc885_macmini3_6ch_modes alc885_mb5_6ch_modes
  6739. /*
  6740. * 2ch mode
  6741. */
  6742. static struct hda_verb alc883_4ST_ch2_init[] = {
  6743. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6744. { 0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6745. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6746. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6747. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  6748. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6749. { } /* end */
  6750. };
  6751. /*
  6752. * 4ch mode
  6753. */
  6754. static struct hda_verb alc883_4ST_ch4_init[] = {
  6755. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6756. { 0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6757. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6758. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6759. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6760. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6761. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6762. { } /* end */
  6763. };
  6764. /*
  6765. * 6ch mode
  6766. */
  6767. static struct hda_verb alc883_4ST_ch6_init[] = {
  6768. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6769. { 0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6770. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6771. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6772. { 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
  6773. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6774. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6775. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6776. { } /* end */
  6777. };
  6778. /*
  6779. * 8ch mode
  6780. */
  6781. static struct hda_verb alc883_4ST_ch8_init[] = {
  6782. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6783. { 0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6784. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x03 },
  6785. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6786. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6787. { 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
  6788. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6789. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6790. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6791. { } /* end */
  6792. };
  6793. static struct hda_channel_mode alc883_4ST_8ch_modes[4] = {
  6794. { 2, alc883_4ST_ch2_init },
  6795. { 4, alc883_4ST_ch4_init },
  6796. { 6, alc883_4ST_ch6_init },
  6797. { 8, alc883_4ST_ch8_init },
  6798. };
  6799. /*
  6800. * 2ch mode
  6801. */
  6802. static struct hda_verb alc883_3ST_ch2_intel_init[] = {
  6803. { 0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6804. { 0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6805. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  6806. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6807. { } /* end */
  6808. };
  6809. /*
  6810. * 4ch mode
  6811. */
  6812. static struct hda_verb alc883_3ST_ch4_intel_init[] = {
  6813. { 0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  6814. { 0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6815. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6816. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6817. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6818. { } /* end */
  6819. };
  6820. /*
  6821. * 6ch mode
  6822. */
  6823. static struct hda_verb alc883_3ST_ch6_intel_init[] = {
  6824. { 0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6825. { 0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6826. { 0x19, AC_VERB_SET_CONNECT_SEL, 0x02 },
  6827. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6828. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6829. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6830. { } /* end */
  6831. };
  6832. static struct hda_channel_mode alc883_3ST_6ch_intel_modes[3] = {
  6833. { 2, alc883_3ST_ch2_intel_init },
  6834. { 4, alc883_3ST_ch4_intel_init },
  6835. { 6, alc883_3ST_ch6_intel_init },
  6836. };
  6837. /*
  6838. * 2ch mode
  6839. */
  6840. static struct hda_verb alc889_ch2_intel_init[] = {
  6841. { 0x14, AC_VERB_SET_CONNECT_SEL, 0x00 },
  6842. { 0x19, AC_VERB_SET_CONNECT_SEL, 0x00 },
  6843. { 0x16, AC_VERB_SET_CONNECT_SEL, 0x00 },
  6844. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x00 },
  6845. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  6846. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6847. { } /* end */
  6848. };
  6849. /*
  6850. * 6ch mode
  6851. */
  6852. static struct hda_verb alc889_ch6_intel_init[] = {
  6853. { 0x14, AC_VERB_SET_CONNECT_SEL, 0x00 },
  6854. { 0x19, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6855. { 0x16, AC_VERB_SET_CONNECT_SEL, 0x02 },
  6856. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x03 },
  6857. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  6858. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  6859. { } /* end */
  6860. };
  6861. /*
  6862. * 8ch mode
  6863. */
  6864. static struct hda_verb alc889_ch8_intel_init[] = {
  6865. { 0x14, AC_VERB_SET_CONNECT_SEL, 0x00 },
  6866. { 0x19, AC_VERB_SET_CONNECT_SEL, 0x01 },
  6867. { 0x16, AC_VERB_SET_CONNECT_SEL, 0x02 },
  6868. { 0x17, AC_VERB_SET_CONNECT_SEL, 0x03 },
  6869. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x03 },
  6870. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6871. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  6872. { } /* end */
  6873. };
  6874. static struct hda_channel_mode alc889_8ch_intel_modes[3] = {
  6875. { 2, alc889_ch2_intel_init },
  6876. { 6, alc889_ch6_intel_init },
  6877. { 8, alc889_ch8_intel_init },
  6878. };
  6879. /*
  6880. * 6ch mode
  6881. */
  6882. static struct hda_verb alc883_sixstack_ch6_init[] = {
  6883. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  6884. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6885. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6886. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6887. { } /* end */
  6888. };
  6889. /*
  6890. * 8ch mode
  6891. */
  6892. static struct hda_verb alc883_sixstack_ch8_init[] = {
  6893. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6894. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6895. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6896. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  6897. { } /* end */
  6898. };
  6899. static struct hda_channel_mode alc883_sixstack_modes[2] = {
  6900. { 6, alc883_sixstack_ch6_init },
  6901. { 8, alc883_sixstack_ch8_init },
  6902. };
  6903. /* Pin assignment: Front=0x14, Rear=0x15, CLFE=0x16, Side=0x17
  6904. * Mic=0x18, Front Mic=0x19, Line-In=0x1a, HP=0x1b
  6905. */
  6906. static struct snd_kcontrol_new alc882_base_mixer[] = {
  6907. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  6908. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  6909. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  6910. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  6911. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  6912. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  6913. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  6914. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  6915. HDA_CODEC_VOLUME("Side Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  6916. HDA_BIND_MUTE("Side Playback Switch", 0x0f, 2, HDA_INPUT),
  6917. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  6918. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  6919. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  6920. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  6921. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  6922. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  6923. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  6924. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  6925. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  6926. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  6927. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  6928. { } /* end */
  6929. };
  6930. /* Macbook Air 2,1 same control for HP and internal Speaker */
  6931. static struct snd_kcontrol_new alc885_mba21_mixer[] = {
  6932. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
  6933. HDA_BIND_MUTE("Speaker Playback Switch", 0x0c, 0x02, HDA_OUTPUT),
  6934. { }
  6935. };
  6936. static struct snd_kcontrol_new alc885_mbp3_mixer[] = {
  6937. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
  6938. HDA_BIND_MUTE ("Speaker Playback Switch", 0x0c, 0x02, HDA_INPUT),
  6939. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0e, 0x00, HDA_OUTPUT),
  6940. HDA_BIND_MUTE ("Headphone Playback Switch", 0x0e, 0x02, HDA_INPUT),
  6941. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x00, HDA_OUTPUT),
  6942. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  6943. HDA_CODEC_MUTE ("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  6944. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x00, HDA_INPUT),
  6945. HDA_CODEC_MUTE ("Mic Playback Switch", 0x0b, 0x00, HDA_INPUT),
  6946. HDA_CODEC_VOLUME("Line Boost", 0x1a, 0x00, HDA_INPUT),
  6947. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0x00, HDA_INPUT),
  6948. { } /* end */
  6949. };
  6950. static struct snd_kcontrol_new alc885_mb5_mixer[] = {
  6951. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
  6952. HDA_BIND_MUTE ("Front Playback Switch", 0x0c, 0x02, HDA_INPUT),
  6953. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x00, HDA_OUTPUT),
  6954. HDA_BIND_MUTE ("Surround Playback Switch", 0x0d, 0x02, HDA_INPUT),
  6955. HDA_CODEC_VOLUME("LFE Playback Volume", 0x0e, 0x00, HDA_OUTPUT),
  6956. HDA_BIND_MUTE ("LFE Playback Switch", 0x0e, 0x02, HDA_INPUT),
  6957. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0f, 0x00, HDA_OUTPUT),
  6958. HDA_BIND_MUTE ("Headphone Playback Switch", 0x0f, 0x02, HDA_INPUT),
  6959. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x07, HDA_INPUT),
  6960. HDA_CODEC_MUTE ("Line Playback Switch", 0x0b, 0x07, HDA_INPUT),
  6961. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  6962. HDA_CODEC_MUTE ("Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  6963. HDA_CODEC_VOLUME("Line Boost", 0x15, 0x00, HDA_INPUT),
  6964. HDA_CODEC_VOLUME("Mic Boost", 0x19, 0x00, HDA_INPUT),
  6965. { } /* end */
  6966. };
  6967. static struct snd_kcontrol_new alc885_macmini3_mixer[] = {
  6968. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
  6969. HDA_BIND_MUTE ("Front Playback Switch", 0x0c, 0x02, HDA_INPUT),
  6970. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x00, HDA_OUTPUT),
  6971. HDA_BIND_MUTE ("Surround Playback Switch", 0x0d, 0x02, HDA_INPUT),
  6972. HDA_CODEC_VOLUME("LFE Playback Volume", 0x0e, 0x00, HDA_OUTPUT),
  6973. HDA_BIND_MUTE ("LFE Playback Switch", 0x0e, 0x02, HDA_INPUT),
  6974. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0f, 0x00, HDA_OUTPUT),
  6975. HDA_BIND_MUTE ("Headphone Playback Switch", 0x0f, 0x02, HDA_INPUT),
  6976. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x07, HDA_INPUT),
  6977. HDA_CODEC_MUTE ("Line Playback Switch", 0x0b, 0x07, HDA_INPUT),
  6978. HDA_CODEC_VOLUME("Line Boost", 0x15, 0x00, HDA_INPUT),
  6979. { } /* end */
  6980. };
  6981. static struct snd_kcontrol_new alc885_imac91_mixer[] = {
  6982. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
  6983. HDA_BIND_MUTE("Speaker Playback Switch", 0x0c, 0x02, HDA_INPUT),
  6984. { } /* end */
  6985. };
  6986. static struct snd_kcontrol_new alc882_w2jc_mixer[] = {
  6987. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  6988. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  6989. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  6990. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  6991. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  6992. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  6993. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  6994. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  6995. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  6996. { } /* end */
  6997. };
  6998. static struct snd_kcontrol_new alc882_targa_mixer[] = {
  6999. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7000. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7001. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  7002. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7003. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7004. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7005. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7006. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7007. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7008. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7009. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7010. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7011. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  7012. { } /* end */
  7013. };
  7014. /* Pin assignment: Front=0x14, HP = 0x15, Front = 0x16, ???
  7015. * Front Mic=0x18, Line In = 0x1a, Line In = 0x1b, CD = 0x1c
  7016. */
  7017. static struct snd_kcontrol_new alc882_asus_a7j_mixer[] = {
  7018. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7019. HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  7020. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  7021. HDA_CODEC_MUTE("Mobile Front Playback Switch", 0x16, 0x0, HDA_OUTPUT),
  7022. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7023. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7024. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7025. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7026. HDA_CODEC_VOLUME("Mobile Line Playback Volume", 0x0b, 0x03, HDA_INPUT),
  7027. HDA_CODEC_MUTE("Mobile Line Playback Switch", 0x0b, 0x03, HDA_INPUT),
  7028. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7029. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7030. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7031. { } /* end */
  7032. };
  7033. static struct snd_kcontrol_new alc882_asus_a7m_mixer[] = {
  7034. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7035. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7036. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  7037. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7038. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7039. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7040. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7041. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7042. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7043. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7044. { } /* end */
  7045. };
  7046. static struct snd_kcontrol_new alc882_chmode_mixer[] = {
  7047. {
  7048. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  7049. .name = "Channel Mode",
  7050. .info = alc_ch_mode_info,
  7051. .get = alc_ch_mode_get,
  7052. .put = alc_ch_mode_put,
  7053. },
  7054. { } /* end */
  7055. };
  7056. static struct hda_verb alc882_base_init_verbs[] = {
  7057. /* Front mixer: unmute input/output amp left and right (volume = 0) */
  7058. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7059. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7060. /* Rear mixer */
  7061. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7062. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7063. /* CLFE mixer */
  7064. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7065. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7066. /* Side mixer */
  7067. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7068. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7069. /* Front Pin: output 0 (0x0c) */
  7070. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7071. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7072. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  7073. /* Rear Pin: output 1 (0x0d) */
  7074. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7075. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7076. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  7077. /* CLFE Pin: output 2 (0x0e) */
  7078. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7079. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7080. {0x16, AC_VERB_SET_CONNECT_SEL, 0x02},
  7081. /* Side Pin: output 3 (0x0f) */
  7082. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7083. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7084. {0x17, AC_VERB_SET_CONNECT_SEL, 0x03},
  7085. /* Mic (rear) pin: input vref at 80% */
  7086. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7087. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7088. /* Front Mic pin: input vref at 80% */
  7089. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7090. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7091. /* Line In pin: input */
  7092. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  7093. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7094. /* Line-2 In: Headphone output (output 0 - 0x0c) */
  7095. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7096. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7097. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  7098. /* CD pin widget for input */
  7099. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  7100. /* FIXME: use matrix-type input source selection */
  7101. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  7102. /* Input mixer2 */
  7103. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7104. /* Input mixer3 */
  7105. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7106. /* ADC2: mute amp left and right */
  7107. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7108. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  7109. /* ADC3: mute amp left and right */
  7110. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7111. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  7112. { }
  7113. };
  7114. static struct hda_verb alc882_adc1_init_verbs[] = {
  7115. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  7116. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7117. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7118. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7119. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7120. /* ADC1: mute amp left and right */
  7121. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7122. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  7123. { }
  7124. };
  7125. static struct hda_verb alc882_eapd_verbs[] = {
  7126. /* change to EAPD mode */
  7127. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  7128. {0x20, AC_VERB_SET_PROC_COEF, 0x3060},
  7129. { }
  7130. };
  7131. static struct hda_verb alc889_eapd_verbs[] = {
  7132. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  7133. {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
  7134. { }
  7135. };
  7136. static struct hda_verb alc_hp15_unsol_verbs[] = {
  7137. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  7138. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7139. {}
  7140. };
  7141. static struct hda_verb alc885_init_verbs[] = {
  7142. /* Front mixer: unmute input/output amp left and right (volume = 0) */
  7143. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7144. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7145. /* Rear mixer */
  7146. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7147. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7148. /* CLFE mixer */
  7149. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7150. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7151. /* Side mixer */
  7152. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7153. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7154. /* Front HP Pin: output 0 (0x0c) */
  7155. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7156. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7157. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  7158. /* Front Pin: output 0 (0x0c) */
  7159. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7160. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7161. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  7162. /* Rear Pin: output 1 (0x0d) */
  7163. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7164. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7165. {0x19, AC_VERB_SET_CONNECT_SEL, 0x01},
  7166. /* CLFE Pin: output 2 (0x0e) */
  7167. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7168. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7169. {0x16, AC_VERB_SET_CONNECT_SEL, 0x02},
  7170. /* Side Pin: output 3 (0x0f) */
  7171. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7172. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7173. {0x17, AC_VERB_SET_CONNECT_SEL, 0x03},
  7174. /* Mic (rear) pin: input vref at 80% */
  7175. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7176. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7177. /* Front Mic pin: input vref at 80% */
  7178. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7179. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7180. /* Line In pin: input */
  7181. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  7182. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7183. /* Mixer elements: 0x18, , 0x1a, 0x1b */
  7184. /* Input mixer1 */
  7185. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7186. /* Input mixer2 */
  7187. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7188. /* Input mixer3 */
  7189. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7190. /* ADC2: mute amp left and right */
  7191. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7192. /* ADC3: mute amp left and right */
  7193. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7194. { }
  7195. };
  7196. static struct hda_verb alc885_init_input_verbs[] = {
  7197. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7198. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  7199. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)},
  7200. { }
  7201. };
  7202. /* Unmute Selector 24h and set the default input to front mic */
  7203. static struct hda_verb alc889_init_input_verbs[] = {
  7204. {0x24, AC_VERB_SET_CONNECT_SEL, 0x00},
  7205. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7206. { }
  7207. };
  7208. #define alc883_init_verbs alc882_base_init_verbs
  7209. /* Mac Pro test */
  7210. static struct snd_kcontrol_new alc882_macpro_mixer[] = {
  7211. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7212. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7213. HDA_CODEC_MUTE("Headphone Playback Switch", 0x18, 0x0, HDA_OUTPUT),
  7214. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x01, HDA_INPUT),
  7215. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x01, HDA_INPUT),
  7216. /* FIXME: this looks suspicious...
  7217. HDA_CODEC_VOLUME("Beep Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7218. HDA_CODEC_MUTE("Beep Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7219. */
  7220. { } /* end */
  7221. };
  7222. static struct hda_verb alc882_macpro_init_verbs[] = {
  7223. /* Front mixer: unmute input/output amp left and right (volume = 0) */
  7224. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7225. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7226. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7227. /* Front Pin: output 0 (0x0c) */
  7228. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7229. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7230. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  7231. /* Front Mic pin: input vref at 80% */
  7232. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7233. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7234. /* Speaker: output */
  7235. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7236. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7237. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x04},
  7238. /* Headphone output (output 0 - 0x0c) */
  7239. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7240. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7241. {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
  7242. /* FIXME: use matrix-type input source selection */
  7243. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  7244. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  7245. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7246. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7247. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7248. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7249. /* Input mixer2 */
  7250. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7251. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7252. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7253. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7254. /* Input mixer3 */
  7255. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7256. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7257. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7258. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7259. /* ADC1: mute amp left and right */
  7260. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7261. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  7262. /* ADC2: mute amp left and right */
  7263. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7264. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  7265. /* ADC3: mute amp left and right */
  7266. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7267. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  7268. { }
  7269. };
  7270. /* Macbook 5,1 */
  7271. static struct hda_verb alc885_mb5_init_verbs[] = {
  7272. /* DACs */
  7273. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7274. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7275. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7276. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7277. /* Front mixer */
  7278. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7279. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7280. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7281. /* Surround mixer */
  7282. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7283. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7284. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7285. /* LFE mixer */
  7286. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7287. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7288. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7289. /* HP mixer */
  7290. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7291. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7292. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7293. /* Front Pin (0x0c) */
  7294. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | 0x01},
  7295. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7296. {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
  7297. /* LFE Pin (0x0e) */
  7298. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | 0x01},
  7299. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7300. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x02},
  7301. /* HP Pin (0x0f) */
  7302. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7303. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7304. {0x14, AC_VERB_SET_CONNECT_SEL, 0x03},
  7305. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  7306. /* Front Mic pin: input vref at 80% */
  7307. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7308. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7309. /* Line In pin */
  7310. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  7311. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7312. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0x1)},
  7313. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0x7)},
  7314. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0x4)},
  7315. { }
  7316. };
  7317. /* Macmini 3,1 */
  7318. static struct hda_verb alc885_macmini3_init_verbs[] = {
  7319. /* DACs */
  7320. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7321. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7322. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7323. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7324. /* Front mixer */
  7325. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7326. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7327. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7328. /* Surround mixer */
  7329. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7330. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7331. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7332. /* LFE mixer */
  7333. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7334. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7335. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7336. /* HP mixer */
  7337. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7338. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7339. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7340. /* Front Pin (0x0c) */
  7341. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | 0x01},
  7342. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7343. {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
  7344. /* LFE Pin (0x0e) */
  7345. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT | 0x01},
  7346. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7347. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x02},
  7348. /* HP Pin (0x0f) */
  7349. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7350. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7351. {0x14, AC_VERB_SET_CONNECT_SEL, 0x03},
  7352. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  7353. /* Line In pin */
  7354. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  7355. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7356. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7357. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7358. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7359. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7360. { }
  7361. };
  7362. static struct hda_verb alc885_mba21_init_verbs[] = {
  7363. /*Internal and HP Speaker Mixer*/
  7364. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7365. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7366. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7367. /*Internal Speaker Pin (0x0c)*/
  7368. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, (PIN_OUT | AC_PINCTL_VREF_50) },
  7369. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7370. {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
  7371. /* HP Pin: output 0 (0x0e) */
  7372. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc4},
  7373. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7374. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  7375. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, (ALC880_HP_EVENT | AC_USRSP_EN)},
  7376. /* Line in (is hp when jack connected)*/
  7377. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, AC_PINCTL_VREF_50},
  7378. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7379. { }
  7380. };
  7381. /* Macbook Pro rev3 */
  7382. static struct hda_verb alc885_mbp3_init_verbs[] = {
  7383. /* Front mixer: unmute input/output amp left and right (volume = 0) */
  7384. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7385. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7386. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7387. /* Rear mixer */
  7388. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7389. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7390. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7391. /* HP mixer */
  7392. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7393. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7394. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7395. /* Front Pin: output 0 (0x0c) */
  7396. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7397. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7398. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  7399. /* HP Pin: output 0 (0x0e) */
  7400. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc4},
  7401. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7402. {0x15, AC_VERB_SET_CONNECT_SEL, 0x02},
  7403. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  7404. /* Mic (rear) pin: input vref at 80% */
  7405. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7406. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7407. /* Front Mic pin: input vref at 80% */
  7408. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7409. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7410. /* Line In pin: use output 1 when in LineOut mode */
  7411. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  7412. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7413. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x01},
  7414. /* FIXME: use matrix-type input source selection */
  7415. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  7416. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  7417. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7418. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7419. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7420. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7421. /* Input mixer2 */
  7422. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7423. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7424. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7425. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7426. /* Input mixer3 */
  7427. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7428. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7429. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7430. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7431. /* ADC1: mute amp left and right */
  7432. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7433. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  7434. /* ADC2: mute amp left and right */
  7435. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7436. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  7437. /* ADC3: mute amp left and right */
  7438. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7439. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  7440. { }
  7441. };
  7442. /* iMac 9,1 */
  7443. static struct hda_verb alc885_imac91_init_verbs[] = {
  7444. /* Internal Speaker Pin (0x0c) */
  7445. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, (PIN_OUT | AC_PINCTL_VREF_50) },
  7446. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7447. {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
  7448. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, (PIN_OUT | AC_PINCTL_VREF_50) },
  7449. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7450. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x00},
  7451. /* HP Pin: Rear */
  7452. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7453. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7454. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  7455. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, (ALC880_HP_EVENT | AC_USRSP_EN)},
  7456. /* Line in Rear */
  7457. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, AC_PINCTL_VREF_50},
  7458. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7459. /* Front Mic pin: input vref at 80% */
  7460. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7461. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7462. /* Rear mixer */
  7463. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7464. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7465. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7466. /* Line-Out mixer: unmute input/output amp left and right (volume = 0) */
  7467. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7468. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7469. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  7470. /* 0x24 [Audio Mixer] wcaps 0x20010b: Stereo Amp-In */
  7471. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7472. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7473. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7474. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7475. /* 0x23 [Audio Mixer] wcaps 0x20010b: Stereo Amp-In */
  7476. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7477. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7478. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7479. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7480. /* 0x22 [Audio Mixer] wcaps 0x20010b: Stereo Amp-In */
  7481. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7482. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  7483. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  7484. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  7485. /* 0x07 [Audio Input] wcaps 0x10011b: Stereo Amp-In */
  7486. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7487. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  7488. /* 0x08 [Audio Input] wcaps 0x10011b: Stereo Amp-In */
  7489. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7490. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  7491. /* 0x09 [Audio Input] wcaps 0x10011b: Stereo Amp-In */
  7492. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  7493. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  7494. { }
  7495. };
  7496. /* iMac 24 mixer. */
  7497. static struct snd_kcontrol_new alc885_imac24_mixer[] = {
  7498. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
  7499. HDA_CODEC_MUTE("Master Playback Switch", 0x0c, 0x00, HDA_INPUT),
  7500. { } /* end */
  7501. };
  7502. /* iMac 24 init verbs. */
  7503. static struct hda_verb alc885_imac24_init_verbs[] = {
  7504. /* Internal speakers: output 0 (0x0c) */
  7505. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7506. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7507. {0x18, AC_VERB_SET_CONNECT_SEL, 0x00},
  7508. /* Internal speakers: output 0 (0x0c) */
  7509. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7510. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7511. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x00},
  7512. /* Headphone: output 0 (0x0c) */
  7513. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7514. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7515. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  7516. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  7517. /* Front Mic: input vref at 80% */
  7518. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  7519. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  7520. { }
  7521. };
  7522. /* Toggle speaker-output according to the hp-jack state */
  7523. static void alc885_imac24_setup(struct hda_codec *codec)
  7524. {
  7525. struct alc_spec *spec = codec->spec;
  7526. spec->autocfg.hp_pins[0] = 0x14;
  7527. spec->autocfg.speaker_pins[0] = 0x18;
  7528. spec->autocfg.speaker_pins[1] = 0x1a;
  7529. }
  7530. #define alc885_mb5_setup alc885_imac24_setup
  7531. #define alc885_macmini3_setup alc885_imac24_setup
  7532. /* Macbook Air 2,1 */
  7533. static void alc885_mba21_setup(struct hda_codec *codec)
  7534. {
  7535. struct alc_spec *spec = codec->spec;
  7536. spec->autocfg.hp_pins[0] = 0x14;
  7537. spec->autocfg.speaker_pins[0] = 0x18;
  7538. }
  7539. static void alc885_mbp3_setup(struct hda_codec *codec)
  7540. {
  7541. struct alc_spec *spec = codec->spec;
  7542. spec->autocfg.hp_pins[0] = 0x15;
  7543. spec->autocfg.speaker_pins[0] = 0x14;
  7544. }
  7545. static void alc885_imac91_setup(struct hda_codec *codec)
  7546. {
  7547. struct alc_spec *spec = codec->spec;
  7548. spec->autocfg.hp_pins[0] = 0x14;
  7549. spec->autocfg.speaker_pins[0] = 0x18;
  7550. spec->autocfg.speaker_pins[1] = 0x1a;
  7551. }
  7552. static struct hda_verb alc882_targa_verbs[] = {
  7553. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7554. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7555. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7556. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7557. {0x18, AC_VERB_SET_CONNECT_SEL, 0x02}, /* mic/clfe */
  7558. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x01}, /* line/surround */
  7559. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  7560. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  7561. { } /* end */
  7562. };
  7563. /* toggle speaker-output according to the hp-jack state */
  7564. static void alc882_targa_automute(struct hda_codec *codec)
  7565. {
  7566. struct alc_spec *spec = codec->spec;
  7567. alc_automute_amp(codec);
  7568. snd_hda_codec_write_cache(codec, 1, 0, AC_VERB_SET_GPIO_DATA,
  7569. spec->jack_present ? 1 : 3);
  7570. }
  7571. static void alc882_targa_setup(struct hda_codec *codec)
  7572. {
  7573. struct alc_spec *spec = codec->spec;
  7574. spec->autocfg.hp_pins[0] = 0x14;
  7575. spec->autocfg.speaker_pins[0] = 0x1b;
  7576. }
  7577. static void alc882_targa_unsol_event(struct hda_codec *codec, unsigned int res)
  7578. {
  7579. if ((res >> 26) == ALC880_HP_EVENT)
  7580. alc882_targa_automute(codec);
  7581. }
  7582. static struct hda_verb alc882_asus_a7j_verbs[] = {
  7583. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7584. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7585. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7586. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7587. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7588. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Front */
  7589. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  7590. {0x16, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Front */
  7591. {0x18, AC_VERB_SET_CONNECT_SEL, 0x02}, /* mic/clfe */
  7592. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x01}, /* line/surround */
  7593. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  7594. { } /* end */
  7595. };
  7596. static struct hda_verb alc882_asus_a7m_verbs[] = {
  7597. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7598. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7599. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7600. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7601. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  7602. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Front */
  7603. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  7604. {0x16, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Front */
  7605. {0x18, AC_VERB_SET_CONNECT_SEL, 0x02}, /* mic/clfe */
  7606. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x01}, /* line/surround */
  7607. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP */
  7608. { } /* end */
  7609. };
  7610. static void alc882_gpio_mute(struct hda_codec *codec, int pin, int muted)
  7611. {
  7612. unsigned int gpiostate, gpiomask, gpiodir;
  7613. gpiostate = snd_hda_codec_read(codec, codec->afg, 0,
  7614. AC_VERB_GET_GPIO_DATA, 0);
  7615. if (!muted)
  7616. gpiostate |= (1 << pin);
  7617. else
  7618. gpiostate &= ~(1 << pin);
  7619. gpiomask = snd_hda_codec_read(codec, codec->afg, 0,
  7620. AC_VERB_GET_GPIO_MASK, 0);
  7621. gpiomask |= (1 << pin);
  7622. gpiodir = snd_hda_codec_read(codec, codec->afg, 0,
  7623. AC_VERB_GET_GPIO_DIRECTION, 0);
  7624. gpiodir |= (1 << pin);
  7625. snd_hda_codec_write(codec, codec->afg, 0,
  7626. AC_VERB_SET_GPIO_MASK, gpiomask);
  7627. snd_hda_codec_write(codec, codec->afg, 0,
  7628. AC_VERB_SET_GPIO_DIRECTION, gpiodir);
  7629. msleep(1);
  7630. snd_hda_codec_write(codec, codec->afg, 0,
  7631. AC_VERB_SET_GPIO_DATA, gpiostate);
  7632. }
  7633. /* set up GPIO at initialization */
  7634. static void alc885_macpro_init_hook(struct hda_codec *codec)
  7635. {
  7636. alc882_gpio_mute(codec, 0, 0);
  7637. alc882_gpio_mute(codec, 1, 0);
  7638. }
  7639. /* set up GPIO and update auto-muting at initialization */
  7640. static void alc885_imac24_init_hook(struct hda_codec *codec)
  7641. {
  7642. alc885_macpro_init_hook(codec);
  7643. alc_automute_amp(codec);
  7644. }
  7645. /*
  7646. * generic initialization of ADC, input mixers and output mixers
  7647. */
  7648. static struct hda_verb alc883_auto_init_verbs[] = {
  7649. /*
  7650. * Unmute ADC0-2 and set the default input to mic-in
  7651. */
  7652. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  7653. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7654. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  7655. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7656. /*
  7657. * Set up output mixers (0x0c - 0x0f)
  7658. */
  7659. /* set vol=0 to output mixers */
  7660. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7661. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7662. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7663. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  7664. /* set up input amps for analog loopback */
  7665. /* Amp Indices: DAC = 0, mixer = 1 */
  7666. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7667. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7668. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7669. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7670. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7671. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7672. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7673. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7674. {0x26, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7675. {0x26, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7676. /* FIXME: use matrix-type input source selection */
  7677. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  7678. /* Input mixer2 */
  7679. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7680. /* Input mixer3 */
  7681. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7682. { }
  7683. };
  7684. /* 2ch mode (Speaker:front, Subwoofer:CLFE, Line:input, Headphones:front) */
  7685. static struct hda_verb alc889A_mb31_ch2_init[] = {
  7686. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP as front */
  7687. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* Subwoofer on */
  7688. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, /* Line as input */
  7689. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, /* Line off */
  7690. { } /* end */
  7691. };
  7692. /* 4ch mode (Speaker:front, Subwoofer:CLFE, Line:CLFE, Headphones:front) */
  7693. static struct hda_verb alc889A_mb31_ch4_init[] = {
  7694. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00}, /* HP as front */
  7695. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* Subwoofer on */
  7696. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, /* Line as output */
  7697. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* Line on */
  7698. { } /* end */
  7699. };
  7700. /* 5ch mode (Speaker:front, Subwoofer:CLFE, Line:input, Headphones:rear) */
  7701. static struct hda_verb alc889A_mb31_ch5_init[] = {
  7702. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, /* HP as rear */
  7703. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* Subwoofer on */
  7704. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, /* Line as input */
  7705. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, /* Line off */
  7706. { } /* end */
  7707. };
  7708. /* 6ch mode (Speaker:front, Subwoofer:off, Line:CLFE, Headphones:Rear) */
  7709. static struct hda_verb alc889A_mb31_ch6_init[] = {
  7710. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, /* HP as front */
  7711. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, /* Subwoofer off */
  7712. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, /* Line as output */
  7713. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* Line on */
  7714. { } /* end */
  7715. };
  7716. static struct hda_channel_mode alc889A_mb31_6ch_modes[4] = {
  7717. { 2, alc889A_mb31_ch2_init },
  7718. { 4, alc889A_mb31_ch4_init },
  7719. { 5, alc889A_mb31_ch5_init },
  7720. { 6, alc889A_mb31_ch6_init },
  7721. };
  7722. static struct hda_verb alc883_medion_eapd_verbs[] = {
  7723. /* eanable EAPD on medion laptop */
  7724. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  7725. {0x20, AC_VERB_SET_PROC_COEF, 0x3070},
  7726. { }
  7727. };
  7728. #define alc883_base_mixer alc882_base_mixer
  7729. static struct snd_kcontrol_new alc883_mitac_mixer[] = {
  7730. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7731. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7732. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  7733. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  7734. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  7735. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  7736. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  7737. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7738. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7739. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7740. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7741. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  7742. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7743. { } /* end */
  7744. };
  7745. static struct snd_kcontrol_new alc883_clevo_m720_mixer[] = {
  7746. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7747. HDA_BIND_MUTE("Headphone Playback Switch", 0x0c, 2, HDA_INPUT),
  7748. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7749. HDA_BIND_MUTE("Speaker Playback Switch", 0x0d, 2, HDA_INPUT),
  7750. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7751. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7752. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7753. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7754. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  7755. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7756. { } /* end */
  7757. };
  7758. static struct snd_kcontrol_new alc883_2ch_fujitsu_pi2515_mixer[] = {
  7759. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7760. HDA_BIND_MUTE("Headphone Playback Switch", 0x0c, 2, HDA_INPUT),
  7761. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7762. HDA_BIND_MUTE("Speaker Playback Switch", 0x0d, 2, HDA_INPUT),
  7763. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7764. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7765. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7766. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7767. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  7768. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7769. { } /* end */
  7770. };
  7771. static struct snd_kcontrol_new alc883_3ST_2ch_mixer[] = {
  7772. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7773. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7774. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  7775. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7776. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7777. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7778. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7779. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7780. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7781. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7782. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7783. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  7784. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7785. { } /* end */
  7786. };
  7787. static struct snd_kcontrol_new alc883_3ST_6ch_mixer[] = {
  7788. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7789. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7790. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7791. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  7792. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  7793. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  7794. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  7795. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  7796. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  7797. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7798. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7799. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7800. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7801. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7802. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7803. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7804. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7805. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  7806. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7807. { } /* end */
  7808. };
  7809. static struct snd_kcontrol_new alc883_3ST_6ch_intel_mixer[] = {
  7810. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7811. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7812. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7813. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  7814. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0,
  7815. HDA_OUTPUT),
  7816. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  7817. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  7818. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  7819. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  7820. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7821. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7822. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7823. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7824. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7825. HDA_CODEC_VOLUME("Mic Boost", 0x19, 0, HDA_INPUT),
  7826. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7827. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7828. HDA_CODEC_VOLUME("Front Mic Boost", 0x18, 0, HDA_INPUT),
  7829. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7830. { } /* end */
  7831. };
  7832. static struct snd_kcontrol_new alc885_8ch_intel_mixer[] = {
  7833. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7834. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7835. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7836. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  7837. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0,
  7838. HDA_OUTPUT),
  7839. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  7840. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  7841. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  7842. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  7843. HDA_BIND_MUTE("Speaker Playback Switch", 0x0f, 2, HDA_INPUT),
  7844. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  7845. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7846. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7847. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x3, HDA_INPUT),
  7848. HDA_CODEC_VOLUME("Mic Boost", 0x1b, 0, HDA_INPUT),
  7849. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x3, HDA_INPUT),
  7850. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7851. HDA_CODEC_VOLUME("Front Mic Boost", 0x18, 0, HDA_INPUT),
  7852. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7853. { } /* end */
  7854. };
  7855. static struct snd_kcontrol_new alc883_fivestack_mixer[] = {
  7856. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7857. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7858. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7859. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  7860. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  7861. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  7862. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  7863. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  7864. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  7865. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7866. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7867. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7868. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7869. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7870. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7871. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7872. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7873. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  7874. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7875. { } /* end */
  7876. };
  7877. static struct snd_kcontrol_new alc883_targa_mixer[] = {
  7878. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7879. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7880. HDA_CODEC_MUTE("Headphone Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  7881. HDA_CODEC_MUTE("Speaker Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  7882. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7883. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  7884. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  7885. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  7886. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  7887. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  7888. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7889. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7890. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7891. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7892. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7893. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7894. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7895. { } /* end */
  7896. };
  7897. static struct snd_kcontrol_new alc883_targa_2ch_mixer[] = {
  7898. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7899. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7900. HDA_CODEC_MUTE("Headphone Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  7901. HDA_CODEC_MUTE("Speaker Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  7902. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7903. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7904. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7905. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7906. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7907. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7908. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  7909. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7910. { } /* end */
  7911. };
  7912. static struct snd_kcontrol_new alc883_targa_8ch_mixer[] = {
  7913. HDA_CODEC_VOLUME("Side Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  7914. HDA_BIND_MUTE("Side Playback Switch", 0x0f, 2, HDA_INPUT),
  7915. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7916. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  7917. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7918. { } /* end */
  7919. };
  7920. static struct snd_kcontrol_new alc883_lenovo_101e_2ch_mixer[] = {
  7921. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7922. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7923. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  7924. HDA_BIND_MUTE("Speaker Playback Switch", 0x0d, 2, HDA_INPUT),
  7925. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  7926. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7927. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7928. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7929. { } /* end */
  7930. };
  7931. static struct snd_kcontrol_new alc883_lenovo_nb0763_mixer[] = {
  7932. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7933. HDA_BIND_MUTE("Speaker Playback Switch", 0x0c, 2, HDA_INPUT),
  7934. HDA_CODEC_MUTE("Headphone Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  7935. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7936. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7937. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7938. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7939. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  7940. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  7941. { } /* end */
  7942. };
  7943. static struct snd_kcontrol_new alc883_medion_md2_mixer[] = {
  7944. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7945. HDA_CODEC_MUTE("Headphone Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  7946. HDA_CODEC_MUTE("Front Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  7947. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  7948. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  7949. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7950. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7951. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7952. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7953. { } /* end */
  7954. };
  7955. static struct snd_kcontrol_new alc883_medion_wim2160_mixer[] = {
  7956. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7957. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7958. HDA_CODEC_MUTE("Speaker Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  7959. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x0, HDA_OUTPUT),
  7960. HDA_CODEC_VOLUME("Line Playback Volume", 0x08, 0x0, HDA_INPUT),
  7961. HDA_CODEC_MUTE("Line Playback Switch", 0x08, 0x0, HDA_INPUT),
  7962. { } /* end */
  7963. };
  7964. static struct hda_verb alc883_medion_wim2160_verbs[] = {
  7965. /* Unmute front mixer */
  7966. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  7967. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  7968. /* Set speaker pin to front mixer */
  7969. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  7970. /* Init headphone pin */
  7971. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  7972. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  7973. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x00},
  7974. {0x1a, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  7975. { } /* end */
  7976. };
  7977. /* toggle speaker-output according to the hp-jack state */
  7978. static void alc883_medion_wim2160_setup(struct hda_codec *codec)
  7979. {
  7980. struct alc_spec *spec = codec->spec;
  7981. spec->autocfg.hp_pins[0] = 0x1a;
  7982. spec->autocfg.speaker_pins[0] = 0x15;
  7983. }
  7984. static struct snd_kcontrol_new alc883_acer_aspire_mixer[] = {
  7985. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7986. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  7987. HDA_CODEC_MUTE("Headphone Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  7988. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7989. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  7990. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  7991. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  7992. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  7993. { } /* end */
  7994. };
  7995. static struct snd_kcontrol_new alc888_acer_aspire_6530_mixer[] = {
  7996. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  7997. HDA_CODEC_VOLUME("LFE Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  7998. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  7999. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  8000. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  8001. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  8002. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  8003. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  8004. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  8005. { } /* end */
  8006. };
  8007. static struct snd_kcontrol_new alc888_lenovo_sky_mixer[] = {
  8008. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  8009. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  8010. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0e, 0x0, HDA_OUTPUT),
  8011. HDA_BIND_MUTE("Surround Playback Switch", 0x0e, 2, HDA_INPUT),
  8012. HDA_CODEC_VOLUME_MONO("Center Playback Volume",
  8013. 0x0d, 1, 0x0, HDA_OUTPUT),
  8014. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0d, 2, 0x0, HDA_OUTPUT),
  8015. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0d, 1, 2, HDA_INPUT),
  8016. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0d, 2, 2, HDA_INPUT),
  8017. HDA_CODEC_VOLUME("Side Playback Volume", 0x0f, 0x0, HDA_OUTPUT),
  8018. HDA_BIND_MUTE("Side Playback Switch", 0x0f, 2, HDA_INPUT),
  8019. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  8020. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  8021. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  8022. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  8023. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  8024. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  8025. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  8026. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  8027. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  8028. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  8029. { } /* end */
  8030. };
  8031. static struct snd_kcontrol_new alc889A_mb31_mixer[] = {
  8032. /* Output mixers */
  8033. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x00, HDA_OUTPUT),
  8034. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 0x02, HDA_INPUT),
  8035. HDA_CODEC_VOLUME("Surround Playback Volume", 0x0d, 0x00, HDA_OUTPUT),
  8036. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 0x02, HDA_INPUT),
  8037. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x00,
  8038. HDA_OUTPUT),
  8039. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 0x02, HDA_INPUT),
  8040. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x00, HDA_OUTPUT),
  8041. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 0x02, HDA_INPUT),
  8042. /* Output switches */
  8043. HDA_CODEC_MUTE("Enable Speaker", 0x14, 0x00, HDA_OUTPUT),
  8044. HDA_CODEC_MUTE("Enable Headphones", 0x15, 0x00, HDA_OUTPUT),
  8045. HDA_CODEC_MUTE_MONO("Enable LFE", 0x16, 2, 0x00, HDA_OUTPUT),
  8046. /* Boost mixers */
  8047. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0x00, HDA_INPUT),
  8048. HDA_CODEC_VOLUME("Line Boost", 0x1a, 0x00, HDA_INPUT),
  8049. /* Input mixers */
  8050. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x00, HDA_INPUT),
  8051. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x00, HDA_INPUT),
  8052. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  8053. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  8054. { } /* end */
  8055. };
  8056. static struct snd_kcontrol_new alc883_vaiott_mixer[] = {
  8057. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  8058. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  8059. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  8060. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  8061. HDA_CODEC_VOLUME("Mic Boost", 0x19, 0, HDA_INPUT),
  8062. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  8063. { } /* end */
  8064. };
  8065. static struct hda_bind_ctls alc883_bind_cap_vol = {
  8066. .ops = &snd_hda_bind_vol,
  8067. .values = {
  8068. HDA_COMPOSE_AMP_VAL(0x08, 3, 0, HDA_INPUT),
  8069. HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_INPUT),
  8070. 0
  8071. },
  8072. };
  8073. static struct hda_bind_ctls alc883_bind_cap_switch = {
  8074. .ops = &snd_hda_bind_sw,
  8075. .values = {
  8076. HDA_COMPOSE_AMP_VAL(0x08, 3, 0, HDA_INPUT),
  8077. HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_INPUT),
  8078. 0
  8079. },
  8080. };
  8081. static struct snd_kcontrol_new alc883_asus_eee1601_mixer[] = {
  8082. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  8083. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  8084. HDA_CODEC_MUTE("Headphone Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  8085. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  8086. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  8087. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  8088. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  8089. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  8090. { } /* end */
  8091. };
  8092. static struct snd_kcontrol_new alc883_asus_eee1601_cap_mixer[] = {
  8093. HDA_BIND_VOL("Capture Volume", &alc883_bind_cap_vol),
  8094. HDA_BIND_SW("Capture Switch", &alc883_bind_cap_switch),
  8095. {
  8096. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  8097. /* .name = "Capture Source", */
  8098. .name = "Input Source",
  8099. .count = 1,
  8100. .info = alc_mux_enum_info,
  8101. .get = alc_mux_enum_get,
  8102. .put = alc_mux_enum_put,
  8103. },
  8104. { } /* end */
  8105. };
  8106. static struct snd_kcontrol_new alc883_chmode_mixer[] = {
  8107. {
  8108. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  8109. .name = "Channel Mode",
  8110. .info = alc_ch_mode_info,
  8111. .get = alc_ch_mode_get,
  8112. .put = alc_ch_mode_put,
  8113. },
  8114. { } /* end */
  8115. };
  8116. /* toggle speaker-output according to the hp-jack state */
  8117. static void alc883_mitac_setup(struct hda_codec *codec)
  8118. {
  8119. struct alc_spec *spec = codec->spec;
  8120. spec->autocfg.hp_pins[0] = 0x15;
  8121. spec->autocfg.speaker_pins[0] = 0x14;
  8122. spec->autocfg.speaker_pins[1] = 0x17;
  8123. }
  8124. /* auto-toggle front mic */
  8125. /*
  8126. static void alc883_mitac_mic_automute(struct hda_codec *codec)
  8127. {
  8128. unsigned char bits = snd_hda_jack_detect(codec, 0x18) ? HDA_AMP_MUTE : 0;
  8129. snd_hda_codec_amp_stereo(codec, 0x0b, HDA_INPUT, 1, HDA_AMP_MUTE, bits);
  8130. }
  8131. */
  8132. static struct hda_verb alc883_mitac_verbs[] = {
  8133. /* HP */
  8134. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8135. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8136. /* Subwoofer */
  8137. {0x17, AC_VERB_SET_CONNECT_SEL, 0x02},
  8138. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8139. /* enable unsolicited event */
  8140. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8141. /* {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_MIC_EVENT | AC_USRSP_EN}, */
  8142. { } /* end */
  8143. };
  8144. static struct hda_verb alc883_clevo_m540r_verbs[] = {
  8145. /* HP */
  8146. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8147. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8148. /* Int speaker */
  8149. /*{0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},*/
  8150. /* enable unsolicited event */
  8151. /*
  8152. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8153. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_MIC_EVENT | AC_USRSP_EN},
  8154. */
  8155. { } /* end */
  8156. };
  8157. static struct hda_verb alc883_clevo_m720_verbs[] = {
  8158. /* HP */
  8159. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8160. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8161. /* Int speaker */
  8162. {0x14, AC_VERB_SET_CONNECT_SEL, 0x01},
  8163. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8164. /* enable unsolicited event */
  8165. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8166. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_MIC_EVENT | AC_USRSP_EN},
  8167. { } /* end */
  8168. };
  8169. static struct hda_verb alc883_2ch_fujitsu_pi2515_verbs[] = {
  8170. /* HP */
  8171. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  8172. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8173. /* Subwoofer */
  8174. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  8175. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8176. /* enable unsolicited event */
  8177. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8178. { } /* end */
  8179. };
  8180. static struct hda_verb alc883_targa_verbs[] = {
  8181. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8182. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  8183. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8184. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8185. /* Connect Line-Out side jack (SPDIF) to Side */
  8186. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8187. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  8188. {0x17, AC_VERB_SET_CONNECT_SEL, 0x03},
  8189. /* Connect Mic jack to CLFE */
  8190. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8191. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  8192. {0x18, AC_VERB_SET_CONNECT_SEL, 0x02},
  8193. /* Connect Line-in jack to Surround */
  8194. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8195. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  8196. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x01},
  8197. /* Connect HP out jack to Front */
  8198. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8199. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  8200. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  8201. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8202. { } /* end */
  8203. };
  8204. static struct hda_verb alc883_lenovo_101e_verbs[] = {
  8205. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8206. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_FRONT_EVENT|AC_USRSP_EN},
  8207. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT|AC_USRSP_EN},
  8208. { } /* end */
  8209. };
  8210. static struct hda_verb alc883_lenovo_nb0763_verbs[] = {
  8211. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8212. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8213. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8214. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8215. { } /* end */
  8216. };
  8217. static struct hda_verb alc888_lenovo_ms7195_verbs[] = {
  8218. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8219. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  8220. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8221. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_FRONT_EVENT | AC_USRSP_EN},
  8222. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8223. { } /* end */
  8224. };
  8225. static struct hda_verb alc883_haier_w66_verbs[] = {
  8226. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8227. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  8228. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8229. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  8230. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8231. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8232. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8233. { } /* end */
  8234. };
  8235. static struct hda_verb alc888_lenovo_sky_verbs[] = {
  8236. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8237. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  8238. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8239. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8240. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8241. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8242. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x00},
  8243. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8244. { } /* end */
  8245. };
  8246. static struct hda_verb alc888_6st_dell_verbs[] = {
  8247. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8248. { }
  8249. };
  8250. static struct hda_verb alc883_vaiott_verbs[] = {
  8251. /* HP */
  8252. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8253. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8254. /* enable unsolicited event */
  8255. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8256. { } /* end */
  8257. };
  8258. static void alc888_3st_hp_setup(struct hda_codec *codec)
  8259. {
  8260. struct alc_spec *spec = codec->spec;
  8261. spec->autocfg.hp_pins[0] = 0x1b;
  8262. spec->autocfg.speaker_pins[0] = 0x14;
  8263. spec->autocfg.speaker_pins[1] = 0x16;
  8264. spec->autocfg.speaker_pins[2] = 0x18;
  8265. }
  8266. static struct hda_verb alc888_3st_hp_verbs[] = {
  8267. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Front: output 0 (0x0c) */
  8268. {0x16, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Rear : output 1 (0x0d) */
  8269. {0x18, AC_VERB_SET_CONNECT_SEL, 0x02}, /* CLFE : output 2 (0x0e) */
  8270. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8271. { } /* end */
  8272. };
  8273. /*
  8274. * 2ch mode
  8275. */
  8276. static struct hda_verb alc888_3st_hp_2ch_init[] = {
  8277. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  8278. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  8279. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  8280. { 0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  8281. { } /* end */
  8282. };
  8283. /*
  8284. * 4ch mode
  8285. */
  8286. static struct hda_verb alc888_3st_hp_4ch_init[] = {
  8287. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  8288. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  8289. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  8290. { 0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  8291. { 0x16, AC_VERB_SET_CONNECT_SEL, 0x01 },
  8292. { } /* end */
  8293. };
  8294. /*
  8295. * 6ch mode
  8296. */
  8297. static struct hda_verb alc888_3st_hp_6ch_init[] = {
  8298. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  8299. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  8300. { 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
  8301. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  8302. { 0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  8303. { 0x16, AC_VERB_SET_CONNECT_SEL, 0x01 },
  8304. { } /* end */
  8305. };
  8306. static struct hda_channel_mode alc888_3st_hp_modes[3] = {
  8307. { 2, alc888_3st_hp_2ch_init },
  8308. { 4, alc888_3st_hp_4ch_init },
  8309. { 6, alc888_3st_hp_6ch_init },
  8310. };
  8311. /* toggle front-jack and RCA according to the hp-jack state */
  8312. static void alc888_lenovo_ms7195_front_automute(struct hda_codec *codec)
  8313. {
  8314. unsigned int present = snd_hda_jack_detect(codec, 0x1b);
  8315. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  8316. HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
  8317. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  8318. HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
  8319. }
  8320. /* toggle RCA according to the front-jack state */
  8321. static void alc888_lenovo_ms7195_rca_automute(struct hda_codec *codec)
  8322. {
  8323. unsigned int present = snd_hda_jack_detect(codec, 0x14);
  8324. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  8325. HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
  8326. }
  8327. static void alc883_lenovo_ms7195_unsol_event(struct hda_codec *codec,
  8328. unsigned int res)
  8329. {
  8330. if ((res >> 26) == ALC880_HP_EVENT)
  8331. alc888_lenovo_ms7195_front_automute(codec);
  8332. if ((res >> 26) == ALC880_FRONT_EVENT)
  8333. alc888_lenovo_ms7195_rca_automute(codec);
  8334. }
  8335. static struct hda_verb alc883_medion_md2_verbs[] = {
  8336. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8337. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  8338. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8339. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8340. { } /* end */
  8341. };
  8342. /* toggle speaker-output according to the hp-jack state */
  8343. static void alc883_medion_md2_setup(struct hda_codec *codec)
  8344. {
  8345. struct alc_spec *spec = codec->spec;
  8346. spec->autocfg.hp_pins[0] = 0x14;
  8347. spec->autocfg.speaker_pins[0] = 0x15;
  8348. }
  8349. /* toggle speaker-output according to the hp-jack state */
  8350. #define alc883_targa_init_hook alc882_targa_init_hook
  8351. #define alc883_targa_unsol_event alc882_targa_unsol_event
  8352. static void alc883_clevo_m720_mic_automute(struct hda_codec *codec)
  8353. {
  8354. unsigned int present;
  8355. present = snd_hda_jack_detect(codec, 0x18);
  8356. snd_hda_codec_amp_stereo(codec, 0x0b, HDA_INPUT, 1,
  8357. HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
  8358. }
  8359. static void alc883_clevo_m720_setup(struct hda_codec *codec)
  8360. {
  8361. struct alc_spec *spec = codec->spec;
  8362. spec->autocfg.hp_pins[0] = 0x15;
  8363. spec->autocfg.speaker_pins[0] = 0x14;
  8364. }
  8365. static void alc883_clevo_m720_init_hook(struct hda_codec *codec)
  8366. {
  8367. alc_automute_amp(codec);
  8368. alc883_clevo_m720_mic_automute(codec);
  8369. }
  8370. static void alc883_clevo_m720_unsol_event(struct hda_codec *codec,
  8371. unsigned int res)
  8372. {
  8373. switch (res >> 26) {
  8374. case ALC880_MIC_EVENT:
  8375. alc883_clevo_m720_mic_automute(codec);
  8376. break;
  8377. default:
  8378. alc_automute_amp_unsol_event(codec, res);
  8379. break;
  8380. }
  8381. }
  8382. /* toggle speaker-output according to the hp-jack state */
  8383. static void alc883_2ch_fujitsu_pi2515_setup(struct hda_codec *codec)
  8384. {
  8385. struct alc_spec *spec = codec->spec;
  8386. spec->autocfg.hp_pins[0] = 0x14;
  8387. spec->autocfg.speaker_pins[0] = 0x15;
  8388. }
  8389. static void alc883_haier_w66_setup(struct hda_codec *codec)
  8390. {
  8391. struct alc_spec *spec = codec->spec;
  8392. spec->autocfg.hp_pins[0] = 0x1b;
  8393. spec->autocfg.speaker_pins[0] = 0x14;
  8394. }
  8395. static void alc883_lenovo_101e_ispeaker_automute(struct hda_codec *codec)
  8396. {
  8397. int bits = snd_hda_jack_detect(codec, 0x14) ? HDA_AMP_MUTE : 0;
  8398. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  8399. HDA_AMP_MUTE, bits);
  8400. }
  8401. static void alc883_lenovo_101e_all_automute(struct hda_codec *codec)
  8402. {
  8403. int bits = snd_hda_jack_detect(codec, 0x1b) ? HDA_AMP_MUTE : 0;
  8404. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  8405. HDA_AMP_MUTE, bits);
  8406. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  8407. HDA_AMP_MUTE, bits);
  8408. }
  8409. static void alc883_lenovo_101e_unsol_event(struct hda_codec *codec,
  8410. unsigned int res)
  8411. {
  8412. if ((res >> 26) == ALC880_HP_EVENT)
  8413. alc883_lenovo_101e_all_automute(codec);
  8414. if ((res >> 26) == ALC880_FRONT_EVENT)
  8415. alc883_lenovo_101e_ispeaker_automute(codec);
  8416. }
  8417. /* toggle speaker-output according to the hp-jack state */
  8418. static void alc883_acer_aspire_setup(struct hda_codec *codec)
  8419. {
  8420. struct alc_spec *spec = codec->spec;
  8421. spec->autocfg.hp_pins[0] = 0x14;
  8422. spec->autocfg.speaker_pins[0] = 0x15;
  8423. spec->autocfg.speaker_pins[1] = 0x16;
  8424. }
  8425. static struct hda_verb alc883_acer_eapd_verbs[] = {
  8426. /* HP Pin: output 0 (0x0c) */
  8427. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8428. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  8429. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  8430. /* Front Pin: output 0 (0x0c) */
  8431. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8432. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8433. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8434. {0x16, AC_VERB_SET_CONNECT_SEL, 0x00},
  8435. /* eanable EAPD on medion laptop */
  8436. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  8437. {0x20, AC_VERB_SET_PROC_COEF, 0x3050},
  8438. /* enable unsolicited event */
  8439. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8440. { }
  8441. };
  8442. static struct hda_verb alc888_acer_aspire_7730G_verbs[] = {
  8443. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  8444. {0x17, AC_VERB_SET_CONNECT_SEL, 0x02},
  8445. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8446. { } /* end */
  8447. };
  8448. static void alc888_6st_dell_setup(struct hda_codec *codec)
  8449. {
  8450. struct alc_spec *spec = codec->spec;
  8451. spec->autocfg.hp_pins[0] = 0x1b;
  8452. spec->autocfg.speaker_pins[0] = 0x14;
  8453. spec->autocfg.speaker_pins[1] = 0x15;
  8454. spec->autocfg.speaker_pins[2] = 0x16;
  8455. spec->autocfg.speaker_pins[3] = 0x17;
  8456. }
  8457. static void alc888_lenovo_sky_setup(struct hda_codec *codec)
  8458. {
  8459. struct alc_spec *spec = codec->spec;
  8460. spec->autocfg.hp_pins[0] = 0x1b;
  8461. spec->autocfg.speaker_pins[0] = 0x14;
  8462. spec->autocfg.speaker_pins[1] = 0x15;
  8463. spec->autocfg.speaker_pins[2] = 0x16;
  8464. spec->autocfg.speaker_pins[3] = 0x17;
  8465. spec->autocfg.speaker_pins[4] = 0x1a;
  8466. }
  8467. static void alc883_vaiott_setup(struct hda_codec *codec)
  8468. {
  8469. struct alc_spec *spec = codec->spec;
  8470. spec->autocfg.hp_pins[0] = 0x15;
  8471. spec->autocfg.speaker_pins[0] = 0x14;
  8472. spec->autocfg.speaker_pins[1] = 0x17;
  8473. }
  8474. static struct hda_verb alc888_asus_m90v_verbs[] = {
  8475. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  8476. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  8477. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  8478. /* enable unsolicited event */
  8479. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8480. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_MIC_EVENT | AC_USRSP_EN},
  8481. { } /* end */
  8482. };
  8483. static void alc883_mode2_setup(struct hda_codec *codec)
  8484. {
  8485. struct alc_spec *spec = codec->spec;
  8486. spec->autocfg.hp_pins[0] = 0x1b;
  8487. spec->autocfg.speaker_pins[0] = 0x14;
  8488. spec->autocfg.speaker_pins[1] = 0x15;
  8489. spec->autocfg.speaker_pins[2] = 0x16;
  8490. spec->ext_mic.pin = 0x18;
  8491. spec->int_mic.pin = 0x19;
  8492. spec->ext_mic.mux_idx = 0;
  8493. spec->int_mic.mux_idx = 1;
  8494. spec->auto_mic = 1;
  8495. }
  8496. static struct hda_verb alc888_asus_eee1601_verbs[] = {
  8497. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  8498. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  8499. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  8500. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  8501. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  8502. {0x20, AC_VERB_SET_COEF_INDEX, 0x0b},
  8503. {0x20, AC_VERB_SET_PROC_COEF, 0x0838},
  8504. /* enable unsolicited event */
  8505. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8506. { } /* end */
  8507. };
  8508. static void alc883_eee1601_inithook(struct hda_codec *codec)
  8509. {
  8510. struct alc_spec *spec = codec->spec;
  8511. spec->autocfg.hp_pins[0] = 0x14;
  8512. spec->autocfg.speaker_pins[0] = 0x1b;
  8513. alc_automute_pin(codec);
  8514. }
  8515. static struct hda_verb alc889A_mb31_verbs[] = {
  8516. /* Init rear pin (used as headphone output) */
  8517. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc4}, /* Apple Headphones */
  8518. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Connect to front */
  8519. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  8520. /* Init line pin (used as output in 4ch and 6ch mode) */
  8521. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x02}, /* Connect to CLFE */
  8522. /* Init line 2 pin (used as headphone out by default) */
  8523. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, /* Use as input */
  8524. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, /* Mute output */
  8525. { } /* end */
  8526. };
  8527. /* Mute speakers according to the headphone jack state */
  8528. static void alc889A_mb31_automute(struct hda_codec *codec)
  8529. {
  8530. unsigned int present;
  8531. /* Mute only in 2ch or 4ch mode */
  8532. if (snd_hda_codec_read(codec, 0x15, 0, AC_VERB_GET_CONNECT_SEL, 0)
  8533. == 0x00) {
  8534. present = snd_hda_jack_detect(codec, 0x15);
  8535. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  8536. HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
  8537. snd_hda_codec_amp_stereo(codec, 0x16, HDA_OUTPUT, 0,
  8538. HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
  8539. }
  8540. }
  8541. static void alc889A_mb31_unsol_event(struct hda_codec *codec, unsigned int res)
  8542. {
  8543. if ((res >> 26) == ALC880_HP_EVENT)
  8544. alc889A_mb31_automute(codec);
  8545. }
  8546. #ifdef CONFIG_SND_HDA_POWER_SAVE
  8547. #define alc882_loopbacks alc880_loopbacks
  8548. #endif
  8549. /* pcm configuration: identical with ALC880 */
  8550. #define alc882_pcm_analog_playback alc880_pcm_analog_playback
  8551. #define alc882_pcm_analog_capture alc880_pcm_analog_capture
  8552. #define alc882_pcm_digital_playback alc880_pcm_digital_playback
  8553. #define alc882_pcm_digital_capture alc880_pcm_digital_capture
  8554. static hda_nid_t alc883_slave_dig_outs[] = {
  8555. ALC1200_DIGOUT_NID, 0,
  8556. };
  8557. static hda_nid_t alc1200_slave_dig_outs[] = {
  8558. ALC883_DIGOUT_NID, 0,
  8559. };
  8560. /*
  8561. * configuration and preset
  8562. */
  8563. static const char *alc882_models[ALC882_MODEL_LAST] = {
  8564. [ALC882_3ST_DIG] = "3stack-dig",
  8565. [ALC882_6ST_DIG] = "6stack-dig",
  8566. [ALC882_ARIMA] = "arima",
  8567. [ALC882_W2JC] = "w2jc",
  8568. [ALC882_TARGA] = "targa",
  8569. [ALC882_ASUS_A7J] = "asus-a7j",
  8570. [ALC882_ASUS_A7M] = "asus-a7m",
  8571. [ALC885_MACPRO] = "macpro",
  8572. [ALC885_MB5] = "mb5",
  8573. [ALC885_MACMINI3] = "macmini3",
  8574. [ALC885_MBA21] = "mba21",
  8575. [ALC885_MBP3] = "mbp3",
  8576. [ALC885_IMAC24] = "imac24",
  8577. [ALC885_IMAC91] = "imac91",
  8578. [ALC883_3ST_2ch_DIG] = "3stack-2ch-dig",
  8579. [ALC883_3ST_6ch_DIG] = "3stack-6ch-dig",
  8580. [ALC883_3ST_6ch] = "3stack-6ch",
  8581. [ALC883_6ST_DIG] = "alc883-6stack-dig",
  8582. [ALC883_TARGA_DIG] = "targa-dig",
  8583. [ALC883_TARGA_2ch_DIG] = "targa-2ch-dig",
  8584. [ALC883_TARGA_8ch_DIG] = "targa-8ch-dig",
  8585. [ALC883_ACER] = "acer",
  8586. [ALC883_ACER_ASPIRE] = "acer-aspire",
  8587. [ALC888_ACER_ASPIRE_4930G] = "acer-aspire-4930g",
  8588. [ALC888_ACER_ASPIRE_6530G] = "acer-aspire-6530g",
  8589. [ALC888_ACER_ASPIRE_8930G] = "acer-aspire-8930g",
  8590. [ALC888_ACER_ASPIRE_7730G] = "acer-aspire-7730g",
  8591. [ALC883_MEDION] = "medion",
  8592. [ALC883_MEDION_MD2] = "medion-md2",
  8593. [ALC883_MEDION_WIM2160] = "medion-wim2160",
  8594. [ALC883_LAPTOP_EAPD] = "laptop-eapd",
  8595. [ALC883_LENOVO_101E_2ch] = "lenovo-101e",
  8596. [ALC883_LENOVO_NB0763] = "lenovo-nb0763",
  8597. [ALC888_LENOVO_MS7195_DIG] = "lenovo-ms7195-dig",
  8598. [ALC888_LENOVO_SKY] = "lenovo-sky",
  8599. [ALC883_HAIER_W66] = "haier-w66",
  8600. [ALC888_3ST_HP] = "3stack-hp",
  8601. [ALC888_6ST_DELL] = "6stack-dell",
  8602. [ALC883_MITAC] = "mitac",
  8603. [ALC883_CLEVO_M540R] = "clevo-m540r",
  8604. [ALC883_CLEVO_M720] = "clevo-m720",
  8605. [ALC883_FUJITSU_PI2515] = "fujitsu-pi2515",
  8606. [ALC888_FUJITSU_XA3530] = "fujitsu-xa3530",
  8607. [ALC883_3ST_6ch_INTEL] = "3stack-6ch-intel",
  8608. [ALC889A_INTEL] = "intel-alc889a",
  8609. [ALC889_INTEL] = "intel-x58",
  8610. [ALC1200_ASUS_P5Q] = "asus-p5q",
  8611. [ALC889A_MB31] = "mb31",
  8612. [ALC883_SONY_VAIO_TT] = "sony-vaio-tt",
  8613. [ALC882_AUTO] = "auto",
  8614. };
  8615. static struct snd_pci_quirk alc882_cfg_tbl[] = {
  8616. SND_PCI_QUIRK(0x1019, 0x6668, "ECS", ALC882_6ST_DIG),
  8617. SND_PCI_QUIRK(0x1025, 0x006c, "Acer Aspire 9810", ALC883_ACER_ASPIRE),
  8618. SND_PCI_QUIRK(0x1025, 0x0090, "Acer Aspire", ALC883_ACER_ASPIRE),
  8619. SND_PCI_QUIRK(0x1025, 0x010a, "Acer Ferrari 5000", ALC883_ACER_ASPIRE),
  8620. SND_PCI_QUIRK(0x1025, 0x0110, "Acer Aspire", ALC883_ACER_ASPIRE),
  8621. SND_PCI_QUIRK(0x1025, 0x0112, "Acer Aspire 9303", ALC883_ACER_ASPIRE),
  8622. SND_PCI_QUIRK(0x1025, 0x0121, "Acer Aspire 5920G", ALC883_ACER_ASPIRE),
  8623. SND_PCI_QUIRK(0x1025, 0x013e, "Acer Aspire 4930G",
  8624. ALC888_ACER_ASPIRE_4930G),
  8625. SND_PCI_QUIRK(0x1025, 0x013f, "Acer Aspire 5930G",
  8626. ALC888_ACER_ASPIRE_4930G),
  8627. SND_PCI_QUIRK(0x1025, 0x0145, "Acer Aspire 8930G",
  8628. ALC888_ACER_ASPIRE_8930G),
  8629. SND_PCI_QUIRK(0x1025, 0x0146, "Acer Aspire 6935G",
  8630. ALC888_ACER_ASPIRE_8930G),
  8631. SND_PCI_QUIRK(0x1025, 0x0157, "Acer X3200", ALC882_AUTO),
  8632. SND_PCI_QUIRK(0x1025, 0x0158, "Acer AX1700-U3700A", ALC882_AUTO),
  8633. SND_PCI_QUIRK(0x1025, 0x015e, "Acer Aspire 6930G",
  8634. ALC888_ACER_ASPIRE_6530G),
  8635. SND_PCI_QUIRK(0x1025, 0x0166, "Acer Aspire 6530G",
  8636. ALC888_ACER_ASPIRE_6530G),
  8637. SND_PCI_QUIRK(0x1025, 0x0142, "Acer Aspire 7730G",
  8638. ALC888_ACER_ASPIRE_7730G),
  8639. /* default Acer -- disabled as it causes more problems.
  8640. * model=auto should work fine now
  8641. */
  8642. /* SND_PCI_QUIRK_VENDOR(0x1025, "Acer laptop", ALC883_ACER), */
  8643. SND_PCI_QUIRK(0x1028, 0x020d, "Dell Inspiron 530", ALC888_6ST_DELL),
  8644. SND_PCI_QUIRK(0x103c, 0x2a3d, "HP Pavillion", ALC883_6ST_DIG),
  8645. SND_PCI_QUIRK(0x103c, 0x2a4f, "HP Samba", ALC888_3ST_HP),
  8646. SND_PCI_QUIRK(0x103c, 0x2a60, "HP Lucknow", ALC888_3ST_HP),
  8647. SND_PCI_QUIRK(0x103c, 0x2a61, "HP Nettle", ALC883_6ST_DIG),
  8648. SND_PCI_QUIRK(0x103c, 0x2a66, "HP Acacia", ALC888_3ST_HP),
  8649. SND_PCI_QUIRK(0x103c, 0x2a72, "HP Educ.ar", ALC888_3ST_HP),
  8650. SND_PCI_QUIRK(0x1043, 0x060d, "Asus A7J", ALC882_ASUS_A7J),
  8651. SND_PCI_QUIRK(0x1043, 0x1243, "Asus A7J", ALC882_ASUS_A7J),
  8652. SND_PCI_QUIRK(0x1043, 0x13c2, "Asus A7M", ALC882_ASUS_A7M),
  8653. SND_PCI_QUIRK(0x1043, 0x1873, "Asus M90V", ALC888_ASUS_M90V),
  8654. SND_PCI_QUIRK(0x1043, 0x1971, "Asus W2JC", ALC882_W2JC),
  8655. SND_PCI_QUIRK(0x1043, 0x817f, "Asus P5LD2", ALC882_6ST_DIG),
  8656. SND_PCI_QUIRK(0x1043, 0x81d8, "Asus P5WD", ALC882_6ST_DIG),
  8657. SND_PCI_QUIRK(0x1043, 0x8249, "Asus M2A-VM HDMI", ALC883_3ST_6ch_DIG),
  8658. SND_PCI_QUIRK(0x1043, 0x8284, "Asus Z37E", ALC883_6ST_DIG),
  8659. SND_PCI_QUIRK(0x1043, 0x82fe, "Asus P5Q-EM HDMI", ALC1200_ASUS_P5Q),
  8660. SND_PCI_QUIRK(0x1043, 0x835f, "Asus Eee 1601", ALC888_ASUS_EEE1601),
  8661. SND_PCI_QUIRK(0x104d, 0x9047, "Sony Vaio TT", ALC883_SONY_VAIO_TT),
  8662. SND_PCI_QUIRK(0x105b, 0x0ce8, "Foxconn P35AX-S", ALC883_6ST_DIG),
  8663. SND_PCI_QUIRK(0x105b, 0x6668, "Foxconn", ALC882_6ST_DIG),
  8664. SND_PCI_QUIRK(0x1071, 0x8227, "Mitac 82801H", ALC883_MITAC),
  8665. SND_PCI_QUIRK(0x1071, 0x8253, "Mitac 8252d", ALC883_MITAC),
  8666. SND_PCI_QUIRK(0x1071, 0x8258, "Evesham Voyaeger", ALC883_LAPTOP_EAPD),
  8667. SND_PCI_QUIRK(0x10f1, 0x2350, "TYAN-S2350", ALC888_6ST_DELL),
  8668. SND_PCI_QUIRK(0x108e, 0x534d, NULL, ALC883_3ST_6ch),
  8669. SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte P35 DS3R", ALC882_6ST_DIG),
  8670. SND_PCI_QUIRK(0x1462, 0x0349, "MSI", ALC883_TARGA_2ch_DIG),
  8671. SND_PCI_QUIRK(0x1462, 0x040d, "MSI", ALC883_TARGA_2ch_DIG),
  8672. SND_PCI_QUIRK(0x1462, 0x0579, "MSI", ALC883_TARGA_2ch_DIG),
  8673. SND_PCI_QUIRK(0x1462, 0x28fb, "Targa T8", ALC882_TARGA), /* MSI-1049 T8 */
  8674. SND_PCI_QUIRK(0x1462, 0x2fb3, "MSI", ALC882_AUTO),
  8675. SND_PCI_QUIRK(0x1462, 0x6668, "MSI", ALC882_6ST_DIG),
  8676. SND_PCI_QUIRK(0x1462, 0x3729, "MSI S420", ALC883_TARGA_DIG),
  8677. SND_PCI_QUIRK(0x1462, 0x3783, "NEC S970", ALC883_TARGA_DIG),
  8678. SND_PCI_QUIRK(0x1462, 0x3b7f, "MSI", ALC883_TARGA_2ch_DIG),
  8679. SND_PCI_QUIRK(0x1462, 0x3ef9, "MSI", ALC883_TARGA_DIG),
  8680. SND_PCI_QUIRK(0x1462, 0x3fc1, "MSI", ALC883_TARGA_DIG),
  8681. SND_PCI_QUIRK(0x1462, 0x3fc3, "MSI", ALC883_TARGA_DIG),
  8682. SND_PCI_QUIRK(0x1462, 0x3fcc, "MSI", ALC883_TARGA_DIG),
  8683. SND_PCI_QUIRK(0x1462, 0x3fdf, "MSI", ALC883_TARGA_DIG),
  8684. SND_PCI_QUIRK(0x1462, 0x42cd, "MSI", ALC883_TARGA_DIG),
  8685. SND_PCI_QUIRK(0x1462, 0x4314, "MSI", ALC883_TARGA_DIG),
  8686. SND_PCI_QUIRK(0x1462, 0x4319, "MSI", ALC883_TARGA_DIG),
  8687. SND_PCI_QUIRK(0x1462, 0x4324, "MSI", ALC883_TARGA_DIG),
  8688. SND_PCI_QUIRK(0x1462, 0x4570, "MSI Wind Top AE2220", ALC883_TARGA_DIG),
  8689. SND_PCI_QUIRK(0x1462, 0x6510, "MSI GX620", ALC883_TARGA_8ch_DIG),
  8690. SND_PCI_QUIRK(0x1462, 0x6668, "MSI", ALC883_6ST_DIG),
  8691. SND_PCI_QUIRK(0x1462, 0x7187, "MSI", ALC883_6ST_DIG),
  8692. SND_PCI_QUIRK(0x1462, 0x7250, "MSI", ALC883_6ST_DIG),
  8693. SND_PCI_QUIRK(0x1462, 0x7260, "MSI 7260", ALC883_TARGA_DIG),
  8694. SND_PCI_QUIRK(0x1462, 0x7267, "MSI", ALC883_3ST_6ch_DIG),
  8695. SND_PCI_QUIRK(0x1462, 0x7280, "MSI", ALC883_6ST_DIG),
  8696. SND_PCI_QUIRK(0x1462, 0x7327, "MSI", ALC883_6ST_DIG),
  8697. SND_PCI_QUIRK(0x1462, 0x7350, "MSI", ALC883_6ST_DIG),
  8698. SND_PCI_QUIRK(0x1462, 0x7437, "MSI NetOn AP1900", ALC883_TARGA_DIG),
  8699. SND_PCI_QUIRK(0x1462, 0xa422, "MSI", ALC883_TARGA_2ch_DIG),
  8700. SND_PCI_QUIRK(0x1462, 0xaa08, "MSI", ALC883_TARGA_2ch_DIG),
  8701. SND_PCI_QUIRK(0x147b, 0x1083, "Abit IP35-PRO", ALC883_6ST_DIG),
  8702. SND_PCI_QUIRK(0x1558, 0x0571, "Clevo laptop M570U", ALC883_3ST_6ch_DIG),
  8703. SND_PCI_QUIRK(0x1558, 0x0721, "Clevo laptop M720R", ALC883_CLEVO_M720),
  8704. SND_PCI_QUIRK(0x1558, 0x0722, "Clevo laptop M720SR", ALC883_CLEVO_M720),
  8705. SND_PCI_QUIRK(0x1558, 0x5409, "Clevo laptop M540R", ALC883_CLEVO_M540R),
  8706. SND_PCI_QUIRK_VENDOR(0x1558, "Clevo laptop", ALC883_LAPTOP_EAPD),
  8707. SND_PCI_QUIRK(0x15d9, 0x8780, "Supermicro PDSBA", ALC883_3ST_6ch),
  8708. /* SND_PCI_QUIRK(0x161f, 0x2054, "Arima W820", ALC882_ARIMA), */
  8709. SND_PCI_QUIRK(0x161f, 0x2054, "Medion laptop", ALC883_MEDION),
  8710. SND_PCI_QUIRK_MASK(0x1734, 0xfff0, 0x1100, "FSC AMILO Xi/Pi25xx",
  8711. ALC883_FUJITSU_PI2515),
  8712. SND_PCI_QUIRK_MASK(0x1734, 0xfff0, 0x1130, "Fujitsu AMILO Xa35xx",
  8713. ALC888_FUJITSU_XA3530),
  8714. SND_PCI_QUIRK(0x17aa, 0x101e, "Lenovo 101e", ALC883_LENOVO_101E_2ch),
  8715. SND_PCI_QUIRK(0x17aa, 0x2085, "Lenovo NB0763", ALC883_LENOVO_NB0763),
  8716. SND_PCI_QUIRK(0x17aa, 0x3bfc, "Lenovo NB0763", ALC883_LENOVO_NB0763),
  8717. SND_PCI_QUIRK(0x17aa, 0x3bfd, "Lenovo NB0763", ALC883_LENOVO_NB0763),
  8718. SND_PCI_QUIRK(0x17aa, 0x101d, "Lenovo Sky", ALC888_LENOVO_SKY),
  8719. SND_PCI_QUIRK(0x17c0, 0x4071, "MEDION MD2", ALC883_MEDION_MD2),
  8720. SND_PCI_QUIRK(0x17c0, 0x4085, "MEDION MD96630", ALC888_LENOVO_MS7195_DIG),
  8721. SND_PCI_QUIRK(0x17f2, 0x5000, "Albatron KI690-AM2", ALC883_6ST_DIG),
  8722. SND_PCI_QUIRK(0x1991, 0x5625, "Haier W66", ALC883_HAIER_W66),
  8723. SND_PCI_QUIRK(0x8086, 0x0001, "DG33BUC", ALC883_3ST_6ch_INTEL),
  8724. SND_PCI_QUIRK(0x8086, 0x0002, "DG33FBC", ALC883_3ST_6ch_INTEL),
  8725. SND_PCI_QUIRK(0x8086, 0x2503, "82801H", ALC883_MITAC),
  8726. SND_PCI_QUIRK(0x8086, 0x0022, "DX58SO", ALC889_INTEL),
  8727. SND_PCI_QUIRK(0x8086, 0x0021, "Intel IbexPeak", ALC889A_INTEL),
  8728. SND_PCI_QUIRK(0x8086, 0x3b56, "Intel IbexPeak", ALC889A_INTEL),
  8729. SND_PCI_QUIRK(0x8086, 0xd601, "D102GGC", ALC882_6ST_DIG),
  8730. {}
  8731. };
  8732. /* codec SSID table for Intel Mac */
  8733. static struct snd_pci_quirk alc882_ssid_cfg_tbl[] = {
  8734. SND_PCI_QUIRK(0x106b, 0x00a0, "MacBookPro 3,1", ALC885_MBP3),
  8735. SND_PCI_QUIRK(0x106b, 0x00a1, "Macbook", ALC885_MBP3),
  8736. SND_PCI_QUIRK(0x106b, 0x00a4, "MacbookPro 4,1", ALC885_MBP3),
  8737. SND_PCI_QUIRK(0x106b, 0x0c00, "Mac Pro", ALC885_MACPRO),
  8738. SND_PCI_QUIRK(0x106b, 0x1000, "iMac 24", ALC885_IMAC24),
  8739. SND_PCI_QUIRK(0x106b, 0x2800, "AppleTV", ALC885_IMAC24),
  8740. SND_PCI_QUIRK(0x106b, 0x2c00, "MacbookPro rev3", ALC885_MBP3),
  8741. SND_PCI_QUIRK(0x106b, 0x3000, "iMac", ALC889A_MB31),
  8742. SND_PCI_QUIRK(0x106b, 0x3200, "iMac 7,1 Aluminum", ALC882_ASUS_A7M),
  8743. SND_PCI_QUIRK(0x106b, 0x3400, "MacBookAir 1,1", ALC885_MBP3),
  8744. SND_PCI_QUIRK(0x106b, 0x3500, "MacBookAir 2,1", ALC885_MBA21),
  8745. SND_PCI_QUIRK(0x106b, 0x3600, "Macbook 3,1", ALC889A_MB31),
  8746. SND_PCI_QUIRK(0x106b, 0x3800, "MacbookPro 4,1", ALC885_MBP3),
  8747. SND_PCI_QUIRK(0x106b, 0x3e00, "iMac 24 Aluminum", ALC885_IMAC24),
  8748. SND_PCI_QUIRK(0x106b, 0x4900, "iMac 9,1 Aluminum", ALC885_IMAC91),
  8749. SND_PCI_QUIRK(0x106b, 0x3f00, "Macbook 5,1", ALC885_MB5),
  8750. SND_PCI_QUIRK(0x106b, 0x4a00, "Macbook 5,2", ALC885_MB5),
  8751. /* FIXME: HP jack sense seems not working for MBP 5,1 or 5,2,
  8752. * so apparently no perfect solution yet
  8753. */
  8754. SND_PCI_QUIRK(0x106b, 0x4000, "MacbookPro 5,1", ALC885_MB5),
  8755. SND_PCI_QUIRK(0x106b, 0x4600, "MacbookPro 5,2", ALC885_MB5),
  8756. SND_PCI_QUIRK(0x106b, 0x4100, "Macmini 3,1", ALC885_MACMINI3),
  8757. {} /* terminator */
  8758. };
  8759. static struct alc_config_preset alc882_presets[] = {
  8760. [ALC882_3ST_DIG] = {
  8761. .mixers = { alc882_base_mixer },
  8762. .init_verbs = { alc882_base_init_verbs,
  8763. alc882_adc1_init_verbs },
  8764. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8765. .dac_nids = alc882_dac_nids,
  8766. .dig_out_nid = ALC882_DIGOUT_NID,
  8767. .dig_in_nid = ALC882_DIGIN_NID,
  8768. .num_channel_mode = ARRAY_SIZE(alc882_ch_modes),
  8769. .channel_mode = alc882_ch_modes,
  8770. .need_dac_fix = 1,
  8771. .input_mux = &alc882_capture_source,
  8772. },
  8773. [ALC882_6ST_DIG] = {
  8774. .mixers = { alc882_base_mixer, alc882_chmode_mixer },
  8775. .init_verbs = { alc882_base_init_verbs,
  8776. alc882_adc1_init_verbs },
  8777. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8778. .dac_nids = alc882_dac_nids,
  8779. .dig_out_nid = ALC882_DIGOUT_NID,
  8780. .dig_in_nid = ALC882_DIGIN_NID,
  8781. .num_channel_mode = ARRAY_SIZE(alc882_sixstack_modes),
  8782. .channel_mode = alc882_sixstack_modes,
  8783. .input_mux = &alc882_capture_source,
  8784. },
  8785. [ALC882_ARIMA] = {
  8786. .mixers = { alc882_base_mixer, alc882_chmode_mixer },
  8787. .init_verbs = { alc882_base_init_verbs, alc882_adc1_init_verbs,
  8788. alc882_eapd_verbs },
  8789. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8790. .dac_nids = alc882_dac_nids,
  8791. .num_channel_mode = ARRAY_SIZE(alc882_sixstack_modes),
  8792. .channel_mode = alc882_sixstack_modes,
  8793. .input_mux = &alc882_capture_source,
  8794. },
  8795. [ALC882_W2JC] = {
  8796. .mixers = { alc882_w2jc_mixer, alc882_chmode_mixer },
  8797. .init_verbs = { alc882_base_init_verbs, alc882_adc1_init_verbs,
  8798. alc882_eapd_verbs, alc880_gpio1_init_verbs },
  8799. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8800. .dac_nids = alc882_dac_nids,
  8801. .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes),
  8802. .channel_mode = alc880_threestack_modes,
  8803. .need_dac_fix = 1,
  8804. .input_mux = &alc882_capture_source,
  8805. .dig_out_nid = ALC882_DIGOUT_NID,
  8806. },
  8807. [ALC885_MBA21] = {
  8808. .mixers = { alc885_mba21_mixer },
  8809. .init_verbs = { alc885_mba21_init_verbs, alc880_gpio1_init_verbs },
  8810. .num_dacs = 2,
  8811. .dac_nids = alc882_dac_nids,
  8812. .channel_mode = alc885_mba21_ch_modes,
  8813. .num_channel_mode = ARRAY_SIZE(alc885_mba21_ch_modes),
  8814. .input_mux = &alc882_capture_source,
  8815. .unsol_event = alc_automute_amp_unsol_event,
  8816. .setup = alc885_mba21_setup,
  8817. .init_hook = alc_automute_amp,
  8818. },
  8819. [ALC885_MBP3] = {
  8820. .mixers = { alc885_mbp3_mixer, alc882_chmode_mixer },
  8821. .init_verbs = { alc885_mbp3_init_verbs,
  8822. alc880_gpio1_init_verbs },
  8823. .num_dacs = 2,
  8824. .dac_nids = alc882_dac_nids,
  8825. .hp_nid = 0x04,
  8826. .channel_mode = alc885_mbp_4ch_modes,
  8827. .num_channel_mode = ARRAY_SIZE(alc885_mbp_4ch_modes),
  8828. .input_mux = &alc882_capture_source,
  8829. .dig_out_nid = ALC882_DIGOUT_NID,
  8830. .dig_in_nid = ALC882_DIGIN_NID,
  8831. .unsol_event = alc_automute_amp_unsol_event,
  8832. .setup = alc885_mbp3_setup,
  8833. .init_hook = alc_automute_amp,
  8834. },
  8835. [ALC885_MB5] = {
  8836. .mixers = { alc885_mb5_mixer, alc882_chmode_mixer },
  8837. .init_verbs = { alc885_mb5_init_verbs,
  8838. alc880_gpio1_init_verbs },
  8839. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8840. .dac_nids = alc882_dac_nids,
  8841. .channel_mode = alc885_mb5_6ch_modes,
  8842. .num_channel_mode = ARRAY_SIZE(alc885_mb5_6ch_modes),
  8843. .input_mux = &mb5_capture_source,
  8844. .dig_out_nid = ALC882_DIGOUT_NID,
  8845. .dig_in_nid = ALC882_DIGIN_NID,
  8846. .unsol_event = alc_automute_amp_unsol_event,
  8847. .setup = alc885_mb5_setup,
  8848. .init_hook = alc_automute_amp,
  8849. },
  8850. [ALC885_MACMINI3] = {
  8851. .mixers = { alc885_macmini3_mixer, alc882_chmode_mixer },
  8852. .init_verbs = { alc885_macmini3_init_verbs,
  8853. alc880_gpio1_init_verbs },
  8854. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8855. .dac_nids = alc882_dac_nids,
  8856. .channel_mode = alc885_macmini3_6ch_modes,
  8857. .num_channel_mode = ARRAY_SIZE(alc885_macmini3_6ch_modes),
  8858. .input_mux = &macmini3_capture_source,
  8859. .dig_out_nid = ALC882_DIGOUT_NID,
  8860. .dig_in_nid = ALC882_DIGIN_NID,
  8861. .unsol_event = alc_automute_amp_unsol_event,
  8862. .setup = alc885_macmini3_setup,
  8863. .init_hook = alc_automute_amp,
  8864. },
  8865. [ALC885_MACPRO] = {
  8866. .mixers = { alc882_macpro_mixer },
  8867. .init_verbs = { alc882_macpro_init_verbs },
  8868. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8869. .dac_nids = alc882_dac_nids,
  8870. .dig_out_nid = ALC882_DIGOUT_NID,
  8871. .dig_in_nid = ALC882_DIGIN_NID,
  8872. .num_channel_mode = ARRAY_SIZE(alc882_ch_modes),
  8873. .channel_mode = alc882_ch_modes,
  8874. .input_mux = &alc882_capture_source,
  8875. .init_hook = alc885_macpro_init_hook,
  8876. },
  8877. [ALC885_IMAC24] = {
  8878. .mixers = { alc885_imac24_mixer },
  8879. .init_verbs = { alc885_imac24_init_verbs },
  8880. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8881. .dac_nids = alc882_dac_nids,
  8882. .dig_out_nid = ALC882_DIGOUT_NID,
  8883. .dig_in_nid = ALC882_DIGIN_NID,
  8884. .num_channel_mode = ARRAY_SIZE(alc882_ch_modes),
  8885. .channel_mode = alc882_ch_modes,
  8886. .input_mux = &alc882_capture_source,
  8887. .unsol_event = alc_automute_amp_unsol_event,
  8888. .setup = alc885_imac24_setup,
  8889. .init_hook = alc885_imac24_init_hook,
  8890. },
  8891. [ALC885_IMAC91] = {
  8892. .mixers = {alc885_imac91_mixer},
  8893. .init_verbs = { alc885_imac91_init_verbs,
  8894. alc880_gpio1_init_verbs },
  8895. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8896. .dac_nids = alc882_dac_nids,
  8897. .channel_mode = alc885_mba21_ch_modes,
  8898. .num_channel_mode = ARRAY_SIZE(alc885_mba21_ch_modes),
  8899. .input_mux = &alc889A_imac91_capture_source,
  8900. .dig_out_nid = ALC882_DIGOUT_NID,
  8901. .dig_in_nid = ALC882_DIGIN_NID,
  8902. .unsol_event = alc_automute_amp_unsol_event,
  8903. .setup = alc885_imac91_setup,
  8904. .init_hook = alc_automute_amp,
  8905. },
  8906. [ALC882_TARGA] = {
  8907. .mixers = { alc882_targa_mixer, alc882_chmode_mixer },
  8908. .init_verbs = { alc882_base_init_verbs, alc882_adc1_init_verbs,
  8909. alc880_gpio3_init_verbs, alc882_targa_verbs},
  8910. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8911. .dac_nids = alc882_dac_nids,
  8912. .dig_out_nid = ALC882_DIGOUT_NID,
  8913. .num_adc_nids = ARRAY_SIZE(alc882_adc_nids),
  8914. .adc_nids = alc882_adc_nids,
  8915. .capsrc_nids = alc882_capsrc_nids,
  8916. .num_channel_mode = ARRAY_SIZE(alc882_3ST_6ch_modes),
  8917. .channel_mode = alc882_3ST_6ch_modes,
  8918. .need_dac_fix = 1,
  8919. .input_mux = &alc882_capture_source,
  8920. .unsol_event = alc882_targa_unsol_event,
  8921. .setup = alc882_targa_setup,
  8922. .init_hook = alc882_targa_automute,
  8923. },
  8924. [ALC882_ASUS_A7J] = {
  8925. .mixers = { alc882_asus_a7j_mixer, alc882_chmode_mixer },
  8926. .init_verbs = { alc882_base_init_verbs, alc882_adc1_init_verbs,
  8927. alc882_asus_a7j_verbs},
  8928. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8929. .dac_nids = alc882_dac_nids,
  8930. .dig_out_nid = ALC882_DIGOUT_NID,
  8931. .num_adc_nids = ARRAY_SIZE(alc882_adc_nids),
  8932. .adc_nids = alc882_adc_nids,
  8933. .capsrc_nids = alc882_capsrc_nids,
  8934. .num_channel_mode = ARRAY_SIZE(alc882_3ST_6ch_modes),
  8935. .channel_mode = alc882_3ST_6ch_modes,
  8936. .need_dac_fix = 1,
  8937. .input_mux = &alc882_capture_source,
  8938. },
  8939. [ALC882_ASUS_A7M] = {
  8940. .mixers = { alc882_asus_a7m_mixer, alc882_chmode_mixer },
  8941. .init_verbs = { alc882_base_init_verbs, alc882_adc1_init_verbs,
  8942. alc882_eapd_verbs, alc880_gpio1_init_verbs,
  8943. alc882_asus_a7m_verbs },
  8944. .num_dacs = ARRAY_SIZE(alc882_dac_nids),
  8945. .dac_nids = alc882_dac_nids,
  8946. .dig_out_nid = ALC882_DIGOUT_NID,
  8947. .num_channel_mode = ARRAY_SIZE(alc880_threestack_modes),
  8948. .channel_mode = alc880_threestack_modes,
  8949. .need_dac_fix = 1,
  8950. .input_mux = &alc882_capture_source,
  8951. },
  8952. [ALC883_3ST_2ch_DIG] = {
  8953. .mixers = { alc883_3ST_2ch_mixer },
  8954. .init_verbs = { alc883_init_verbs },
  8955. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  8956. .dac_nids = alc883_dac_nids,
  8957. .dig_out_nid = ALC883_DIGOUT_NID,
  8958. .dig_in_nid = ALC883_DIGIN_NID,
  8959. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  8960. .channel_mode = alc883_3ST_2ch_modes,
  8961. .input_mux = &alc883_capture_source,
  8962. },
  8963. [ALC883_3ST_6ch_DIG] = {
  8964. .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer },
  8965. .init_verbs = { alc883_init_verbs },
  8966. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  8967. .dac_nids = alc883_dac_nids,
  8968. .dig_out_nid = ALC883_DIGOUT_NID,
  8969. .dig_in_nid = ALC883_DIGIN_NID,
  8970. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  8971. .channel_mode = alc883_3ST_6ch_modes,
  8972. .need_dac_fix = 1,
  8973. .input_mux = &alc883_capture_source,
  8974. },
  8975. [ALC883_3ST_6ch] = {
  8976. .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer },
  8977. .init_verbs = { alc883_init_verbs },
  8978. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  8979. .dac_nids = alc883_dac_nids,
  8980. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  8981. .channel_mode = alc883_3ST_6ch_modes,
  8982. .need_dac_fix = 1,
  8983. .input_mux = &alc883_capture_source,
  8984. },
  8985. [ALC883_3ST_6ch_INTEL] = {
  8986. .mixers = { alc883_3ST_6ch_intel_mixer, alc883_chmode_mixer },
  8987. .init_verbs = { alc883_init_verbs },
  8988. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  8989. .dac_nids = alc883_dac_nids,
  8990. .dig_out_nid = ALC883_DIGOUT_NID,
  8991. .dig_in_nid = ALC883_DIGIN_NID,
  8992. .slave_dig_outs = alc883_slave_dig_outs,
  8993. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_intel_modes),
  8994. .channel_mode = alc883_3ST_6ch_intel_modes,
  8995. .need_dac_fix = 1,
  8996. .input_mux = &alc883_3stack_6ch_intel,
  8997. },
  8998. [ALC889A_INTEL] = {
  8999. .mixers = { alc885_8ch_intel_mixer, alc883_chmode_mixer },
  9000. .init_verbs = { alc885_init_verbs, alc885_init_input_verbs,
  9001. alc_hp15_unsol_verbs },
  9002. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9003. .dac_nids = alc883_dac_nids,
  9004. .num_adc_nids = ARRAY_SIZE(alc889_adc_nids),
  9005. .adc_nids = alc889_adc_nids,
  9006. .dig_out_nid = ALC883_DIGOUT_NID,
  9007. .dig_in_nid = ALC883_DIGIN_NID,
  9008. .slave_dig_outs = alc883_slave_dig_outs,
  9009. .num_channel_mode = ARRAY_SIZE(alc889_8ch_intel_modes),
  9010. .channel_mode = alc889_8ch_intel_modes,
  9011. .capsrc_nids = alc889_capsrc_nids,
  9012. .input_mux = &alc889_capture_source,
  9013. .setup = alc889_automute_setup,
  9014. .init_hook = alc_automute_amp,
  9015. .unsol_event = alc_automute_amp_unsol_event,
  9016. .need_dac_fix = 1,
  9017. },
  9018. [ALC889_INTEL] = {
  9019. .mixers = { alc885_8ch_intel_mixer, alc883_chmode_mixer },
  9020. .init_verbs = { alc885_init_verbs, alc889_init_input_verbs,
  9021. alc889_eapd_verbs, alc_hp15_unsol_verbs},
  9022. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9023. .dac_nids = alc883_dac_nids,
  9024. .num_adc_nids = ARRAY_SIZE(alc889_adc_nids),
  9025. .adc_nids = alc889_adc_nids,
  9026. .dig_out_nid = ALC883_DIGOUT_NID,
  9027. .dig_in_nid = ALC883_DIGIN_NID,
  9028. .slave_dig_outs = alc883_slave_dig_outs,
  9029. .num_channel_mode = ARRAY_SIZE(alc889_8ch_intel_modes),
  9030. .channel_mode = alc889_8ch_intel_modes,
  9031. .capsrc_nids = alc889_capsrc_nids,
  9032. .input_mux = &alc889_capture_source,
  9033. .setup = alc889_automute_setup,
  9034. .init_hook = alc889_intel_init_hook,
  9035. .unsol_event = alc_automute_amp_unsol_event,
  9036. .need_dac_fix = 1,
  9037. },
  9038. [ALC883_6ST_DIG] = {
  9039. .mixers = { alc883_base_mixer, alc883_chmode_mixer },
  9040. .init_verbs = { alc883_init_verbs },
  9041. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9042. .dac_nids = alc883_dac_nids,
  9043. .dig_out_nid = ALC883_DIGOUT_NID,
  9044. .dig_in_nid = ALC883_DIGIN_NID,
  9045. .num_channel_mode = ARRAY_SIZE(alc883_sixstack_modes),
  9046. .channel_mode = alc883_sixstack_modes,
  9047. .input_mux = &alc883_capture_source,
  9048. },
  9049. [ALC883_TARGA_DIG] = {
  9050. .mixers = { alc883_targa_mixer, alc883_chmode_mixer },
  9051. .init_verbs = { alc883_init_verbs, alc880_gpio3_init_verbs,
  9052. alc883_targa_verbs},
  9053. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9054. .dac_nids = alc883_dac_nids,
  9055. .dig_out_nid = ALC883_DIGOUT_NID,
  9056. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  9057. .channel_mode = alc883_3ST_6ch_modes,
  9058. .need_dac_fix = 1,
  9059. .input_mux = &alc883_capture_source,
  9060. .unsol_event = alc883_targa_unsol_event,
  9061. .setup = alc882_targa_setup,
  9062. .init_hook = alc882_targa_automute,
  9063. },
  9064. [ALC883_TARGA_2ch_DIG] = {
  9065. .mixers = { alc883_targa_2ch_mixer},
  9066. .init_verbs = { alc883_init_verbs, alc880_gpio3_init_verbs,
  9067. alc883_targa_verbs},
  9068. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9069. .dac_nids = alc883_dac_nids,
  9070. .adc_nids = alc883_adc_nids_alt,
  9071. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt),
  9072. .capsrc_nids = alc883_capsrc_nids,
  9073. .dig_out_nid = ALC883_DIGOUT_NID,
  9074. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9075. .channel_mode = alc883_3ST_2ch_modes,
  9076. .input_mux = &alc883_capture_source,
  9077. .unsol_event = alc883_targa_unsol_event,
  9078. .setup = alc882_targa_setup,
  9079. .init_hook = alc882_targa_automute,
  9080. },
  9081. [ALC883_TARGA_8ch_DIG] = {
  9082. .mixers = { alc883_targa_mixer, alc883_targa_8ch_mixer,
  9083. alc883_chmode_mixer },
  9084. .init_verbs = { alc883_init_verbs, alc880_gpio3_init_verbs,
  9085. alc883_targa_verbs },
  9086. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9087. .dac_nids = alc883_dac_nids,
  9088. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_rev),
  9089. .adc_nids = alc883_adc_nids_rev,
  9090. .capsrc_nids = alc883_capsrc_nids_rev,
  9091. .dig_out_nid = ALC883_DIGOUT_NID,
  9092. .dig_in_nid = ALC883_DIGIN_NID,
  9093. .num_channel_mode = ARRAY_SIZE(alc883_4ST_8ch_modes),
  9094. .channel_mode = alc883_4ST_8ch_modes,
  9095. .need_dac_fix = 1,
  9096. .input_mux = &alc883_capture_source,
  9097. .unsol_event = alc883_targa_unsol_event,
  9098. .setup = alc882_targa_setup,
  9099. .init_hook = alc882_targa_automute,
  9100. },
  9101. [ALC883_ACER] = {
  9102. .mixers = { alc883_base_mixer },
  9103. /* On TravelMate laptops, GPIO 0 enables the internal speaker
  9104. * and the headphone jack. Turn this on and rely on the
  9105. * standard mute methods whenever the user wants to turn
  9106. * these outputs off.
  9107. */
  9108. .init_verbs = { alc883_init_verbs, alc880_gpio1_init_verbs },
  9109. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9110. .dac_nids = alc883_dac_nids,
  9111. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9112. .channel_mode = alc883_3ST_2ch_modes,
  9113. .input_mux = &alc883_capture_source,
  9114. },
  9115. [ALC883_ACER_ASPIRE] = {
  9116. .mixers = { alc883_acer_aspire_mixer },
  9117. .init_verbs = { alc883_init_verbs, alc883_acer_eapd_verbs },
  9118. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9119. .dac_nids = alc883_dac_nids,
  9120. .dig_out_nid = ALC883_DIGOUT_NID,
  9121. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9122. .channel_mode = alc883_3ST_2ch_modes,
  9123. .input_mux = &alc883_capture_source,
  9124. .unsol_event = alc_automute_amp_unsol_event,
  9125. .setup = alc883_acer_aspire_setup,
  9126. .init_hook = alc_automute_amp,
  9127. },
  9128. [ALC888_ACER_ASPIRE_4930G] = {
  9129. .mixers = { alc888_base_mixer,
  9130. alc883_chmode_mixer },
  9131. .init_verbs = { alc883_init_verbs, alc880_gpio1_init_verbs,
  9132. alc888_acer_aspire_4930g_verbs },
  9133. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9134. .dac_nids = alc883_dac_nids,
  9135. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_rev),
  9136. .adc_nids = alc883_adc_nids_rev,
  9137. .capsrc_nids = alc883_capsrc_nids_rev,
  9138. .dig_out_nid = ALC883_DIGOUT_NID,
  9139. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  9140. .channel_mode = alc883_3ST_6ch_modes,
  9141. .need_dac_fix = 1,
  9142. .const_channel_count = 6,
  9143. .num_mux_defs =
  9144. ARRAY_SIZE(alc888_2_capture_sources),
  9145. .input_mux = alc888_2_capture_sources,
  9146. .unsol_event = alc_automute_amp_unsol_event,
  9147. .setup = alc888_acer_aspire_4930g_setup,
  9148. .init_hook = alc_automute_amp,
  9149. },
  9150. [ALC888_ACER_ASPIRE_6530G] = {
  9151. .mixers = { alc888_acer_aspire_6530_mixer },
  9152. .init_verbs = { alc883_init_verbs, alc880_gpio1_init_verbs,
  9153. alc888_acer_aspire_6530g_verbs },
  9154. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9155. .dac_nids = alc883_dac_nids,
  9156. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_rev),
  9157. .adc_nids = alc883_adc_nids_rev,
  9158. .capsrc_nids = alc883_capsrc_nids_rev,
  9159. .dig_out_nid = ALC883_DIGOUT_NID,
  9160. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9161. .channel_mode = alc883_3ST_2ch_modes,
  9162. .num_mux_defs =
  9163. ARRAY_SIZE(alc888_2_capture_sources),
  9164. .input_mux = alc888_acer_aspire_6530_sources,
  9165. .unsol_event = alc_automute_amp_unsol_event,
  9166. .setup = alc888_acer_aspire_6530g_setup,
  9167. .init_hook = alc_automute_amp,
  9168. },
  9169. [ALC888_ACER_ASPIRE_8930G] = {
  9170. .mixers = { alc889_acer_aspire_8930g_mixer,
  9171. alc883_chmode_mixer },
  9172. .init_verbs = { alc883_init_verbs, alc880_gpio1_init_verbs,
  9173. alc889_acer_aspire_8930g_verbs,
  9174. alc889_eapd_verbs},
  9175. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9176. .dac_nids = alc883_dac_nids,
  9177. .num_adc_nids = ARRAY_SIZE(alc889_adc_nids),
  9178. .adc_nids = alc889_adc_nids,
  9179. .capsrc_nids = alc889_capsrc_nids,
  9180. .dig_out_nid = ALC883_DIGOUT_NID,
  9181. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  9182. .channel_mode = alc883_3ST_6ch_modes,
  9183. .need_dac_fix = 1,
  9184. .const_channel_count = 6,
  9185. .num_mux_defs =
  9186. ARRAY_SIZE(alc889_capture_sources),
  9187. .input_mux = alc889_capture_sources,
  9188. .unsol_event = alc_automute_amp_unsol_event,
  9189. .setup = alc889_acer_aspire_8930g_setup,
  9190. .init_hook = alc_automute_amp,
  9191. #ifdef CONFIG_SND_HDA_POWER_SAVE
  9192. .power_hook = alc_power_eapd,
  9193. #endif
  9194. },
  9195. [ALC888_ACER_ASPIRE_7730G] = {
  9196. .mixers = { alc883_3ST_6ch_mixer,
  9197. alc883_chmode_mixer },
  9198. .init_verbs = { alc883_init_verbs, alc880_gpio1_init_verbs,
  9199. alc888_acer_aspire_7730G_verbs },
  9200. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9201. .dac_nids = alc883_dac_nids,
  9202. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_rev),
  9203. .adc_nids = alc883_adc_nids_rev,
  9204. .capsrc_nids = alc883_capsrc_nids_rev,
  9205. .dig_out_nid = ALC883_DIGOUT_NID,
  9206. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  9207. .channel_mode = alc883_3ST_6ch_modes,
  9208. .need_dac_fix = 1,
  9209. .const_channel_count = 6,
  9210. .input_mux = &alc883_capture_source,
  9211. .unsol_event = alc_automute_amp_unsol_event,
  9212. .setup = alc888_acer_aspire_6530g_setup,
  9213. .init_hook = alc_automute_amp,
  9214. },
  9215. [ALC883_MEDION] = {
  9216. .mixers = { alc883_fivestack_mixer,
  9217. alc883_chmode_mixer },
  9218. .init_verbs = { alc883_init_verbs,
  9219. alc883_medion_eapd_verbs },
  9220. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9221. .dac_nids = alc883_dac_nids,
  9222. .adc_nids = alc883_adc_nids_alt,
  9223. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt),
  9224. .capsrc_nids = alc883_capsrc_nids,
  9225. .num_channel_mode = ARRAY_SIZE(alc883_sixstack_modes),
  9226. .channel_mode = alc883_sixstack_modes,
  9227. .input_mux = &alc883_capture_source,
  9228. },
  9229. [ALC883_MEDION_MD2] = {
  9230. .mixers = { alc883_medion_md2_mixer},
  9231. .init_verbs = { alc883_init_verbs, alc883_medion_md2_verbs},
  9232. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9233. .dac_nids = alc883_dac_nids,
  9234. .dig_out_nid = ALC883_DIGOUT_NID,
  9235. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9236. .channel_mode = alc883_3ST_2ch_modes,
  9237. .input_mux = &alc883_capture_source,
  9238. .unsol_event = alc_automute_amp_unsol_event,
  9239. .setup = alc883_medion_md2_setup,
  9240. .init_hook = alc_automute_amp,
  9241. },
  9242. [ALC883_MEDION_WIM2160] = {
  9243. .mixers = { alc883_medion_wim2160_mixer },
  9244. .init_verbs = { alc883_init_verbs, alc883_medion_wim2160_verbs },
  9245. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9246. .dac_nids = alc883_dac_nids,
  9247. .dig_out_nid = ALC883_DIGOUT_NID,
  9248. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids),
  9249. .adc_nids = alc883_adc_nids,
  9250. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9251. .channel_mode = alc883_3ST_2ch_modes,
  9252. .input_mux = &alc883_capture_source,
  9253. .unsol_event = alc_automute_amp_unsol_event,
  9254. .setup = alc883_medion_wim2160_setup,
  9255. .init_hook = alc_automute_amp,
  9256. },
  9257. [ALC883_LAPTOP_EAPD] = {
  9258. .mixers = { alc883_base_mixer },
  9259. .init_verbs = { alc883_init_verbs, alc882_eapd_verbs },
  9260. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9261. .dac_nids = alc883_dac_nids,
  9262. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9263. .channel_mode = alc883_3ST_2ch_modes,
  9264. .input_mux = &alc883_capture_source,
  9265. },
  9266. [ALC883_CLEVO_M540R] = {
  9267. .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer },
  9268. .init_verbs = { alc883_init_verbs, alc883_clevo_m540r_verbs },
  9269. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9270. .dac_nids = alc883_dac_nids,
  9271. .dig_out_nid = ALC883_DIGOUT_NID,
  9272. .dig_in_nid = ALC883_DIGIN_NID,
  9273. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_clevo_modes),
  9274. .channel_mode = alc883_3ST_6ch_clevo_modes,
  9275. .need_dac_fix = 1,
  9276. .input_mux = &alc883_capture_source,
  9277. /* This machine has the hardware HP auto-muting, thus
  9278. * we need no software mute via unsol event
  9279. */
  9280. },
  9281. [ALC883_CLEVO_M720] = {
  9282. .mixers = { alc883_clevo_m720_mixer },
  9283. .init_verbs = { alc883_init_verbs, alc883_clevo_m720_verbs },
  9284. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9285. .dac_nids = alc883_dac_nids,
  9286. .dig_out_nid = ALC883_DIGOUT_NID,
  9287. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9288. .channel_mode = alc883_3ST_2ch_modes,
  9289. .input_mux = &alc883_capture_source,
  9290. .unsol_event = alc883_clevo_m720_unsol_event,
  9291. .setup = alc883_clevo_m720_setup,
  9292. .init_hook = alc883_clevo_m720_init_hook,
  9293. },
  9294. [ALC883_LENOVO_101E_2ch] = {
  9295. .mixers = { alc883_lenovo_101e_2ch_mixer},
  9296. .init_verbs = { alc883_init_verbs, alc883_lenovo_101e_verbs},
  9297. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9298. .dac_nids = alc883_dac_nids,
  9299. .adc_nids = alc883_adc_nids_alt,
  9300. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_alt),
  9301. .capsrc_nids = alc883_capsrc_nids,
  9302. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9303. .channel_mode = alc883_3ST_2ch_modes,
  9304. .input_mux = &alc883_lenovo_101e_capture_source,
  9305. .unsol_event = alc883_lenovo_101e_unsol_event,
  9306. .init_hook = alc883_lenovo_101e_all_automute,
  9307. },
  9308. [ALC883_LENOVO_NB0763] = {
  9309. .mixers = { alc883_lenovo_nb0763_mixer },
  9310. .init_verbs = { alc883_init_verbs, alc883_lenovo_nb0763_verbs},
  9311. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9312. .dac_nids = alc883_dac_nids,
  9313. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9314. .channel_mode = alc883_3ST_2ch_modes,
  9315. .need_dac_fix = 1,
  9316. .input_mux = &alc883_lenovo_nb0763_capture_source,
  9317. .unsol_event = alc_automute_amp_unsol_event,
  9318. .setup = alc883_medion_md2_setup,
  9319. .init_hook = alc_automute_amp,
  9320. },
  9321. [ALC888_LENOVO_MS7195_DIG] = {
  9322. .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer },
  9323. .init_verbs = { alc883_init_verbs, alc888_lenovo_ms7195_verbs},
  9324. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9325. .dac_nids = alc883_dac_nids,
  9326. .dig_out_nid = ALC883_DIGOUT_NID,
  9327. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  9328. .channel_mode = alc883_3ST_6ch_modes,
  9329. .need_dac_fix = 1,
  9330. .input_mux = &alc883_capture_source,
  9331. .unsol_event = alc883_lenovo_ms7195_unsol_event,
  9332. .init_hook = alc888_lenovo_ms7195_front_automute,
  9333. },
  9334. [ALC883_HAIER_W66] = {
  9335. .mixers = { alc883_targa_2ch_mixer},
  9336. .init_verbs = { alc883_init_verbs, alc883_haier_w66_verbs},
  9337. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9338. .dac_nids = alc883_dac_nids,
  9339. .dig_out_nid = ALC883_DIGOUT_NID,
  9340. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9341. .channel_mode = alc883_3ST_2ch_modes,
  9342. .input_mux = &alc883_capture_source,
  9343. .unsol_event = alc_automute_amp_unsol_event,
  9344. .setup = alc883_haier_w66_setup,
  9345. .init_hook = alc_automute_amp,
  9346. },
  9347. [ALC888_3ST_HP] = {
  9348. .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer },
  9349. .init_verbs = { alc883_init_verbs, alc888_3st_hp_verbs },
  9350. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9351. .dac_nids = alc883_dac_nids,
  9352. .num_channel_mode = ARRAY_SIZE(alc888_3st_hp_modes),
  9353. .channel_mode = alc888_3st_hp_modes,
  9354. .need_dac_fix = 1,
  9355. .input_mux = &alc883_capture_source,
  9356. .unsol_event = alc_automute_amp_unsol_event,
  9357. .setup = alc888_3st_hp_setup,
  9358. .init_hook = alc_automute_amp,
  9359. },
  9360. [ALC888_6ST_DELL] = {
  9361. .mixers = { alc883_base_mixer, alc883_chmode_mixer },
  9362. .init_verbs = { alc883_init_verbs, alc888_6st_dell_verbs },
  9363. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9364. .dac_nids = alc883_dac_nids,
  9365. .dig_out_nid = ALC883_DIGOUT_NID,
  9366. .dig_in_nid = ALC883_DIGIN_NID,
  9367. .num_channel_mode = ARRAY_SIZE(alc883_sixstack_modes),
  9368. .channel_mode = alc883_sixstack_modes,
  9369. .input_mux = &alc883_capture_source,
  9370. .unsol_event = alc_automute_amp_unsol_event,
  9371. .setup = alc888_6st_dell_setup,
  9372. .init_hook = alc_automute_amp,
  9373. },
  9374. [ALC883_MITAC] = {
  9375. .mixers = { alc883_mitac_mixer },
  9376. .init_verbs = { alc883_init_verbs, alc883_mitac_verbs },
  9377. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9378. .dac_nids = alc883_dac_nids,
  9379. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9380. .channel_mode = alc883_3ST_2ch_modes,
  9381. .input_mux = &alc883_capture_source,
  9382. .unsol_event = alc_automute_amp_unsol_event,
  9383. .setup = alc883_mitac_setup,
  9384. .init_hook = alc_automute_amp,
  9385. },
  9386. [ALC883_FUJITSU_PI2515] = {
  9387. .mixers = { alc883_2ch_fujitsu_pi2515_mixer },
  9388. .init_verbs = { alc883_init_verbs,
  9389. alc883_2ch_fujitsu_pi2515_verbs},
  9390. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9391. .dac_nids = alc883_dac_nids,
  9392. .dig_out_nid = ALC883_DIGOUT_NID,
  9393. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9394. .channel_mode = alc883_3ST_2ch_modes,
  9395. .input_mux = &alc883_fujitsu_pi2515_capture_source,
  9396. .unsol_event = alc_automute_amp_unsol_event,
  9397. .setup = alc883_2ch_fujitsu_pi2515_setup,
  9398. .init_hook = alc_automute_amp,
  9399. },
  9400. [ALC888_FUJITSU_XA3530] = {
  9401. .mixers = { alc888_base_mixer, alc883_chmode_mixer },
  9402. .init_verbs = { alc883_init_verbs,
  9403. alc888_fujitsu_xa3530_verbs },
  9404. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9405. .dac_nids = alc883_dac_nids,
  9406. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids_rev),
  9407. .adc_nids = alc883_adc_nids_rev,
  9408. .capsrc_nids = alc883_capsrc_nids_rev,
  9409. .dig_out_nid = ALC883_DIGOUT_NID,
  9410. .num_channel_mode = ARRAY_SIZE(alc888_4ST_8ch_intel_modes),
  9411. .channel_mode = alc888_4ST_8ch_intel_modes,
  9412. .num_mux_defs =
  9413. ARRAY_SIZE(alc888_2_capture_sources),
  9414. .input_mux = alc888_2_capture_sources,
  9415. .unsol_event = alc_automute_amp_unsol_event,
  9416. .setup = alc888_fujitsu_xa3530_setup,
  9417. .init_hook = alc_automute_amp,
  9418. },
  9419. [ALC888_LENOVO_SKY] = {
  9420. .mixers = { alc888_lenovo_sky_mixer, alc883_chmode_mixer },
  9421. .init_verbs = { alc883_init_verbs, alc888_lenovo_sky_verbs},
  9422. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9423. .dac_nids = alc883_dac_nids,
  9424. .dig_out_nid = ALC883_DIGOUT_NID,
  9425. .num_channel_mode = ARRAY_SIZE(alc883_sixstack_modes),
  9426. .channel_mode = alc883_sixstack_modes,
  9427. .need_dac_fix = 1,
  9428. .input_mux = &alc883_lenovo_sky_capture_source,
  9429. .unsol_event = alc_automute_amp_unsol_event,
  9430. .setup = alc888_lenovo_sky_setup,
  9431. .init_hook = alc_automute_amp,
  9432. },
  9433. [ALC888_ASUS_M90V] = {
  9434. .mixers = { alc883_3ST_6ch_mixer, alc883_chmode_mixer },
  9435. .init_verbs = { alc883_init_verbs, alc888_asus_m90v_verbs },
  9436. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9437. .dac_nids = alc883_dac_nids,
  9438. .dig_out_nid = ALC883_DIGOUT_NID,
  9439. .dig_in_nid = ALC883_DIGIN_NID,
  9440. .num_channel_mode = ARRAY_SIZE(alc883_3ST_6ch_modes),
  9441. .channel_mode = alc883_3ST_6ch_modes,
  9442. .need_dac_fix = 1,
  9443. .input_mux = &alc883_fujitsu_pi2515_capture_source,
  9444. .unsol_event = alc_sku_unsol_event,
  9445. .setup = alc883_mode2_setup,
  9446. .init_hook = alc_inithook,
  9447. },
  9448. [ALC888_ASUS_EEE1601] = {
  9449. .mixers = { alc883_asus_eee1601_mixer },
  9450. .cap_mixer = alc883_asus_eee1601_cap_mixer,
  9451. .init_verbs = { alc883_init_verbs, alc888_asus_eee1601_verbs },
  9452. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9453. .dac_nids = alc883_dac_nids,
  9454. .dig_out_nid = ALC883_DIGOUT_NID,
  9455. .dig_in_nid = ALC883_DIGIN_NID,
  9456. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9457. .channel_mode = alc883_3ST_2ch_modes,
  9458. .need_dac_fix = 1,
  9459. .input_mux = &alc883_asus_eee1601_capture_source,
  9460. .unsol_event = alc_sku_unsol_event,
  9461. .init_hook = alc883_eee1601_inithook,
  9462. },
  9463. [ALC1200_ASUS_P5Q] = {
  9464. .mixers = { alc883_base_mixer, alc883_chmode_mixer },
  9465. .init_verbs = { alc883_init_verbs },
  9466. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9467. .dac_nids = alc883_dac_nids,
  9468. .dig_out_nid = ALC1200_DIGOUT_NID,
  9469. .dig_in_nid = ALC883_DIGIN_NID,
  9470. .slave_dig_outs = alc1200_slave_dig_outs,
  9471. .num_channel_mode = ARRAY_SIZE(alc883_sixstack_modes),
  9472. .channel_mode = alc883_sixstack_modes,
  9473. .input_mux = &alc883_capture_source,
  9474. },
  9475. [ALC889A_MB31] = {
  9476. .mixers = { alc889A_mb31_mixer, alc883_chmode_mixer},
  9477. .init_verbs = { alc883_init_verbs, alc889A_mb31_verbs,
  9478. alc880_gpio1_init_verbs },
  9479. .adc_nids = alc883_adc_nids,
  9480. .num_adc_nids = ARRAY_SIZE(alc883_adc_nids),
  9481. .capsrc_nids = alc883_capsrc_nids,
  9482. .dac_nids = alc883_dac_nids,
  9483. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9484. .channel_mode = alc889A_mb31_6ch_modes,
  9485. .num_channel_mode = ARRAY_SIZE(alc889A_mb31_6ch_modes),
  9486. .input_mux = &alc889A_mb31_capture_source,
  9487. .dig_out_nid = ALC883_DIGOUT_NID,
  9488. .unsol_event = alc889A_mb31_unsol_event,
  9489. .init_hook = alc889A_mb31_automute,
  9490. },
  9491. [ALC883_SONY_VAIO_TT] = {
  9492. .mixers = { alc883_vaiott_mixer },
  9493. .init_verbs = { alc883_init_verbs, alc883_vaiott_verbs },
  9494. .num_dacs = ARRAY_SIZE(alc883_dac_nids),
  9495. .dac_nids = alc883_dac_nids,
  9496. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  9497. .channel_mode = alc883_3ST_2ch_modes,
  9498. .input_mux = &alc883_capture_source,
  9499. .unsol_event = alc_automute_amp_unsol_event,
  9500. .setup = alc883_vaiott_setup,
  9501. .init_hook = alc_automute_amp,
  9502. },
  9503. };
  9504. /*
  9505. * Pin config fixes
  9506. */
  9507. enum {
  9508. PINFIX_ABIT_AW9D_MAX,
  9509. PINFIX_PB_M5210,
  9510. };
  9511. static struct alc_pincfg alc882_abit_aw9d_pinfix[] = {
  9512. { 0x15, 0x01080104 }, /* side */
  9513. { 0x16, 0x01011012 }, /* rear */
  9514. { 0x17, 0x01016011 }, /* clfe */
  9515. { }
  9516. };
  9517. static const struct hda_verb pb_m5210_verbs[] = {
  9518. { 0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50 },
  9519. {}
  9520. };
  9521. static const struct alc_fixup alc882_fixups[] = {
  9522. [PINFIX_ABIT_AW9D_MAX] = {
  9523. .pins = alc882_abit_aw9d_pinfix
  9524. },
  9525. [PINFIX_PB_M5210] = {
  9526. .verbs = pb_m5210_verbs
  9527. },
  9528. };
  9529. static struct snd_pci_quirk alc882_fixup_tbl[] = {
  9530. SND_PCI_QUIRK(0x1025, 0x0155, "Packard-Bell M5120", PINFIX_PB_M5210),
  9531. SND_PCI_QUIRK(0x147b, 0x107a, "Abit AW9D-MAX", PINFIX_ABIT_AW9D_MAX),
  9532. {}
  9533. };
  9534. /*
  9535. * BIOS auto configuration
  9536. */
  9537. static int alc882_auto_create_input_ctls(struct hda_codec *codec,
  9538. const struct auto_pin_cfg *cfg)
  9539. {
  9540. return alc_auto_create_input_ctls(codec, cfg, 0x0b, 0x23, 0x22);
  9541. }
  9542. static void alc882_auto_set_output_and_unmute(struct hda_codec *codec,
  9543. hda_nid_t nid, int pin_type,
  9544. hda_nid_t dac)
  9545. {
  9546. int idx;
  9547. /* set as output */
  9548. alc_set_pin_output(codec, nid, pin_type);
  9549. if (dac == 0x25)
  9550. idx = 4;
  9551. else if (dac >= 0x02 && dac <= 0x05)
  9552. idx = dac - 2;
  9553. else
  9554. return;
  9555. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx);
  9556. }
  9557. static void alc882_auto_init_multi_out(struct hda_codec *codec)
  9558. {
  9559. struct alc_spec *spec = codec->spec;
  9560. int i;
  9561. for (i = 0; i <= HDA_SIDE; i++) {
  9562. hda_nid_t nid = spec->autocfg.line_out_pins[i];
  9563. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  9564. if (nid)
  9565. alc882_auto_set_output_and_unmute(codec, nid, pin_type,
  9566. spec->multiout.dac_nids[i]);
  9567. }
  9568. }
  9569. static void alc882_auto_init_hp_out(struct hda_codec *codec)
  9570. {
  9571. struct alc_spec *spec = codec->spec;
  9572. hda_nid_t pin, dac;
  9573. pin = spec->autocfg.hp_pins[0];
  9574. if (pin) {
  9575. dac = spec->multiout.hp_nid;
  9576. if (!dac)
  9577. dac = spec->multiout.dac_nids[0]; /* to front */
  9578. alc882_auto_set_output_and_unmute(codec, pin, PIN_HP, dac);
  9579. }
  9580. pin = spec->autocfg.speaker_pins[0];
  9581. if (pin) {
  9582. dac = spec->multiout.extra_out_nid[0];
  9583. if (!dac)
  9584. dac = spec->multiout.dac_nids[0]; /* to front */
  9585. alc882_auto_set_output_and_unmute(codec, pin, PIN_OUT, dac);
  9586. }
  9587. }
  9588. static void alc882_auto_init_analog_input(struct hda_codec *codec)
  9589. {
  9590. struct alc_spec *spec = codec->spec;
  9591. int i;
  9592. for (i = 0; i < AUTO_PIN_LAST; i++) {
  9593. hda_nid_t nid = spec->autocfg.input_pins[i];
  9594. if (!nid)
  9595. continue;
  9596. alc_set_input_pin(codec, nid, i);
  9597. if (get_wcaps(codec, nid) & AC_WCAP_OUT_AMP)
  9598. snd_hda_codec_write(codec, nid, 0,
  9599. AC_VERB_SET_AMP_GAIN_MUTE,
  9600. AMP_OUT_MUTE);
  9601. }
  9602. }
  9603. static void alc882_auto_init_input_src(struct hda_codec *codec)
  9604. {
  9605. struct alc_spec *spec = codec->spec;
  9606. int c;
  9607. for (c = 0; c < spec->num_adc_nids; c++) {
  9608. hda_nid_t conn_list[HDA_MAX_NUM_INPUTS];
  9609. hda_nid_t nid = spec->capsrc_nids[c];
  9610. unsigned int mux_idx;
  9611. const struct hda_input_mux *imux;
  9612. int conns, mute, idx, item;
  9613. conns = snd_hda_get_connections(codec, nid, conn_list,
  9614. ARRAY_SIZE(conn_list));
  9615. if (conns < 0)
  9616. continue;
  9617. mux_idx = c >= spec->num_mux_defs ? 0 : c;
  9618. imux = &spec->input_mux[mux_idx];
  9619. if (!imux->num_items && mux_idx > 0)
  9620. imux = &spec->input_mux[0];
  9621. for (idx = 0; idx < conns; idx++) {
  9622. /* if the current connection is the selected one,
  9623. * unmute it as default - otherwise mute it
  9624. */
  9625. mute = AMP_IN_MUTE(idx);
  9626. for (item = 0; item < imux->num_items; item++) {
  9627. if (imux->items[item].index == idx) {
  9628. if (spec->cur_mux[c] == item)
  9629. mute = AMP_IN_UNMUTE(idx);
  9630. break;
  9631. }
  9632. }
  9633. /* check if we have a selector or mixer
  9634. * we could check for the widget type instead, but
  9635. * just check for Amp-In presence (in case of mixer
  9636. * without amp-in there is something wrong, this
  9637. * function shouldn't be used or capsrc nid is wrong)
  9638. */
  9639. if (get_wcaps(codec, nid) & AC_WCAP_IN_AMP)
  9640. snd_hda_codec_write(codec, nid, 0,
  9641. AC_VERB_SET_AMP_GAIN_MUTE,
  9642. mute);
  9643. else if (mute != AMP_IN_MUTE(idx))
  9644. snd_hda_codec_write(codec, nid, 0,
  9645. AC_VERB_SET_CONNECT_SEL,
  9646. idx);
  9647. }
  9648. }
  9649. }
  9650. /* add mic boosts if needed */
  9651. static int alc_auto_add_mic_boost(struct hda_codec *codec)
  9652. {
  9653. struct alc_spec *spec = codec->spec;
  9654. int err;
  9655. hda_nid_t nid;
  9656. nid = spec->autocfg.input_pins[AUTO_PIN_MIC];
  9657. if (nid && (get_wcaps(codec, nid) & AC_WCAP_IN_AMP)) {
  9658. err = add_control(spec, ALC_CTL_WIDGET_VOL,
  9659. "Mic Boost",
  9660. HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_INPUT));
  9661. if (err < 0)
  9662. return err;
  9663. }
  9664. nid = spec->autocfg.input_pins[AUTO_PIN_FRONT_MIC];
  9665. if (nid && (get_wcaps(codec, nid) & AC_WCAP_IN_AMP)) {
  9666. err = add_control(spec, ALC_CTL_WIDGET_VOL,
  9667. "Front Mic Boost",
  9668. HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_INPUT));
  9669. if (err < 0)
  9670. return err;
  9671. }
  9672. return 0;
  9673. }
  9674. /* almost identical with ALC880 parser... */
  9675. static int alc882_parse_auto_config(struct hda_codec *codec)
  9676. {
  9677. struct alc_spec *spec = codec->spec;
  9678. static hda_nid_t alc882_ignore[] = { 0x1d, 0 };
  9679. int err;
  9680. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  9681. alc882_ignore);
  9682. if (err < 0)
  9683. return err;
  9684. if (!spec->autocfg.line_outs)
  9685. return 0; /* can't find valid BIOS pin config */
  9686. err = alc880_auto_fill_dac_nids(spec, &spec->autocfg);
  9687. if (err < 0)
  9688. return err;
  9689. err = alc880_auto_create_multi_out_ctls(spec, &spec->autocfg);
  9690. if (err < 0)
  9691. return err;
  9692. err = alc880_auto_create_extra_out(spec, spec->autocfg.hp_pins[0],
  9693. "Headphone");
  9694. if (err < 0)
  9695. return err;
  9696. err = alc880_auto_create_extra_out(spec,
  9697. spec->autocfg.speaker_pins[0],
  9698. "Speaker");
  9699. if (err < 0)
  9700. return err;
  9701. err = alc882_auto_create_input_ctls(codec, &spec->autocfg);
  9702. if (err < 0)
  9703. return err;
  9704. spec->multiout.max_channels = spec->multiout.num_dacs * 2;
  9705. alc_auto_parse_digital(codec);
  9706. if (spec->kctls.list)
  9707. add_mixer(spec, spec->kctls.list);
  9708. add_verb(spec, alc883_auto_init_verbs);
  9709. /* if ADC 0x07 is available, initialize it, too */
  9710. if (get_wcaps_type(get_wcaps(codec, 0x07)) == AC_WID_AUD_IN)
  9711. add_verb(spec, alc882_adc1_init_verbs);
  9712. spec->num_mux_defs = 1;
  9713. spec->input_mux = &spec->private_imux[0];
  9714. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
  9715. err = alc_auto_add_mic_boost(codec);
  9716. if (err < 0)
  9717. return err;
  9718. return 1; /* config found */
  9719. }
  9720. /* additional initialization for auto-configuration model */
  9721. static void alc882_auto_init(struct hda_codec *codec)
  9722. {
  9723. struct alc_spec *spec = codec->spec;
  9724. alc882_auto_init_multi_out(codec);
  9725. alc882_auto_init_hp_out(codec);
  9726. alc882_auto_init_analog_input(codec);
  9727. alc882_auto_init_input_src(codec);
  9728. alc_auto_init_digital(codec);
  9729. if (spec->unsol_event)
  9730. alc_inithook(codec);
  9731. }
  9732. static int patch_alc882(struct hda_codec *codec)
  9733. {
  9734. struct alc_spec *spec;
  9735. int err, board_config;
  9736. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  9737. if (spec == NULL)
  9738. return -ENOMEM;
  9739. codec->spec = spec;
  9740. alc_auto_parse_customize_define(codec);
  9741. switch (codec->vendor_id) {
  9742. case 0x10ec0882:
  9743. case 0x10ec0885:
  9744. break;
  9745. default:
  9746. /* ALC883 and variants */
  9747. alc_fix_pll_init(codec, 0x20, 0x0a, 10);
  9748. break;
  9749. }
  9750. board_config = snd_hda_check_board_config(codec, ALC882_MODEL_LAST,
  9751. alc882_models,
  9752. alc882_cfg_tbl);
  9753. if (board_config < 0 || board_config >= ALC882_MODEL_LAST)
  9754. board_config = snd_hda_check_board_codec_sid_config(codec,
  9755. ALC882_MODEL_LAST, alc882_models, alc882_ssid_cfg_tbl);
  9756. if (board_config < 0 || board_config >= ALC882_MODEL_LAST) {
  9757. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  9758. codec->chip_name);
  9759. board_config = ALC882_AUTO;
  9760. }
  9761. if (board_config == ALC882_AUTO)
  9762. alc_pick_fixup(codec, alc882_fixup_tbl, alc882_fixups, 1);
  9763. if (board_config == ALC882_AUTO) {
  9764. /* automatic parse from the BIOS config */
  9765. err = alc882_parse_auto_config(codec);
  9766. if (err < 0) {
  9767. alc_free(codec);
  9768. return err;
  9769. } else if (!err) {
  9770. printk(KERN_INFO
  9771. "hda_codec: Cannot set up configuration "
  9772. "from BIOS. Using base mode...\n");
  9773. board_config = ALC882_3ST_DIG;
  9774. }
  9775. }
  9776. if (has_cdefine_beep(codec)) {
  9777. err = snd_hda_attach_beep_device(codec, 0x1);
  9778. if (err < 0) {
  9779. alc_free(codec);
  9780. return err;
  9781. }
  9782. }
  9783. if (board_config != ALC882_AUTO)
  9784. setup_preset(codec, &alc882_presets[board_config]);
  9785. spec->stream_analog_playback = &alc882_pcm_analog_playback;
  9786. spec->stream_analog_capture = &alc882_pcm_analog_capture;
  9787. /* FIXME: setup DAC5 */
  9788. /*spec->stream_analog_alt_playback = &alc880_pcm_analog_alt_playback;*/
  9789. spec->stream_analog_alt_capture = &alc880_pcm_analog_alt_capture;
  9790. spec->stream_digital_playback = &alc882_pcm_digital_playback;
  9791. spec->stream_digital_capture = &alc882_pcm_digital_capture;
  9792. if (!spec->adc_nids && spec->input_mux) {
  9793. int i, j;
  9794. spec->num_adc_nids = 0;
  9795. for (i = 0; i < ARRAY_SIZE(alc882_adc_nids); i++) {
  9796. const struct hda_input_mux *imux = spec->input_mux;
  9797. hda_nid_t cap;
  9798. hda_nid_t items[16];
  9799. hda_nid_t nid = alc882_adc_nids[i];
  9800. unsigned int wcap = get_wcaps(codec, nid);
  9801. /* get type */
  9802. wcap = get_wcaps_type(wcap);
  9803. if (wcap != AC_WID_AUD_IN)
  9804. continue;
  9805. spec->private_adc_nids[spec->num_adc_nids] = nid;
  9806. err = snd_hda_get_connections(codec, nid, &cap, 1);
  9807. if (err < 0)
  9808. continue;
  9809. err = snd_hda_get_connections(codec, cap, items,
  9810. ARRAY_SIZE(items));
  9811. if (err < 0)
  9812. continue;
  9813. for (j = 0; j < imux->num_items; j++)
  9814. if (imux->items[j].index >= err)
  9815. break;
  9816. if (j < imux->num_items)
  9817. continue;
  9818. spec->private_capsrc_nids[spec->num_adc_nids] = cap;
  9819. spec->num_adc_nids++;
  9820. }
  9821. spec->adc_nids = spec->private_adc_nids;
  9822. spec->capsrc_nids = spec->private_capsrc_nids;
  9823. }
  9824. set_capture_mixer(codec);
  9825. if (has_cdefine_beep(codec))
  9826. set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT);
  9827. if (board_config == ALC882_AUTO)
  9828. alc_pick_fixup(codec, alc882_fixup_tbl, alc882_fixups, 0);
  9829. spec->vmaster_nid = 0x0c;
  9830. codec->patch_ops = alc_patch_ops;
  9831. if (board_config == ALC882_AUTO)
  9832. spec->init_hook = alc882_auto_init;
  9833. #ifdef CONFIG_SND_HDA_POWER_SAVE
  9834. if (!spec->loopback.amplist)
  9835. spec->loopback.amplist = alc882_loopbacks;
  9836. #endif
  9837. return 0;
  9838. }
  9839. /*
  9840. * ALC262 support
  9841. */
  9842. #define ALC262_DIGOUT_NID ALC880_DIGOUT_NID
  9843. #define ALC262_DIGIN_NID ALC880_DIGIN_NID
  9844. #define alc262_dac_nids alc260_dac_nids
  9845. #define alc262_adc_nids alc882_adc_nids
  9846. #define alc262_adc_nids_alt alc882_adc_nids_alt
  9847. #define alc262_capsrc_nids alc882_capsrc_nids
  9848. #define alc262_capsrc_nids_alt alc882_capsrc_nids_alt
  9849. #define alc262_modes alc260_modes
  9850. #define alc262_capture_source alc882_capture_source
  9851. static hda_nid_t alc262_dmic_adc_nids[1] = {
  9852. /* ADC0 */
  9853. 0x09
  9854. };
  9855. static hda_nid_t alc262_dmic_capsrc_nids[1] = { 0x22 };
  9856. static struct snd_kcontrol_new alc262_base_mixer[] = {
  9857. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  9858. HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  9859. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  9860. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  9861. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  9862. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  9863. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  9864. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  9865. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  9866. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  9867. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  9868. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  9869. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0D, 0x0, HDA_OUTPUT),
  9870. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  9871. HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  9872. HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x16, 2, 0x0, HDA_OUTPUT),
  9873. { } /* end */
  9874. };
  9875. /* update HP, line and mono-out pins according to the master switch */
  9876. static void alc262_hp_master_update(struct hda_codec *codec)
  9877. {
  9878. struct alc_spec *spec = codec->spec;
  9879. int val = spec->master_sw;
  9880. /* HP & line-out */
  9881. snd_hda_codec_write_cache(codec, 0x1b, 0,
  9882. AC_VERB_SET_PIN_WIDGET_CONTROL,
  9883. val ? PIN_HP : 0);
  9884. snd_hda_codec_write_cache(codec, 0x15, 0,
  9885. AC_VERB_SET_PIN_WIDGET_CONTROL,
  9886. val ? PIN_HP : 0);
  9887. /* mono (speaker) depending on the HP jack sense */
  9888. val = val && !spec->jack_present;
  9889. snd_hda_codec_write_cache(codec, 0x16, 0,
  9890. AC_VERB_SET_PIN_WIDGET_CONTROL,
  9891. val ? PIN_OUT : 0);
  9892. }
  9893. static void alc262_hp_bpc_automute(struct hda_codec *codec)
  9894. {
  9895. struct alc_spec *spec = codec->spec;
  9896. spec->jack_present = snd_hda_jack_detect(codec, 0x1b);
  9897. alc262_hp_master_update(codec);
  9898. }
  9899. static void alc262_hp_bpc_unsol_event(struct hda_codec *codec, unsigned int res)
  9900. {
  9901. if ((res >> 26) != ALC880_HP_EVENT)
  9902. return;
  9903. alc262_hp_bpc_automute(codec);
  9904. }
  9905. static void alc262_hp_wildwest_automute(struct hda_codec *codec)
  9906. {
  9907. struct alc_spec *spec = codec->spec;
  9908. spec->jack_present = snd_hda_jack_detect(codec, 0x15);
  9909. alc262_hp_master_update(codec);
  9910. }
  9911. static void alc262_hp_wildwest_unsol_event(struct hda_codec *codec,
  9912. unsigned int res)
  9913. {
  9914. if ((res >> 26) != ALC880_HP_EVENT)
  9915. return;
  9916. alc262_hp_wildwest_automute(codec);
  9917. }
  9918. #define alc262_hp_master_sw_get alc260_hp_master_sw_get
  9919. static int alc262_hp_master_sw_put(struct snd_kcontrol *kcontrol,
  9920. struct snd_ctl_elem_value *ucontrol)
  9921. {
  9922. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  9923. struct alc_spec *spec = codec->spec;
  9924. int val = !!*ucontrol->value.integer.value;
  9925. if (val == spec->master_sw)
  9926. return 0;
  9927. spec->master_sw = val;
  9928. alc262_hp_master_update(codec);
  9929. return 1;
  9930. }
  9931. #define ALC262_HP_MASTER_SWITCH \
  9932. { \
  9933. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  9934. .name = "Master Playback Switch", \
  9935. .info = snd_ctl_boolean_mono_info, \
  9936. .get = alc262_hp_master_sw_get, \
  9937. .put = alc262_hp_master_sw_put, \
  9938. }, \
  9939. { \
  9940. .iface = NID_MAPPING, \
  9941. .name = "Master Playback Switch", \
  9942. .private_value = 0x15 | (0x16 << 8) | (0x1b << 16), \
  9943. }
  9944. static struct snd_kcontrol_new alc262_HP_BPC_mixer[] = {
  9945. ALC262_HP_MASTER_SWITCH,
  9946. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  9947. HDA_CODEC_MUTE("Front Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  9948. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  9949. HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0e, 2, 0x0,
  9950. HDA_OUTPUT),
  9951. HDA_CODEC_MUTE_MONO("Speaker Playback Switch", 0x16, 2, 0x0,
  9952. HDA_OUTPUT),
  9953. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  9954. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  9955. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  9956. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  9957. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  9958. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  9959. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  9960. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  9961. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  9962. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  9963. HDA_CODEC_VOLUME("AUX IN Playback Volume", 0x0b, 0x06, HDA_INPUT),
  9964. HDA_CODEC_MUTE("AUX IN Playback Switch", 0x0b, 0x06, HDA_INPUT),
  9965. { } /* end */
  9966. };
  9967. static struct snd_kcontrol_new alc262_HP_BPC_WildWest_mixer[] = {
  9968. ALC262_HP_MASTER_SWITCH,
  9969. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  9970. HDA_CODEC_MUTE("Front Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  9971. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  9972. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  9973. HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0e, 2, 0x0,
  9974. HDA_OUTPUT),
  9975. HDA_CODEC_MUTE_MONO("Speaker Playback Switch", 0x16, 2, 0x0,
  9976. HDA_OUTPUT),
  9977. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x02, HDA_INPUT),
  9978. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x02, HDA_INPUT),
  9979. HDA_CODEC_VOLUME("Front Mic Boost", 0x1a, 0, HDA_INPUT),
  9980. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x01, HDA_INPUT),
  9981. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x01, HDA_INPUT),
  9982. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  9983. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  9984. { } /* end */
  9985. };
  9986. static struct snd_kcontrol_new alc262_HP_BPC_WildWest_option_mixer[] = {
  9987. HDA_CODEC_VOLUME("Rear Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  9988. HDA_CODEC_MUTE("Rear Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  9989. HDA_CODEC_VOLUME("Rear Mic Boost", 0x18, 0, HDA_INPUT),
  9990. { } /* end */
  9991. };
  9992. /* mute/unmute internal speaker according to the hp jack and mute state */
  9993. static void alc262_hp_t5735_setup(struct hda_codec *codec)
  9994. {
  9995. struct alc_spec *spec = codec->spec;
  9996. spec->autocfg.hp_pins[0] = 0x15;
  9997. spec->autocfg.speaker_pins[0] = 0x14;
  9998. }
  9999. static struct snd_kcontrol_new alc262_hp_t5735_mixer[] = {
  10000. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10001. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  10002. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  10003. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  10004. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10005. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10006. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10007. { } /* end */
  10008. };
  10009. static struct hda_verb alc262_hp_t5735_verbs[] = {
  10010. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  10011. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10012. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  10013. { }
  10014. };
  10015. static struct snd_kcontrol_new alc262_hp_rp5700_mixer[] = {
  10016. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10017. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  10018. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0e, 0x0, HDA_OUTPUT),
  10019. HDA_CODEC_MUTE("Speaker Playback Switch", 0x16, 0x0, HDA_OUTPUT),
  10020. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10021. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10022. { } /* end */
  10023. };
  10024. static struct hda_verb alc262_hp_rp5700_verbs[] = {
  10025. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  10026. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  10027. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  10028. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  10029. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  10030. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  10031. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  10032. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  10033. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x00 << 8))},
  10034. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x00 << 8))},
  10035. {}
  10036. };
  10037. static struct hda_input_mux alc262_hp_rp5700_capture_source = {
  10038. .num_items = 1,
  10039. .items = {
  10040. { "Line", 0x1 },
  10041. },
  10042. };
  10043. /* bind hp and internal speaker mute (with plug check) as master switch */
  10044. static void alc262_hippo_master_update(struct hda_codec *codec)
  10045. {
  10046. struct alc_spec *spec = codec->spec;
  10047. hda_nid_t hp_nid = spec->autocfg.hp_pins[0];
  10048. hda_nid_t line_nid = spec->autocfg.line_out_pins[0];
  10049. hda_nid_t speaker_nid = spec->autocfg.speaker_pins[0];
  10050. unsigned int mute;
  10051. /* HP */
  10052. mute = spec->master_sw ? 0 : HDA_AMP_MUTE;
  10053. snd_hda_codec_amp_stereo(codec, hp_nid, HDA_OUTPUT, 0,
  10054. HDA_AMP_MUTE, mute);
  10055. /* mute internal speaker per jack sense */
  10056. if (spec->jack_present)
  10057. mute = HDA_AMP_MUTE;
  10058. if (line_nid)
  10059. snd_hda_codec_amp_stereo(codec, line_nid, HDA_OUTPUT, 0,
  10060. HDA_AMP_MUTE, mute);
  10061. if (speaker_nid && speaker_nid != line_nid)
  10062. snd_hda_codec_amp_stereo(codec, speaker_nid, HDA_OUTPUT, 0,
  10063. HDA_AMP_MUTE, mute);
  10064. }
  10065. #define alc262_hippo_master_sw_get alc262_hp_master_sw_get
  10066. static int alc262_hippo_master_sw_put(struct snd_kcontrol *kcontrol,
  10067. struct snd_ctl_elem_value *ucontrol)
  10068. {
  10069. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  10070. struct alc_spec *spec = codec->spec;
  10071. int val = !!*ucontrol->value.integer.value;
  10072. if (val == spec->master_sw)
  10073. return 0;
  10074. spec->master_sw = val;
  10075. alc262_hippo_master_update(codec);
  10076. return 1;
  10077. }
  10078. #define ALC262_HIPPO_MASTER_SWITCH \
  10079. { \
  10080. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  10081. .name = "Master Playback Switch", \
  10082. .info = snd_ctl_boolean_mono_info, \
  10083. .get = alc262_hippo_master_sw_get, \
  10084. .put = alc262_hippo_master_sw_put, \
  10085. }, \
  10086. { \
  10087. .iface = NID_MAPPING, \
  10088. .name = "Master Playback Switch", \
  10089. .subdevice = SUBDEV_HP(0) | (SUBDEV_LINE(0) << 8) | \
  10090. (SUBDEV_SPEAKER(0) << 16), \
  10091. }
  10092. static struct snd_kcontrol_new alc262_hippo_mixer[] = {
  10093. ALC262_HIPPO_MASTER_SWITCH,
  10094. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10095. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  10096. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  10097. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  10098. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  10099. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10100. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10101. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10102. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10103. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10104. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  10105. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  10106. { } /* end */
  10107. };
  10108. static struct snd_kcontrol_new alc262_hippo1_mixer[] = {
  10109. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10110. ALC262_HIPPO_MASTER_SWITCH,
  10111. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  10112. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  10113. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  10114. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  10115. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10116. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10117. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10118. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10119. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10120. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  10121. { } /* end */
  10122. };
  10123. /* mute/unmute internal speaker according to the hp jack and mute state */
  10124. static void alc262_hippo_automute(struct hda_codec *codec)
  10125. {
  10126. struct alc_spec *spec = codec->spec;
  10127. hda_nid_t hp_nid = spec->autocfg.hp_pins[0];
  10128. spec->jack_present = snd_hda_jack_detect(codec, hp_nid);
  10129. alc262_hippo_master_update(codec);
  10130. }
  10131. static void alc262_hippo_unsol_event(struct hda_codec *codec, unsigned int res)
  10132. {
  10133. if ((res >> 26) != ALC880_HP_EVENT)
  10134. return;
  10135. alc262_hippo_automute(codec);
  10136. }
  10137. static void alc262_hippo_setup(struct hda_codec *codec)
  10138. {
  10139. struct alc_spec *spec = codec->spec;
  10140. spec->autocfg.hp_pins[0] = 0x15;
  10141. spec->autocfg.speaker_pins[0] = 0x14;
  10142. }
  10143. static void alc262_hippo1_setup(struct hda_codec *codec)
  10144. {
  10145. struct alc_spec *spec = codec->spec;
  10146. spec->autocfg.hp_pins[0] = 0x1b;
  10147. spec->autocfg.speaker_pins[0] = 0x14;
  10148. }
  10149. static struct snd_kcontrol_new alc262_sony_mixer[] = {
  10150. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10151. ALC262_HIPPO_MASTER_SWITCH,
  10152. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10153. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10154. HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10155. HDA_CODEC_MUTE("ATAPI Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10156. { } /* end */
  10157. };
  10158. static struct snd_kcontrol_new alc262_benq_t31_mixer[] = {
  10159. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10160. ALC262_HIPPO_MASTER_SWITCH,
  10161. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  10162. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10163. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10164. HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10165. HDA_CODEC_MUTE("ATAPI Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10166. { } /* end */
  10167. };
  10168. static struct snd_kcontrol_new alc262_tyan_mixer[] = {
  10169. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10170. HDA_BIND_MUTE("Master Playback Switch", 0x0c, 2, HDA_INPUT),
  10171. HDA_CODEC_VOLUME("Aux Playback Volume", 0x0b, 0x06, HDA_INPUT),
  10172. HDA_CODEC_MUTE("Aux Playback Switch", 0x0b, 0x06, HDA_INPUT),
  10173. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  10174. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  10175. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10176. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10177. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10178. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10179. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10180. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  10181. { } /* end */
  10182. };
  10183. static struct hda_verb alc262_tyan_verbs[] = {
  10184. /* Headphone automute */
  10185. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  10186. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10187. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  10188. /* P11 AUX_IN, white 4-pin connector */
  10189. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  10190. {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_1, 0xe1},
  10191. {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_2, 0x93},
  10192. {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_3, 0x19},
  10193. {}
  10194. };
  10195. /* unsolicited event for HP jack sensing */
  10196. static void alc262_tyan_setup(struct hda_codec *codec)
  10197. {
  10198. struct alc_spec *spec = codec->spec;
  10199. spec->autocfg.hp_pins[0] = 0x1b;
  10200. spec->autocfg.speaker_pins[0] = 0x15;
  10201. }
  10202. #define alc262_capture_mixer alc882_capture_mixer
  10203. #define alc262_capture_alt_mixer alc882_capture_alt_mixer
  10204. /*
  10205. * generic initialization of ADC, input mixers and output mixers
  10206. */
  10207. static struct hda_verb alc262_init_verbs[] = {
  10208. /*
  10209. * Unmute ADC0-2 and set the default input to mic-in
  10210. */
  10211. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  10212. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10213. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  10214. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10215. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  10216. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10217. /* Mute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
  10218. * mixer widget
  10219. * Note: PASD motherboards uses the Line In 2 as the input for
  10220. * front panel mic (mic 2)
  10221. */
  10222. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  10223. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  10224. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  10225. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  10226. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  10227. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  10228. /*
  10229. * Set up output mixers (0x0c - 0x0e)
  10230. */
  10231. /* set vol=0 to output mixers */
  10232. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10233. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10234. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10235. /* set up input amps for analog loopback */
  10236. /* Amp Indices: DAC = 0, mixer = 1 */
  10237. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10238. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10239. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10240. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10241. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10242. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10243. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  10244. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  10245. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  10246. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  10247. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  10248. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  10249. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  10250. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  10251. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  10252. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  10253. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  10254. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  10255. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  10256. /* FIXME: use matrix-type input source selection */
  10257. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  10258. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  10259. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10260. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10261. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10262. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10263. /* Input mixer2 */
  10264. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10265. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10266. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10267. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10268. /* Input mixer3 */
  10269. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10270. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10271. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10272. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10273. { }
  10274. };
  10275. static struct hda_verb alc262_eapd_verbs[] = {
  10276. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  10277. {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
  10278. { }
  10279. };
  10280. static struct hda_verb alc262_hippo1_unsol_verbs[] = {
  10281. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  10282. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  10283. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  10284. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  10285. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10286. {}
  10287. };
  10288. static struct hda_verb alc262_sony_unsol_verbs[] = {
  10289. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  10290. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  10291. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24}, // Front Mic
  10292. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  10293. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10294. {}
  10295. };
  10296. static struct snd_kcontrol_new alc262_toshiba_s06_mixer[] = {
  10297. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10298. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  10299. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  10300. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10301. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10302. { } /* end */
  10303. };
  10304. static struct hda_verb alc262_toshiba_s06_verbs[] = {
  10305. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  10306. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  10307. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10308. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  10309. {0x22, AC_VERB_SET_CONNECT_SEL, 0x09},
  10310. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  10311. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  10312. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  10313. {}
  10314. };
  10315. static void alc262_toshiba_s06_setup(struct hda_codec *codec)
  10316. {
  10317. struct alc_spec *spec = codec->spec;
  10318. spec->autocfg.hp_pins[0] = 0x15;
  10319. spec->autocfg.speaker_pins[0] = 0x14;
  10320. spec->ext_mic.pin = 0x18;
  10321. spec->ext_mic.mux_idx = 0;
  10322. spec->int_mic.pin = 0x12;
  10323. spec->int_mic.mux_idx = 9;
  10324. spec->auto_mic = 1;
  10325. }
  10326. /*
  10327. * nec model
  10328. * 0x15 = headphone
  10329. * 0x16 = internal speaker
  10330. * 0x18 = external mic
  10331. */
  10332. static struct snd_kcontrol_new alc262_nec_mixer[] = {
  10333. HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  10334. HDA_CODEC_MUTE_MONO("Speaker Playback Switch", 0x16, 0, 0x0, HDA_OUTPUT),
  10335. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10336. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10337. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10338. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  10339. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  10340. { } /* end */
  10341. };
  10342. static struct hda_verb alc262_nec_verbs[] = {
  10343. /* Unmute Speaker */
  10344. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  10345. /* Headphone */
  10346. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  10347. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  10348. /* External mic to headphone */
  10349. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10350. /* External mic to speaker */
  10351. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10352. {}
  10353. };
  10354. /*
  10355. * fujitsu model
  10356. * 0x14 = headphone/spdif-out, 0x15 = internal speaker,
  10357. * 0x1b = port replicator headphone out
  10358. */
  10359. #define ALC_HP_EVENT 0x37
  10360. static struct hda_verb alc262_fujitsu_unsol_verbs[] = {
  10361. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  10362. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10363. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  10364. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10365. {}
  10366. };
  10367. static struct hda_verb alc262_lenovo_3000_unsol_verbs[] = {
  10368. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  10369. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10370. {}
  10371. };
  10372. static struct hda_verb alc262_lenovo_3000_init_verbs[] = {
  10373. /* Front Mic pin: input vref at 50% */
  10374. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
  10375. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  10376. {}
  10377. };
  10378. static struct hda_input_mux alc262_fujitsu_capture_source = {
  10379. .num_items = 3,
  10380. .items = {
  10381. { "Mic", 0x0 },
  10382. { "Int Mic", 0x1 },
  10383. { "CD", 0x4 },
  10384. },
  10385. };
  10386. static struct hda_input_mux alc262_HP_capture_source = {
  10387. .num_items = 5,
  10388. .items = {
  10389. { "Mic", 0x0 },
  10390. { "Front Mic", 0x1 },
  10391. { "Line", 0x2 },
  10392. { "CD", 0x4 },
  10393. { "AUX IN", 0x6 },
  10394. },
  10395. };
  10396. static struct hda_input_mux alc262_HP_D7000_capture_source = {
  10397. .num_items = 4,
  10398. .items = {
  10399. { "Mic", 0x0 },
  10400. { "Front Mic", 0x2 },
  10401. { "Line", 0x1 },
  10402. { "CD", 0x4 },
  10403. },
  10404. };
  10405. /* mute/unmute internal speaker according to the hp jacks and mute state */
  10406. static void alc262_fujitsu_automute(struct hda_codec *codec, int force)
  10407. {
  10408. struct alc_spec *spec = codec->spec;
  10409. unsigned int mute;
  10410. if (force || !spec->sense_updated) {
  10411. spec->jack_present = snd_hda_jack_detect(codec, 0x14) ||
  10412. snd_hda_jack_detect(codec, 0x1b);
  10413. spec->sense_updated = 1;
  10414. }
  10415. /* unmute internal speaker only if both HPs are unplugged and
  10416. * master switch is on
  10417. */
  10418. if (spec->jack_present)
  10419. mute = HDA_AMP_MUTE;
  10420. else
  10421. mute = snd_hda_codec_amp_read(codec, 0x14, 0, HDA_OUTPUT, 0);
  10422. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  10423. HDA_AMP_MUTE, mute);
  10424. }
  10425. /* unsolicited event for HP jack sensing */
  10426. static void alc262_fujitsu_unsol_event(struct hda_codec *codec,
  10427. unsigned int res)
  10428. {
  10429. if ((res >> 26) != ALC_HP_EVENT)
  10430. return;
  10431. alc262_fujitsu_automute(codec, 1);
  10432. }
  10433. static void alc262_fujitsu_init_hook(struct hda_codec *codec)
  10434. {
  10435. alc262_fujitsu_automute(codec, 1);
  10436. }
  10437. /* bind volumes of both NID 0x0c and 0x0d */
  10438. static struct hda_bind_ctls alc262_fujitsu_bind_master_vol = {
  10439. .ops = &snd_hda_bind_vol,
  10440. .values = {
  10441. HDA_COMPOSE_AMP_VAL(0x0c, 3, 0, HDA_OUTPUT),
  10442. HDA_COMPOSE_AMP_VAL(0x0d, 3, 0, HDA_OUTPUT),
  10443. 0
  10444. },
  10445. };
  10446. /* mute/unmute internal speaker according to the hp jack and mute state */
  10447. static void alc262_lenovo_3000_automute(struct hda_codec *codec, int force)
  10448. {
  10449. struct alc_spec *spec = codec->spec;
  10450. unsigned int mute;
  10451. if (force || !spec->sense_updated) {
  10452. spec->jack_present = snd_hda_jack_detect(codec, 0x1b);
  10453. spec->sense_updated = 1;
  10454. }
  10455. if (spec->jack_present) {
  10456. /* mute internal speaker */
  10457. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  10458. HDA_AMP_MUTE, HDA_AMP_MUTE);
  10459. snd_hda_codec_amp_stereo(codec, 0x16, HDA_OUTPUT, 0,
  10460. HDA_AMP_MUTE, HDA_AMP_MUTE);
  10461. } else {
  10462. /* unmute internal speaker if necessary */
  10463. mute = snd_hda_codec_amp_read(codec, 0x1b, 0, HDA_OUTPUT, 0);
  10464. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  10465. HDA_AMP_MUTE, mute);
  10466. snd_hda_codec_amp_stereo(codec, 0x16, HDA_OUTPUT, 0,
  10467. HDA_AMP_MUTE, mute);
  10468. }
  10469. }
  10470. /* unsolicited event for HP jack sensing */
  10471. static void alc262_lenovo_3000_unsol_event(struct hda_codec *codec,
  10472. unsigned int res)
  10473. {
  10474. if ((res >> 26) != ALC_HP_EVENT)
  10475. return;
  10476. alc262_lenovo_3000_automute(codec, 1);
  10477. }
  10478. static int amp_stereo_mute_update(struct hda_codec *codec, hda_nid_t nid,
  10479. int dir, int idx, long *valp)
  10480. {
  10481. int i, change = 0;
  10482. for (i = 0; i < 2; i++, valp++)
  10483. change |= snd_hda_codec_amp_update(codec, nid, i, dir, idx,
  10484. HDA_AMP_MUTE,
  10485. *valp ? 0 : HDA_AMP_MUTE);
  10486. return change;
  10487. }
  10488. /* bind hp and internal speaker mute (with plug check) */
  10489. static int alc262_fujitsu_master_sw_put(struct snd_kcontrol *kcontrol,
  10490. struct snd_ctl_elem_value *ucontrol)
  10491. {
  10492. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  10493. long *valp = ucontrol->value.integer.value;
  10494. int change;
  10495. change = amp_stereo_mute_update(codec, 0x14, HDA_OUTPUT, 0, valp);
  10496. change |= amp_stereo_mute_update(codec, 0x1b, HDA_OUTPUT, 0, valp);
  10497. if (change)
  10498. alc262_fujitsu_automute(codec, 0);
  10499. return change;
  10500. }
  10501. static struct snd_kcontrol_new alc262_fujitsu_mixer[] = {
  10502. HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
  10503. {
  10504. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  10505. .name = "Master Playback Switch",
  10506. .subdevice = HDA_SUBDEV_AMP_FLAG,
  10507. .info = snd_hda_mixer_amp_switch_info,
  10508. .get = snd_hda_mixer_amp_switch_get,
  10509. .put = alc262_fujitsu_master_sw_put,
  10510. .private_value = HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  10511. },
  10512. {
  10513. .iface = NID_MAPPING,
  10514. .name = "Master Playback Switch",
  10515. .private_value = 0x1b,
  10516. },
  10517. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  10518. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  10519. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10520. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10521. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10522. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  10523. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  10524. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  10525. { } /* end */
  10526. };
  10527. /* bind hp and internal speaker mute (with plug check) */
  10528. static int alc262_lenovo_3000_master_sw_put(struct snd_kcontrol *kcontrol,
  10529. struct snd_ctl_elem_value *ucontrol)
  10530. {
  10531. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  10532. long *valp = ucontrol->value.integer.value;
  10533. int change;
  10534. change = amp_stereo_mute_update(codec, 0x1b, HDA_OUTPUT, 0, valp);
  10535. if (change)
  10536. alc262_lenovo_3000_automute(codec, 0);
  10537. return change;
  10538. }
  10539. static struct snd_kcontrol_new alc262_lenovo_3000_mixer[] = {
  10540. HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
  10541. {
  10542. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  10543. .name = "Master Playback Switch",
  10544. .subdevice = HDA_SUBDEV_AMP_FLAG,
  10545. .info = snd_hda_mixer_amp_switch_info,
  10546. .get = snd_hda_mixer_amp_switch_get,
  10547. .put = alc262_lenovo_3000_master_sw_put,
  10548. .private_value = HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
  10549. },
  10550. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  10551. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  10552. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10553. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10554. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10555. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  10556. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  10557. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  10558. { } /* end */
  10559. };
  10560. static struct snd_kcontrol_new alc262_toshiba_rx1_mixer[] = {
  10561. HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
  10562. ALC262_HIPPO_MASTER_SWITCH,
  10563. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  10564. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  10565. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  10566. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10567. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10568. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  10569. { } /* end */
  10570. };
  10571. /* additional init verbs for Benq laptops */
  10572. static struct hda_verb alc262_EAPD_verbs[] = {
  10573. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  10574. {0x20, AC_VERB_SET_PROC_COEF, 0x3070},
  10575. {}
  10576. };
  10577. static struct hda_verb alc262_benq_t31_EAPD_verbs[] = {
  10578. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  10579. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  10580. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  10581. {0x20, AC_VERB_SET_PROC_COEF, 0x3050},
  10582. {}
  10583. };
  10584. /* Samsung Q1 Ultra Vista model setup */
  10585. static struct snd_kcontrol_new alc262_ultra_mixer[] = {
  10586. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  10587. HDA_BIND_MUTE("Master Playback Switch", 0x0c, 2, HDA_INPUT),
  10588. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  10589. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  10590. HDA_CODEC_VOLUME("Mic Boost", 0x19, 0, HDA_INPUT),
  10591. HDA_CODEC_VOLUME("Headphone Mic Boost", 0x15, 0, HDA_INPUT),
  10592. { } /* end */
  10593. };
  10594. static struct hda_verb alc262_ultra_verbs[] = {
  10595. /* output mixer */
  10596. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  10597. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  10598. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10599. /* speaker */
  10600. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  10601. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  10602. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10603. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  10604. /* HP */
  10605. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10606. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  10607. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10608. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  10609. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  10610. /* internal mic */
  10611. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  10612. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  10613. /* ADC, choose mic */
  10614. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  10615. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  10616. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10617. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  10618. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  10619. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  10620. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)},
  10621. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)},
  10622. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)},
  10623. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(8)},
  10624. {}
  10625. };
  10626. /* mute/unmute internal speaker according to the hp jack and mute state */
  10627. static void alc262_ultra_automute(struct hda_codec *codec)
  10628. {
  10629. struct alc_spec *spec = codec->spec;
  10630. unsigned int mute;
  10631. mute = 0;
  10632. /* auto-mute only when HP is used as HP */
  10633. if (!spec->cur_mux[0]) {
  10634. spec->jack_present = snd_hda_jack_detect(codec, 0x15);
  10635. if (spec->jack_present)
  10636. mute = HDA_AMP_MUTE;
  10637. }
  10638. /* mute/unmute internal speaker */
  10639. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  10640. HDA_AMP_MUTE, mute);
  10641. /* mute/unmute HP */
  10642. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  10643. HDA_AMP_MUTE, mute ? 0 : HDA_AMP_MUTE);
  10644. }
  10645. /* unsolicited event for HP jack sensing */
  10646. static void alc262_ultra_unsol_event(struct hda_codec *codec,
  10647. unsigned int res)
  10648. {
  10649. if ((res >> 26) != ALC880_HP_EVENT)
  10650. return;
  10651. alc262_ultra_automute(codec);
  10652. }
  10653. static struct hda_input_mux alc262_ultra_capture_source = {
  10654. .num_items = 2,
  10655. .items = {
  10656. { "Mic", 0x1 },
  10657. { "Headphone", 0x7 },
  10658. },
  10659. };
  10660. static int alc262_ultra_mux_enum_put(struct snd_kcontrol *kcontrol,
  10661. struct snd_ctl_elem_value *ucontrol)
  10662. {
  10663. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  10664. struct alc_spec *spec = codec->spec;
  10665. int ret;
  10666. ret = alc_mux_enum_put(kcontrol, ucontrol);
  10667. if (!ret)
  10668. return 0;
  10669. /* reprogram the HP pin as mic or HP according to the input source */
  10670. snd_hda_codec_write_cache(codec, 0x15, 0,
  10671. AC_VERB_SET_PIN_WIDGET_CONTROL,
  10672. spec->cur_mux[0] ? PIN_VREF80 : PIN_HP);
  10673. alc262_ultra_automute(codec); /* mute/unmute HP */
  10674. return ret;
  10675. }
  10676. static struct snd_kcontrol_new alc262_ultra_capture_mixer[] = {
  10677. HDA_CODEC_VOLUME("Capture Volume", 0x07, 0x0, HDA_INPUT),
  10678. HDA_CODEC_MUTE("Capture Switch", 0x07, 0x0, HDA_INPUT),
  10679. {
  10680. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  10681. .name = "Capture Source",
  10682. .info = alc_mux_enum_info,
  10683. .get = alc_mux_enum_get,
  10684. .put = alc262_ultra_mux_enum_put,
  10685. },
  10686. {
  10687. .iface = NID_MAPPING,
  10688. .name = "Capture Source",
  10689. .private_value = 0x15,
  10690. },
  10691. { } /* end */
  10692. };
  10693. /* We use two mixers depending on the output pin; 0x16 is a mono output
  10694. * and thus it's bound with a different mixer.
  10695. * This function returns which mixer amp should be used.
  10696. */
  10697. static int alc262_check_volbit(hda_nid_t nid)
  10698. {
  10699. if (!nid)
  10700. return 0;
  10701. else if (nid == 0x16)
  10702. return 2;
  10703. else
  10704. return 1;
  10705. }
  10706. static int alc262_add_out_vol_ctl(struct alc_spec *spec, hda_nid_t nid,
  10707. const char *pfx, int *vbits)
  10708. {
  10709. unsigned long val;
  10710. int vbit;
  10711. vbit = alc262_check_volbit(nid);
  10712. if (!vbit)
  10713. return 0;
  10714. if (*vbits & vbit) /* a volume control for this mixer already there */
  10715. return 0;
  10716. *vbits |= vbit;
  10717. if (vbit == 2)
  10718. val = HDA_COMPOSE_AMP_VAL(0x0e, 2, 0, HDA_OUTPUT);
  10719. else
  10720. val = HDA_COMPOSE_AMP_VAL(0x0c, 3, 0, HDA_OUTPUT);
  10721. return add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, pfx, val);
  10722. }
  10723. static int alc262_add_out_sw_ctl(struct alc_spec *spec, hda_nid_t nid,
  10724. const char *pfx)
  10725. {
  10726. unsigned long val;
  10727. if (!nid)
  10728. return 0;
  10729. if (nid == 0x16)
  10730. val = HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT);
  10731. else
  10732. val = HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT);
  10733. return add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, pfx, val);
  10734. }
  10735. /* add playback controls from the parsed DAC table */
  10736. static int alc262_auto_create_multi_out_ctls(struct alc_spec *spec,
  10737. const struct auto_pin_cfg *cfg)
  10738. {
  10739. const char *pfx;
  10740. int vbits;
  10741. int err;
  10742. spec->multiout.num_dacs = 1; /* only use one dac */
  10743. spec->multiout.dac_nids = spec->private_dac_nids;
  10744. spec->multiout.dac_nids[0] = 2;
  10745. if (!cfg->speaker_pins[0] && !cfg->hp_pins[0])
  10746. pfx = "Master";
  10747. else if (cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  10748. pfx = "Speaker";
  10749. else
  10750. pfx = "Front";
  10751. err = alc262_add_out_sw_ctl(spec, cfg->line_out_pins[0], pfx);
  10752. if (err < 0)
  10753. return err;
  10754. err = alc262_add_out_sw_ctl(spec, cfg->speaker_pins[0], "Speaker");
  10755. if (err < 0)
  10756. return err;
  10757. err = alc262_add_out_sw_ctl(spec, cfg->hp_pins[0], "Headphone");
  10758. if (err < 0)
  10759. return err;
  10760. vbits = alc262_check_volbit(cfg->line_out_pins[0]) |
  10761. alc262_check_volbit(cfg->speaker_pins[0]) |
  10762. alc262_check_volbit(cfg->hp_pins[0]);
  10763. if (vbits == 1 || vbits == 2)
  10764. pfx = "Master"; /* only one mixer is used */
  10765. else if (cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  10766. pfx = "Speaker";
  10767. else
  10768. pfx = "Front";
  10769. vbits = 0;
  10770. err = alc262_add_out_vol_ctl(spec, cfg->line_out_pins[0], pfx, &vbits);
  10771. if (err < 0)
  10772. return err;
  10773. err = alc262_add_out_vol_ctl(spec, cfg->speaker_pins[0], "Speaker",
  10774. &vbits);
  10775. if (err < 0)
  10776. return err;
  10777. err = alc262_add_out_vol_ctl(spec, cfg->hp_pins[0], "Headphone",
  10778. &vbits);
  10779. if (err < 0)
  10780. return err;
  10781. return 0;
  10782. }
  10783. #define alc262_auto_create_input_ctls \
  10784. alc882_auto_create_input_ctls
  10785. /*
  10786. * generic initialization of ADC, input mixers and output mixers
  10787. */
  10788. static struct hda_verb alc262_volume_init_verbs[] = {
  10789. /*
  10790. * Unmute ADC0-2 and set the default input to mic-in
  10791. */
  10792. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  10793. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10794. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  10795. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10796. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  10797. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10798. /* Mute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
  10799. * mixer widget
  10800. * Note: PASD motherboards uses the Line In 2 as the input for
  10801. * front panel mic (mic 2)
  10802. */
  10803. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  10804. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  10805. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  10806. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  10807. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  10808. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  10809. /*
  10810. * Set up output mixers (0x0c - 0x0f)
  10811. */
  10812. /* set vol=0 to output mixers */
  10813. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10814. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10815. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10816. /* set up input amps for analog loopback */
  10817. /* Amp Indices: DAC = 0, mixer = 1 */
  10818. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10819. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10820. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10821. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10822. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10823. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10824. /* FIXME: use matrix-type input source selection */
  10825. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  10826. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  10827. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10828. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10829. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10830. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10831. /* Input mixer2 */
  10832. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10833. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10834. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10835. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10836. /* Input mixer3 */
  10837. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10838. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10839. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10840. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10841. { }
  10842. };
  10843. static struct hda_verb alc262_HP_BPC_init_verbs[] = {
  10844. /*
  10845. * Unmute ADC0-2 and set the default input to mic-in
  10846. */
  10847. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  10848. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10849. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  10850. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10851. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  10852. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10853. /* Mute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
  10854. * mixer widget
  10855. * Note: PASD motherboards uses the Line In 2 as the input for
  10856. * front panel mic (mic 2)
  10857. */
  10858. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  10859. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  10860. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  10861. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  10862. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  10863. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  10864. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)},
  10865. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)},
  10866. /*
  10867. * Set up output mixers (0x0c - 0x0e)
  10868. */
  10869. /* set vol=0 to output mixers */
  10870. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10871. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10872. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10873. /* set up input amps for analog loopback */
  10874. /* Amp Indices: DAC = 0, mixer = 1 */
  10875. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10876. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10877. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10878. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10879. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10880. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10881. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  10882. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  10883. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  10884. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  10885. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  10886. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  10887. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  10888. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  10889. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  10890. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  10891. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  10892. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  10893. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10894. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10895. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10896. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10897. {0x1c, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10898. {0x1d, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10899. /* FIXME: use matrix-type input source selection */
  10900. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 0b, 12 */
  10901. /* Input mixer1: only unmute Mic */
  10902. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10903. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x01 << 8))},
  10904. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10905. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10906. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10907. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x05 << 8))},
  10908. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x06 << 8))},
  10909. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x07 << 8))},
  10910. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x08 << 8))},
  10911. /* Input mixer2 */
  10912. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10913. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x01 << 8))},
  10914. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10915. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10916. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10917. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x05 << 8))},
  10918. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x06 << 8))},
  10919. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x07 << 8))},
  10920. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x08 << 8))},
  10921. /* Input mixer3 */
  10922. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  10923. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x01 << 8))},
  10924. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  10925. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  10926. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  10927. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x05 << 8))},
  10928. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x06 << 8))},
  10929. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x07 << 8))},
  10930. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x08 << 8))},
  10931. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  10932. { }
  10933. };
  10934. static struct hda_verb alc262_HP_BPC_WildWest_init_verbs[] = {
  10935. /*
  10936. * Unmute ADC0-2 and set the default input to mic-in
  10937. */
  10938. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  10939. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10940. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  10941. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10942. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  10943. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10944. /* Mute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
  10945. * mixer widget
  10946. * Note: PASD motherboards uses the Line In 2 as the input for front
  10947. * panel mic (mic 2)
  10948. */
  10949. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  10950. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  10951. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  10952. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  10953. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  10954. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  10955. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)},
  10956. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)},
  10957. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)},
  10958. /*
  10959. * Set up output mixers (0x0c - 0x0e)
  10960. */
  10961. /* set vol=0 to output mixers */
  10962. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10963. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10964. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  10965. /* set up input amps for analog loopback */
  10966. /* Amp Indices: DAC = 0, mixer = 1 */
  10967. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10968. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10969. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10970. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10971. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  10972. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  10973. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP }, /* HP */
  10974. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT }, /* Mono */
  10975. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* rear MIC */
  10976. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN }, /* Line in */
  10977. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* Front MIC */
  10978. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT }, /* Line out */
  10979. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN }, /* CD in */
  10980. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  10981. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  10982. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  10983. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  10984. /* {0x14, AC_VERB_SET_AMP_GAIN_MUTE, 0x7023 }, */
  10985. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10986. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10987. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, 0x7023 },
  10988. {0x1c, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10989. {0x1d, AC_VERB_SET_AMP_GAIN_MUTE, 0x7000 },
  10990. /* FIXME: use matrix-type input source selection */
  10991. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  10992. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  10993. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))}, /*rear MIC*/
  10994. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))}, /*Line in*/
  10995. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x02 << 8))}, /*F MIC*/
  10996. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x03 << 8))}, /*Front*/
  10997. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x04 << 8))}, /*CD*/
  10998. /* {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x06 << 8))}, */
  10999. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x07 << 8))}, /*HP*/
  11000. /* Input mixer2 */
  11001. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  11002. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  11003. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x02 << 8))},
  11004. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x03 << 8))},
  11005. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x04 << 8))},
  11006. /* {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x06 << 8))}, */
  11007. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x07 << 8))},
  11008. /* Input mixer3 */
  11009. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  11010. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8))},
  11011. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x02 << 8))},
  11012. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x03 << 8))},
  11013. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x04 << 8))},
  11014. /* {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x06 << 8))}, */
  11015. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x07 << 8))},
  11016. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  11017. { }
  11018. };
  11019. static struct hda_verb alc262_toshiba_rx1_unsol_verbs[] = {
  11020. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT }, /* Front Speaker */
  11021. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  11022. {0x14, AC_VERB_SET_CONNECT_SEL, 0x01},
  11023. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* MIC jack */
  11024. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* Front MIC */
  11025. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0) },
  11026. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0) },
  11027. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP }, /* HP jack */
  11028. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  11029. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  11030. {}
  11031. };
  11032. #ifdef CONFIG_SND_HDA_POWER_SAVE
  11033. #define alc262_loopbacks alc880_loopbacks
  11034. #endif
  11035. /* pcm configuration: identical with ALC880 */
  11036. #define alc262_pcm_analog_playback alc880_pcm_analog_playback
  11037. #define alc262_pcm_analog_capture alc880_pcm_analog_capture
  11038. #define alc262_pcm_digital_playback alc880_pcm_digital_playback
  11039. #define alc262_pcm_digital_capture alc880_pcm_digital_capture
  11040. /*
  11041. * BIOS auto configuration
  11042. */
  11043. static int alc262_parse_auto_config(struct hda_codec *codec)
  11044. {
  11045. struct alc_spec *spec = codec->spec;
  11046. int err;
  11047. static hda_nid_t alc262_ignore[] = { 0x1d, 0 };
  11048. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  11049. alc262_ignore);
  11050. if (err < 0)
  11051. return err;
  11052. if (!spec->autocfg.line_outs) {
  11053. if (spec->autocfg.dig_outs || spec->autocfg.dig_in_pin) {
  11054. spec->multiout.max_channels = 2;
  11055. spec->no_analog = 1;
  11056. goto dig_only;
  11057. }
  11058. return 0; /* can't find valid BIOS pin config */
  11059. }
  11060. err = alc262_auto_create_multi_out_ctls(spec, &spec->autocfg);
  11061. if (err < 0)
  11062. return err;
  11063. err = alc262_auto_create_input_ctls(codec, &spec->autocfg);
  11064. if (err < 0)
  11065. return err;
  11066. spec->multiout.max_channels = spec->multiout.num_dacs * 2;
  11067. dig_only:
  11068. alc_auto_parse_digital(codec);
  11069. if (spec->kctls.list)
  11070. add_mixer(spec, spec->kctls.list);
  11071. add_verb(spec, alc262_volume_init_verbs);
  11072. spec->num_mux_defs = 1;
  11073. spec->input_mux = &spec->private_imux[0];
  11074. err = alc_auto_add_mic_boost(codec);
  11075. if (err < 0)
  11076. return err;
  11077. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
  11078. return 1;
  11079. }
  11080. #define alc262_auto_init_multi_out alc882_auto_init_multi_out
  11081. #define alc262_auto_init_hp_out alc882_auto_init_hp_out
  11082. #define alc262_auto_init_analog_input alc882_auto_init_analog_input
  11083. #define alc262_auto_init_input_src alc882_auto_init_input_src
  11084. /* init callback for auto-configuration model -- overriding the default init */
  11085. static void alc262_auto_init(struct hda_codec *codec)
  11086. {
  11087. struct alc_spec *spec = codec->spec;
  11088. alc262_auto_init_multi_out(codec);
  11089. alc262_auto_init_hp_out(codec);
  11090. alc262_auto_init_analog_input(codec);
  11091. alc262_auto_init_input_src(codec);
  11092. alc_auto_init_digital(codec);
  11093. if (spec->unsol_event)
  11094. alc_inithook(codec);
  11095. }
  11096. /*
  11097. * configuration and preset
  11098. */
  11099. static const char *alc262_models[ALC262_MODEL_LAST] = {
  11100. [ALC262_BASIC] = "basic",
  11101. [ALC262_HIPPO] = "hippo",
  11102. [ALC262_HIPPO_1] = "hippo_1",
  11103. [ALC262_FUJITSU] = "fujitsu",
  11104. [ALC262_HP_BPC] = "hp-bpc",
  11105. [ALC262_HP_BPC_D7000_WL]= "hp-bpc-d7000",
  11106. [ALC262_HP_TC_T5735] = "hp-tc-t5735",
  11107. [ALC262_HP_RP5700] = "hp-rp5700",
  11108. [ALC262_BENQ_ED8] = "benq",
  11109. [ALC262_BENQ_T31] = "benq-t31",
  11110. [ALC262_SONY_ASSAMD] = "sony-assamd",
  11111. [ALC262_TOSHIBA_S06] = "toshiba-s06",
  11112. [ALC262_TOSHIBA_RX1] = "toshiba-rx1",
  11113. [ALC262_ULTRA] = "ultra",
  11114. [ALC262_LENOVO_3000] = "lenovo-3000",
  11115. [ALC262_NEC] = "nec",
  11116. [ALC262_TYAN] = "tyan",
  11117. [ALC262_AUTO] = "auto",
  11118. };
  11119. static struct snd_pci_quirk alc262_cfg_tbl[] = {
  11120. SND_PCI_QUIRK(0x1002, 0x437b, "Hippo", ALC262_HIPPO),
  11121. SND_PCI_QUIRK(0x1033, 0x8895, "NEC Versa S9100", ALC262_NEC),
  11122. SND_PCI_QUIRK_MASK(0x103c, 0xff00, 0x1200, "HP xw series",
  11123. ALC262_HP_BPC),
  11124. SND_PCI_QUIRK_MASK(0x103c, 0xff00, 0x1300, "HP xw series",
  11125. ALC262_HP_BPC),
  11126. SND_PCI_QUIRK_MASK(0x103c, 0xff00, 0x1700, "HP xw series",
  11127. ALC262_HP_BPC),
  11128. SND_PCI_QUIRK(0x103c, 0x2800, "HP D7000", ALC262_HP_BPC_D7000_WL),
  11129. SND_PCI_QUIRK(0x103c, 0x2801, "HP D7000", ALC262_HP_BPC_D7000_WF),
  11130. SND_PCI_QUIRK(0x103c, 0x2802, "HP D7000", ALC262_HP_BPC_D7000_WL),
  11131. SND_PCI_QUIRK(0x103c, 0x2803, "HP D7000", ALC262_HP_BPC_D7000_WF),
  11132. SND_PCI_QUIRK(0x103c, 0x2804, "HP D7000", ALC262_HP_BPC_D7000_WL),
  11133. SND_PCI_QUIRK(0x103c, 0x2805, "HP D7000", ALC262_HP_BPC_D7000_WF),
  11134. SND_PCI_QUIRK(0x103c, 0x2806, "HP D7000", ALC262_HP_BPC_D7000_WL),
  11135. SND_PCI_QUIRK(0x103c, 0x2807, "HP D7000", ALC262_HP_BPC_D7000_WF),
  11136. SND_PCI_QUIRK(0x103c, 0x280c, "HP xw4400", ALC262_HP_BPC),
  11137. SND_PCI_QUIRK(0x103c, 0x3014, "HP xw6400", ALC262_HP_BPC),
  11138. SND_PCI_QUIRK(0x103c, 0x3015, "HP xw8400", ALC262_HP_BPC),
  11139. SND_PCI_QUIRK(0x103c, 0x302f, "HP Thin Client T5735",
  11140. ALC262_HP_TC_T5735),
  11141. SND_PCI_QUIRK(0x103c, 0x2817, "HP RP5700", ALC262_HP_RP5700),
  11142. SND_PCI_QUIRK(0x104d, 0x1f00, "Sony ASSAMD", ALC262_SONY_ASSAMD),
  11143. SND_PCI_QUIRK(0x104d, 0x8203, "Sony UX-90", ALC262_HIPPO),
  11144. SND_PCI_QUIRK(0x104d, 0x820f, "Sony ASSAMD", ALC262_SONY_ASSAMD),
  11145. SND_PCI_QUIRK(0x104d, 0x9016, "Sony VAIO", ALC262_AUTO), /* dig-only */
  11146. SND_PCI_QUIRK(0x104d, 0x9025, "Sony VAIO Z21MN", ALC262_TOSHIBA_S06),
  11147. SND_PCI_QUIRK(0x104d, 0x9035, "Sony VAIO VGN-FW170J", ALC262_AUTO),
  11148. SND_PCI_QUIRK(0x104d, 0x9047, "Sony VAIO Type G", ALC262_AUTO),
  11149. #if 0 /* disable the quirk since model=auto works better in recent versions */
  11150. SND_PCI_QUIRK_MASK(0x104d, 0xff00, 0x9000, "Sony VAIO",
  11151. ALC262_SONY_ASSAMD),
  11152. #endif
  11153. SND_PCI_QUIRK(0x1179, 0x0001, "Toshiba dynabook SS RX1",
  11154. ALC262_TOSHIBA_RX1),
  11155. SND_PCI_QUIRK(0x1179, 0xff7b, "Toshiba S06", ALC262_TOSHIBA_S06),
  11156. SND_PCI_QUIRK(0x10cf, 0x1397, "Fujitsu", ALC262_FUJITSU),
  11157. SND_PCI_QUIRK(0x10cf, 0x142d, "Fujitsu Lifebook E8410", ALC262_FUJITSU),
  11158. SND_PCI_QUIRK(0x10f1, 0x2915, "Tyan Thunder n6650W", ALC262_TYAN),
  11159. SND_PCI_QUIRK_MASK(0x144d, 0xff00, 0xc032, "Samsung Q1",
  11160. ALC262_ULTRA),
  11161. SND_PCI_QUIRK(0x144d, 0xc510, "Samsung Q45", ALC262_HIPPO),
  11162. SND_PCI_QUIRK(0x17aa, 0x384e, "Lenovo 3000 y410", ALC262_LENOVO_3000),
  11163. SND_PCI_QUIRK(0x17ff, 0x0560, "Benq ED8", ALC262_BENQ_ED8),
  11164. SND_PCI_QUIRK(0x17ff, 0x058d, "Benq T31-16", ALC262_BENQ_T31),
  11165. SND_PCI_QUIRK(0x17ff, 0x058f, "Benq Hippo", ALC262_HIPPO_1),
  11166. {}
  11167. };
  11168. static struct alc_config_preset alc262_presets[] = {
  11169. [ALC262_BASIC] = {
  11170. .mixers = { alc262_base_mixer },
  11171. .init_verbs = { alc262_init_verbs },
  11172. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11173. .dac_nids = alc262_dac_nids,
  11174. .hp_nid = 0x03,
  11175. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11176. .channel_mode = alc262_modes,
  11177. .input_mux = &alc262_capture_source,
  11178. },
  11179. [ALC262_HIPPO] = {
  11180. .mixers = { alc262_hippo_mixer },
  11181. .init_verbs = { alc262_init_verbs, alc_hp15_unsol_verbs},
  11182. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11183. .dac_nids = alc262_dac_nids,
  11184. .hp_nid = 0x03,
  11185. .dig_out_nid = ALC262_DIGOUT_NID,
  11186. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11187. .channel_mode = alc262_modes,
  11188. .input_mux = &alc262_capture_source,
  11189. .unsol_event = alc262_hippo_unsol_event,
  11190. .setup = alc262_hippo_setup,
  11191. .init_hook = alc262_hippo_automute,
  11192. },
  11193. [ALC262_HIPPO_1] = {
  11194. .mixers = { alc262_hippo1_mixer },
  11195. .init_verbs = { alc262_init_verbs, alc262_hippo1_unsol_verbs},
  11196. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11197. .dac_nids = alc262_dac_nids,
  11198. .hp_nid = 0x02,
  11199. .dig_out_nid = ALC262_DIGOUT_NID,
  11200. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11201. .channel_mode = alc262_modes,
  11202. .input_mux = &alc262_capture_source,
  11203. .unsol_event = alc262_hippo_unsol_event,
  11204. .setup = alc262_hippo1_setup,
  11205. .init_hook = alc262_hippo_automute,
  11206. },
  11207. [ALC262_FUJITSU] = {
  11208. .mixers = { alc262_fujitsu_mixer },
  11209. .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs,
  11210. alc262_fujitsu_unsol_verbs },
  11211. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11212. .dac_nids = alc262_dac_nids,
  11213. .hp_nid = 0x03,
  11214. .dig_out_nid = ALC262_DIGOUT_NID,
  11215. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11216. .channel_mode = alc262_modes,
  11217. .input_mux = &alc262_fujitsu_capture_source,
  11218. .unsol_event = alc262_fujitsu_unsol_event,
  11219. .init_hook = alc262_fujitsu_init_hook,
  11220. },
  11221. [ALC262_HP_BPC] = {
  11222. .mixers = { alc262_HP_BPC_mixer },
  11223. .init_verbs = { alc262_HP_BPC_init_verbs },
  11224. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11225. .dac_nids = alc262_dac_nids,
  11226. .hp_nid = 0x03,
  11227. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11228. .channel_mode = alc262_modes,
  11229. .input_mux = &alc262_HP_capture_source,
  11230. .unsol_event = alc262_hp_bpc_unsol_event,
  11231. .init_hook = alc262_hp_bpc_automute,
  11232. },
  11233. [ALC262_HP_BPC_D7000_WF] = {
  11234. .mixers = { alc262_HP_BPC_WildWest_mixer },
  11235. .init_verbs = { alc262_HP_BPC_WildWest_init_verbs },
  11236. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11237. .dac_nids = alc262_dac_nids,
  11238. .hp_nid = 0x03,
  11239. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11240. .channel_mode = alc262_modes,
  11241. .input_mux = &alc262_HP_D7000_capture_source,
  11242. .unsol_event = alc262_hp_wildwest_unsol_event,
  11243. .init_hook = alc262_hp_wildwest_automute,
  11244. },
  11245. [ALC262_HP_BPC_D7000_WL] = {
  11246. .mixers = { alc262_HP_BPC_WildWest_mixer,
  11247. alc262_HP_BPC_WildWest_option_mixer },
  11248. .init_verbs = { alc262_HP_BPC_WildWest_init_verbs },
  11249. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11250. .dac_nids = alc262_dac_nids,
  11251. .hp_nid = 0x03,
  11252. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11253. .channel_mode = alc262_modes,
  11254. .input_mux = &alc262_HP_D7000_capture_source,
  11255. .unsol_event = alc262_hp_wildwest_unsol_event,
  11256. .init_hook = alc262_hp_wildwest_automute,
  11257. },
  11258. [ALC262_HP_TC_T5735] = {
  11259. .mixers = { alc262_hp_t5735_mixer },
  11260. .init_verbs = { alc262_init_verbs, alc262_hp_t5735_verbs },
  11261. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11262. .dac_nids = alc262_dac_nids,
  11263. .hp_nid = 0x03,
  11264. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11265. .channel_mode = alc262_modes,
  11266. .input_mux = &alc262_capture_source,
  11267. .unsol_event = alc_sku_unsol_event,
  11268. .setup = alc262_hp_t5735_setup,
  11269. .init_hook = alc_inithook,
  11270. },
  11271. [ALC262_HP_RP5700] = {
  11272. .mixers = { alc262_hp_rp5700_mixer },
  11273. .init_verbs = { alc262_init_verbs, alc262_hp_rp5700_verbs },
  11274. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11275. .dac_nids = alc262_dac_nids,
  11276. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11277. .channel_mode = alc262_modes,
  11278. .input_mux = &alc262_hp_rp5700_capture_source,
  11279. },
  11280. [ALC262_BENQ_ED8] = {
  11281. .mixers = { alc262_base_mixer },
  11282. .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs },
  11283. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11284. .dac_nids = alc262_dac_nids,
  11285. .hp_nid = 0x03,
  11286. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11287. .channel_mode = alc262_modes,
  11288. .input_mux = &alc262_capture_source,
  11289. },
  11290. [ALC262_SONY_ASSAMD] = {
  11291. .mixers = { alc262_sony_mixer },
  11292. .init_verbs = { alc262_init_verbs, alc262_sony_unsol_verbs},
  11293. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11294. .dac_nids = alc262_dac_nids,
  11295. .hp_nid = 0x02,
  11296. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11297. .channel_mode = alc262_modes,
  11298. .input_mux = &alc262_capture_source,
  11299. .unsol_event = alc262_hippo_unsol_event,
  11300. .setup = alc262_hippo_setup,
  11301. .init_hook = alc262_hippo_automute,
  11302. },
  11303. [ALC262_BENQ_T31] = {
  11304. .mixers = { alc262_benq_t31_mixer },
  11305. .init_verbs = { alc262_init_verbs, alc262_benq_t31_EAPD_verbs,
  11306. alc_hp15_unsol_verbs },
  11307. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11308. .dac_nids = alc262_dac_nids,
  11309. .hp_nid = 0x03,
  11310. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11311. .channel_mode = alc262_modes,
  11312. .input_mux = &alc262_capture_source,
  11313. .unsol_event = alc262_hippo_unsol_event,
  11314. .setup = alc262_hippo_setup,
  11315. .init_hook = alc262_hippo_automute,
  11316. },
  11317. [ALC262_ULTRA] = {
  11318. .mixers = { alc262_ultra_mixer },
  11319. .cap_mixer = alc262_ultra_capture_mixer,
  11320. .init_verbs = { alc262_ultra_verbs },
  11321. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11322. .dac_nids = alc262_dac_nids,
  11323. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11324. .channel_mode = alc262_modes,
  11325. .input_mux = &alc262_ultra_capture_source,
  11326. .adc_nids = alc262_adc_nids, /* ADC0 */
  11327. .capsrc_nids = alc262_capsrc_nids,
  11328. .num_adc_nids = 1, /* single ADC */
  11329. .unsol_event = alc262_ultra_unsol_event,
  11330. .init_hook = alc262_ultra_automute,
  11331. },
  11332. [ALC262_LENOVO_3000] = {
  11333. .mixers = { alc262_lenovo_3000_mixer },
  11334. .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs,
  11335. alc262_lenovo_3000_unsol_verbs,
  11336. alc262_lenovo_3000_init_verbs },
  11337. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11338. .dac_nids = alc262_dac_nids,
  11339. .hp_nid = 0x03,
  11340. .dig_out_nid = ALC262_DIGOUT_NID,
  11341. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11342. .channel_mode = alc262_modes,
  11343. .input_mux = &alc262_fujitsu_capture_source,
  11344. .unsol_event = alc262_lenovo_3000_unsol_event,
  11345. },
  11346. [ALC262_NEC] = {
  11347. .mixers = { alc262_nec_mixer },
  11348. .init_verbs = { alc262_nec_verbs },
  11349. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11350. .dac_nids = alc262_dac_nids,
  11351. .hp_nid = 0x03,
  11352. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11353. .channel_mode = alc262_modes,
  11354. .input_mux = &alc262_capture_source,
  11355. },
  11356. [ALC262_TOSHIBA_S06] = {
  11357. .mixers = { alc262_toshiba_s06_mixer },
  11358. .init_verbs = { alc262_init_verbs, alc262_toshiba_s06_verbs,
  11359. alc262_eapd_verbs },
  11360. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11361. .capsrc_nids = alc262_dmic_capsrc_nids,
  11362. .dac_nids = alc262_dac_nids,
  11363. .adc_nids = alc262_dmic_adc_nids, /* ADC0 */
  11364. .num_adc_nids = 1, /* single ADC */
  11365. .dig_out_nid = ALC262_DIGOUT_NID,
  11366. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11367. .channel_mode = alc262_modes,
  11368. .unsol_event = alc_sku_unsol_event,
  11369. .setup = alc262_toshiba_s06_setup,
  11370. .init_hook = alc_inithook,
  11371. },
  11372. [ALC262_TOSHIBA_RX1] = {
  11373. .mixers = { alc262_toshiba_rx1_mixer },
  11374. .init_verbs = { alc262_init_verbs, alc262_toshiba_rx1_unsol_verbs },
  11375. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11376. .dac_nids = alc262_dac_nids,
  11377. .hp_nid = 0x03,
  11378. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11379. .channel_mode = alc262_modes,
  11380. .input_mux = &alc262_capture_source,
  11381. .unsol_event = alc262_hippo_unsol_event,
  11382. .setup = alc262_hippo_setup,
  11383. .init_hook = alc262_hippo_automute,
  11384. },
  11385. [ALC262_TYAN] = {
  11386. .mixers = { alc262_tyan_mixer },
  11387. .init_verbs = { alc262_init_verbs, alc262_tyan_verbs},
  11388. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  11389. .dac_nids = alc262_dac_nids,
  11390. .hp_nid = 0x02,
  11391. .dig_out_nid = ALC262_DIGOUT_NID,
  11392. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  11393. .channel_mode = alc262_modes,
  11394. .input_mux = &alc262_capture_source,
  11395. .unsol_event = alc_automute_amp_unsol_event,
  11396. .setup = alc262_tyan_setup,
  11397. .init_hook = alc_automute_amp,
  11398. },
  11399. };
  11400. static int patch_alc262(struct hda_codec *codec)
  11401. {
  11402. struct alc_spec *spec;
  11403. int board_config;
  11404. int err;
  11405. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  11406. if (spec == NULL)
  11407. return -ENOMEM;
  11408. codec->spec = spec;
  11409. #if 0
  11410. /* pshou 07/11/05 set a zero PCM sample to DAC when FIFO is
  11411. * under-run
  11412. */
  11413. {
  11414. int tmp;
  11415. snd_hda_codec_write(codec, 0x1a, 0, AC_VERB_SET_COEF_INDEX, 7);
  11416. tmp = snd_hda_codec_read(codec, 0x20, 0, AC_VERB_GET_PROC_COEF, 0);
  11417. snd_hda_codec_write(codec, 0x1a, 0, AC_VERB_SET_COEF_INDEX, 7);
  11418. snd_hda_codec_write(codec, 0x1a, 0, AC_VERB_SET_PROC_COEF, tmp | 0x80);
  11419. }
  11420. #endif
  11421. alc_auto_parse_customize_define(codec);
  11422. alc_fix_pll_init(codec, 0x20, 0x0a, 10);
  11423. board_config = snd_hda_check_board_config(codec, ALC262_MODEL_LAST,
  11424. alc262_models,
  11425. alc262_cfg_tbl);
  11426. if (board_config < 0) {
  11427. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  11428. codec->chip_name);
  11429. board_config = ALC262_AUTO;
  11430. }
  11431. if (board_config == ALC262_AUTO) {
  11432. /* automatic parse from the BIOS config */
  11433. err = alc262_parse_auto_config(codec);
  11434. if (err < 0) {
  11435. alc_free(codec);
  11436. return err;
  11437. } else if (!err) {
  11438. printk(KERN_INFO
  11439. "hda_codec: Cannot set up configuration "
  11440. "from BIOS. Using base mode...\n");
  11441. board_config = ALC262_BASIC;
  11442. }
  11443. }
  11444. if (!spec->no_analog && has_cdefine_beep(codec)) {
  11445. err = snd_hda_attach_beep_device(codec, 0x1);
  11446. if (err < 0) {
  11447. alc_free(codec);
  11448. return err;
  11449. }
  11450. }
  11451. if (board_config != ALC262_AUTO)
  11452. setup_preset(codec, &alc262_presets[board_config]);
  11453. spec->stream_analog_playback = &alc262_pcm_analog_playback;
  11454. spec->stream_analog_capture = &alc262_pcm_analog_capture;
  11455. spec->stream_digital_playback = &alc262_pcm_digital_playback;
  11456. spec->stream_digital_capture = &alc262_pcm_digital_capture;
  11457. if (!spec->adc_nids && spec->input_mux) {
  11458. int i;
  11459. /* check whether the digital-mic has to be supported */
  11460. for (i = 0; i < spec->input_mux->num_items; i++) {
  11461. if (spec->input_mux->items[i].index >= 9)
  11462. break;
  11463. }
  11464. if (i < spec->input_mux->num_items) {
  11465. /* use only ADC0 */
  11466. spec->adc_nids = alc262_dmic_adc_nids;
  11467. spec->num_adc_nids = 1;
  11468. spec->capsrc_nids = alc262_dmic_capsrc_nids;
  11469. } else {
  11470. /* all analog inputs */
  11471. /* check whether NID 0x07 is valid */
  11472. unsigned int wcap = get_wcaps(codec, 0x07);
  11473. /* get type */
  11474. wcap = get_wcaps_type(wcap);
  11475. if (wcap != AC_WID_AUD_IN) {
  11476. spec->adc_nids = alc262_adc_nids_alt;
  11477. spec->num_adc_nids =
  11478. ARRAY_SIZE(alc262_adc_nids_alt);
  11479. spec->capsrc_nids = alc262_capsrc_nids_alt;
  11480. } else {
  11481. spec->adc_nids = alc262_adc_nids;
  11482. spec->num_adc_nids =
  11483. ARRAY_SIZE(alc262_adc_nids);
  11484. spec->capsrc_nids = alc262_capsrc_nids;
  11485. }
  11486. }
  11487. }
  11488. if (!spec->cap_mixer && !spec->no_analog)
  11489. set_capture_mixer(codec);
  11490. if (!spec->no_analog && has_cdefine_beep(codec))
  11491. set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT);
  11492. spec->vmaster_nid = 0x0c;
  11493. codec->patch_ops = alc_patch_ops;
  11494. if (board_config == ALC262_AUTO)
  11495. spec->init_hook = alc262_auto_init;
  11496. #ifdef CONFIG_SND_HDA_POWER_SAVE
  11497. if (!spec->loopback.amplist)
  11498. spec->loopback.amplist = alc262_loopbacks;
  11499. #endif
  11500. return 0;
  11501. }
  11502. /*
  11503. * ALC268 channel source setting (2 channel)
  11504. */
  11505. #define ALC268_DIGOUT_NID ALC880_DIGOUT_NID
  11506. #define alc268_modes alc260_modes
  11507. static hda_nid_t alc268_dac_nids[2] = {
  11508. /* front, hp */
  11509. 0x02, 0x03
  11510. };
  11511. static hda_nid_t alc268_adc_nids[2] = {
  11512. /* ADC0-1 */
  11513. 0x08, 0x07
  11514. };
  11515. static hda_nid_t alc268_adc_nids_alt[1] = {
  11516. /* ADC0 */
  11517. 0x08
  11518. };
  11519. static hda_nid_t alc268_capsrc_nids[2] = { 0x23, 0x24 };
  11520. static struct snd_kcontrol_new alc268_base_mixer[] = {
  11521. /* output mixer control */
  11522. HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT),
  11523. HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  11524. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x3, 0x0, HDA_OUTPUT),
  11525. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  11526. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  11527. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  11528. HDA_CODEC_VOLUME("Line In Boost", 0x1a, 0, HDA_INPUT),
  11529. { }
  11530. };
  11531. static struct snd_kcontrol_new alc268_toshiba_mixer[] = {
  11532. /* output mixer control */
  11533. HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT),
  11534. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x3, 0x0, HDA_OUTPUT),
  11535. ALC262_HIPPO_MASTER_SWITCH,
  11536. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  11537. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  11538. HDA_CODEC_VOLUME("Line In Boost", 0x1a, 0, HDA_INPUT),
  11539. { }
  11540. };
  11541. /* bind Beep switches of both NID 0x0f and 0x10 */
  11542. static struct hda_bind_ctls alc268_bind_beep_sw = {
  11543. .ops = &snd_hda_bind_sw,
  11544. .values = {
  11545. HDA_COMPOSE_AMP_VAL(0x0f, 3, 1, HDA_INPUT),
  11546. HDA_COMPOSE_AMP_VAL(0x10, 3, 1, HDA_INPUT),
  11547. 0
  11548. },
  11549. };
  11550. static struct snd_kcontrol_new alc268_beep_mixer[] = {
  11551. HDA_CODEC_VOLUME("Beep Playback Volume", 0x1d, 0x0, HDA_INPUT),
  11552. HDA_BIND_SW("Beep Playback Switch", &alc268_bind_beep_sw),
  11553. { }
  11554. };
  11555. static struct hda_verb alc268_eapd_verbs[] = {
  11556. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  11557. {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
  11558. { }
  11559. };
  11560. /* Toshiba specific */
  11561. static struct hda_verb alc268_toshiba_verbs[] = {
  11562. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  11563. { } /* end */
  11564. };
  11565. /* Acer specific */
  11566. /* bind volumes of both NID 0x02 and 0x03 */
  11567. static struct hda_bind_ctls alc268_acer_bind_master_vol = {
  11568. .ops = &snd_hda_bind_vol,
  11569. .values = {
  11570. HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT),
  11571. HDA_COMPOSE_AMP_VAL(0x03, 3, 0, HDA_OUTPUT),
  11572. 0
  11573. },
  11574. };
  11575. /* mute/unmute internal speaker according to the hp jack and mute state */
  11576. static void alc268_acer_automute(struct hda_codec *codec, int force)
  11577. {
  11578. struct alc_spec *spec = codec->spec;
  11579. unsigned int mute;
  11580. if (force || !spec->sense_updated) {
  11581. spec->jack_present = snd_hda_jack_detect(codec, 0x14);
  11582. spec->sense_updated = 1;
  11583. }
  11584. if (spec->jack_present)
  11585. mute = HDA_AMP_MUTE; /* mute internal speaker */
  11586. else /* unmute internal speaker if necessary */
  11587. mute = snd_hda_codec_amp_read(codec, 0x14, 0, HDA_OUTPUT, 0);
  11588. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  11589. HDA_AMP_MUTE, mute);
  11590. }
  11591. /* bind hp and internal speaker mute (with plug check) */
  11592. static int alc268_acer_master_sw_put(struct snd_kcontrol *kcontrol,
  11593. struct snd_ctl_elem_value *ucontrol)
  11594. {
  11595. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  11596. long *valp = ucontrol->value.integer.value;
  11597. int change;
  11598. change = amp_stereo_mute_update(codec, 0x14, HDA_OUTPUT, 0, valp);
  11599. if (change)
  11600. alc268_acer_automute(codec, 0);
  11601. return change;
  11602. }
  11603. static struct snd_kcontrol_new alc268_acer_aspire_one_mixer[] = {
  11604. /* output mixer control */
  11605. HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol),
  11606. {
  11607. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  11608. .name = "Master Playback Switch",
  11609. .subdevice = HDA_SUBDEV_AMP_FLAG,
  11610. .info = snd_hda_mixer_amp_switch_info,
  11611. .get = snd_hda_mixer_amp_switch_get,
  11612. .put = alc268_acer_master_sw_put,
  11613. .private_value = HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  11614. },
  11615. HDA_CODEC_VOLUME("Mic Boost Capture Volume", 0x18, 0, HDA_INPUT),
  11616. { }
  11617. };
  11618. static struct snd_kcontrol_new alc268_acer_mixer[] = {
  11619. /* output mixer control */
  11620. HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol),
  11621. {
  11622. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  11623. .name = "Master Playback Switch",
  11624. .subdevice = HDA_SUBDEV_AMP_FLAG,
  11625. .info = snd_hda_mixer_amp_switch_info,
  11626. .get = snd_hda_mixer_amp_switch_get,
  11627. .put = alc268_acer_master_sw_put,
  11628. .private_value = HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  11629. },
  11630. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  11631. HDA_CODEC_VOLUME("Internal Mic Boost", 0x19, 0, HDA_INPUT),
  11632. HDA_CODEC_VOLUME("Line In Boost", 0x1a, 0, HDA_INPUT),
  11633. { }
  11634. };
  11635. static struct snd_kcontrol_new alc268_acer_dmic_mixer[] = {
  11636. /* output mixer control */
  11637. HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol),
  11638. {
  11639. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  11640. .name = "Master Playback Switch",
  11641. .subdevice = HDA_SUBDEV_AMP_FLAG,
  11642. .info = snd_hda_mixer_amp_switch_info,
  11643. .get = snd_hda_mixer_amp_switch_get,
  11644. .put = alc268_acer_master_sw_put,
  11645. .private_value = HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  11646. },
  11647. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  11648. HDA_CODEC_VOLUME("Line In Boost", 0x1a, 0, HDA_INPUT),
  11649. { }
  11650. };
  11651. static struct hda_verb alc268_acer_aspire_one_verbs[] = {
  11652. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  11653. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  11654. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  11655. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  11656. {0x23, AC_VERB_SET_CONNECT_SEL, 0x06},
  11657. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, 0xa017},
  11658. { }
  11659. };
  11660. static struct hda_verb alc268_acer_verbs[] = {
  11661. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, /* internal dmic? */
  11662. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  11663. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  11664. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  11665. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  11666. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  11667. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  11668. { }
  11669. };
  11670. /* unsolicited event for HP jack sensing */
  11671. #define alc268_toshiba_unsol_event alc262_hippo_unsol_event
  11672. #define alc268_toshiba_setup alc262_hippo_setup
  11673. #define alc268_toshiba_automute alc262_hippo_automute
  11674. static void alc268_acer_unsol_event(struct hda_codec *codec,
  11675. unsigned int res)
  11676. {
  11677. if ((res >> 26) != ALC880_HP_EVENT)
  11678. return;
  11679. alc268_acer_automute(codec, 1);
  11680. }
  11681. static void alc268_acer_init_hook(struct hda_codec *codec)
  11682. {
  11683. alc268_acer_automute(codec, 1);
  11684. }
  11685. /* toggle speaker-output according to the hp-jack state */
  11686. static void alc268_aspire_one_speaker_automute(struct hda_codec *codec)
  11687. {
  11688. unsigned int present;
  11689. unsigned char bits;
  11690. present = snd_hda_jack_detect(codec, 0x15);
  11691. bits = present ? HDA_AMP_MUTE : 0;
  11692. snd_hda_codec_amp_stereo(codec, 0x0f, HDA_INPUT, 0,
  11693. HDA_AMP_MUTE, bits);
  11694. snd_hda_codec_amp_stereo(codec, 0x0f, HDA_INPUT, 1,
  11695. HDA_AMP_MUTE, bits);
  11696. }
  11697. static void alc268_acer_lc_unsol_event(struct hda_codec *codec,
  11698. unsigned int res)
  11699. {
  11700. switch (res >> 26) {
  11701. case ALC880_HP_EVENT:
  11702. alc268_aspire_one_speaker_automute(codec);
  11703. break;
  11704. case ALC880_MIC_EVENT:
  11705. alc_mic_automute(codec);
  11706. break;
  11707. }
  11708. }
  11709. static void alc268_acer_lc_setup(struct hda_codec *codec)
  11710. {
  11711. struct alc_spec *spec = codec->spec;
  11712. spec->ext_mic.pin = 0x18;
  11713. spec->ext_mic.mux_idx = 0;
  11714. spec->int_mic.pin = 0x12;
  11715. spec->int_mic.mux_idx = 6;
  11716. spec->auto_mic = 1;
  11717. }
  11718. static void alc268_acer_lc_init_hook(struct hda_codec *codec)
  11719. {
  11720. alc268_aspire_one_speaker_automute(codec);
  11721. alc_mic_automute(codec);
  11722. }
  11723. static struct snd_kcontrol_new alc268_dell_mixer[] = {
  11724. /* output mixer control */
  11725. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  11726. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  11727. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  11728. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  11729. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  11730. HDA_CODEC_VOLUME("Internal Mic Boost", 0x19, 0, HDA_INPUT),
  11731. { }
  11732. };
  11733. static struct hda_verb alc268_dell_verbs[] = {
  11734. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  11735. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  11736. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  11737. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_MIC_EVENT | AC_USRSP_EN},
  11738. { }
  11739. };
  11740. /* mute/unmute internal speaker according to the hp jack and mute state */
  11741. static void alc268_dell_setup(struct hda_codec *codec)
  11742. {
  11743. struct alc_spec *spec = codec->spec;
  11744. spec->autocfg.hp_pins[0] = 0x15;
  11745. spec->autocfg.speaker_pins[0] = 0x14;
  11746. spec->ext_mic.pin = 0x18;
  11747. spec->ext_mic.mux_idx = 0;
  11748. spec->int_mic.pin = 0x19;
  11749. spec->int_mic.mux_idx = 1;
  11750. spec->auto_mic = 1;
  11751. }
  11752. static struct snd_kcontrol_new alc267_quanta_il1_mixer[] = {
  11753. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x2, 0x0, HDA_OUTPUT),
  11754. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  11755. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x3, 0x0, HDA_OUTPUT),
  11756. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  11757. HDA_CODEC_VOLUME("Mic Capture Volume", 0x23, 0x0, HDA_OUTPUT),
  11758. HDA_BIND_MUTE("Mic Capture Switch", 0x23, 2, HDA_OUTPUT),
  11759. HDA_CODEC_VOLUME("Ext Mic Boost", 0x18, 0, HDA_INPUT),
  11760. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  11761. { }
  11762. };
  11763. static struct hda_verb alc267_quanta_il1_verbs[] = {
  11764. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  11765. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_MIC_EVENT | AC_USRSP_EN},
  11766. { }
  11767. };
  11768. static void alc267_quanta_il1_setup(struct hda_codec *codec)
  11769. {
  11770. struct alc_spec *spec = codec->spec;
  11771. spec->autocfg.hp_pins[0] = 0x15;
  11772. spec->autocfg.speaker_pins[0] = 0x14;
  11773. spec->ext_mic.pin = 0x18;
  11774. spec->ext_mic.mux_idx = 0;
  11775. spec->int_mic.pin = 0x19;
  11776. spec->int_mic.mux_idx = 1;
  11777. spec->auto_mic = 1;
  11778. }
  11779. /*
  11780. * generic initialization of ADC, input mixers and output mixers
  11781. */
  11782. static struct hda_verb alc268_base_init_verbs[] = {
  11783. /* Unmute DAC0-1 and set vol = 0 */
  11784. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  11785. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  11786. /*
  11787. * Set up output mixers (0x0c - 0x0e)
  11788. */
  11789. /* set vol=0 to output mixers */
  11790. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11791. {0x0e, AC_VERB_SET_CONNECT_SEL, 0x00},
  11792. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11793. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11794. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  11795. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  11796. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  11797. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  11798. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  11799. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  11800. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  11801. {0x1d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  11802. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  11803. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  11804. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  11805. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  11806. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  11807. /* set PCBEEP vol = 0, mute connections */
  11808. {0x1d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11809. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  11810. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  11811. /* Unmute Selector 23h,24h and set the default input to mic-in */
  11812. {0x23, AC_VERB_SET_CONNECT_SEL, 0x00},
  11813. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  11814. {0x24, AC_VERB_SET_CONNECT_SEL, 0x00},
  11815. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  11816. { }
  11817. };
  11818. /*
  11819. * generic initialization of ADC, input mixers and output mixers
  11820. */
  11821. static struct hda_verb alc268_volume_init_verbs[] = {
  11822. /* set output DAC */
  11823. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  11824. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  11825. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  11826. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  11827. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  11828. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  11829. {0x1d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  11830. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11831. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11832. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11833. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  11834. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  11835. /* set PCBEEP vol = 0, mute connections */
  11836. {0x1d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  11837. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  11838. {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  11839. { }
  11840. };
  11841. static struct snd_kcontrol_new alc268_capture_nosrc_mixer[] = {
  11842. HDA_CODEC_VOLUME("Capture Volume", 0x23, 0x0, HDA_OUTPUT),
  11843. HDA_CODEC_MUTE("Capture Switch", 0x23, 0x0, HDA_OUTPUT),
  11844. { } /* end */
  11845. };
  11846. static struct snd_kcontrol_new alc268_capture_alt_mixer[] = {
  11847. HDA_CODEC_VOLUME("Capture Volume", 0x23, 0x0, HDA_OUTPUT),
  11848. HDA_CODEC_MUTE("Capture Switch", 0x23, 0x0, HDA_OUTPUT),
  11849. _DEFINE_CAPSRC(1),
  11850. { } /* end */
  11851. };
  11852. static struct snd_kcontrol_new alc268_capture_mixer[] = {
  11853. HDA_CODEC_VOLUME("Capture Volume", 0x23, 0x0, HDA_OUTPUT),
  11854. HDA_CODEC_MUTE("Capture Switch", 0x23, 0x0, HDA_OUTPUT),
  11855. HDA_CODEC_VOLUME_IDX("Capture Volume", 1, 0x24, 0x0, HDA_OUTPUT),
  11856. HDA_CODEC_MUTE_IDX("Capture Switch", 1, 0x24, 0x0, HDA_OUTPUT),
  11857. _DEFINE_CAPSRC(2),
  11858. { } /* end */
  11859. };
  11860. static struct hda_input_mux alc268_capture_source = {
  11861. .num_items = 4,
  11862. .items = {
  11863. { "Mic", 0x0 },
  11864. { "Front Mic", 0x1 },
  11865. { "Line", 0x2 },
  11866. { "CD", 0x3 },
  11867. },
  11868. };
  11869. static struct hda_input_mux alc268_acer_capture_source = {
  11870. .num_items = 3,
  11871. .items = {
  11872. { "Mic", 0x0 },
  11873. { "Internal Mic", 0x1 },
  11874. { "Line", 0x2 },
  11875. },
  11876. };
  11877. static struct hda_input_mux alc268_acer_dmic_capture_source = {
  11878. .num_items = 3,
  11879. .items = {
  11880. { "Mic", 0x0 },
  11881. { "Internal Mic", 0x6 },
  11882. { "Line", 0x2 },
  11883. },
  11884. };
  11885. #ifdef CONFIG_SND_DEBUG
  11886. static struct snd_kcontrol_new alc268_test_mixer[] = {
  11887. /* Volume widgets */
  11888. HDA_CODEC_VOLUME("LOUT1 Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  11889. HDA_CODEC_VOLUME("LOUT2 Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  11890. HDA_BIND_MUTE_MONO("Mono sum Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  11891. HDA_BIND_MUTE("LINE-OUT sum Playback Switch", 0x0f, 2, HDA_INPUT),
  11892. HDA_BIND_MUTE("HP-OUT sum Playback Switch", 0x10, 2, HDA_INPUT),
  11893. HDA_BIND_MUTE("LINE-OUT Playback Switch", 0x14, 2, HDA_OUTPUT),
  11894. HDA_BIND_MUTE("HP-OUT Playback Switch", 0x15, 2, HDA_OUTPUT),
  11895. HDA_BIND_MUTE("Mono Playback Switch", 0x16, 2, HDA_OUTPUT),
  11896. HDA_CODEC_VOLUME("MIC1 Capture Volume", 0x18, 0x0, HDA_INPUT),
  11897. HDA_BIND_MUTE("MIC1 Capture Switch", 0x18, 2, HDA_OUTPUT),
  11898. HDA_CODEC_VOLUME("MIC2 Capture Volume", 0x19, 0x0, HDA_INPUT),
  11899. HDA_CODEC_VOLUME("LINE1 Capture Volume", 0x1a, 0x0, HDA_INPUT),
  11900. HDA_BIND_MUTE("LINE1 Capture Switch", 0x1a, 2, HDA_OUTPUT),
  11901. /* The below appears problematic on some hardwares */
  11902. /*HDA_CODEC_VOLUME("PCBEEP Playback Volume", 0x1d, 0x0, HDA_INPUT),*/
  11903. HDA_CODEC_VOLUME("PCM-IN1 Capture Volume", 0x23, 0x0, HDA_OUTPUT),
  11904. HDA_BIND_MUTE("PCM-IN1 Capture Switch", 0x23, 2, HDA_OUTPUT),
  11905. HDA_CODEC_VOLUME("PCM-IN2 Capture Volume", 0x24, 0x0, HDA_OUTPUT),
  11906. HDA_BIND_MUTE("PCM-IN2 Capture Switch", 0x24, 2, HDA_OUTPUT),
  11907. /* Modes for retasking pin widgets */
  11908. ALC_PIN_MODE("LINE-OUT pin mode", 0x14, ALC_PIN_DIR_INOUT),
  11909. ALC_PIN_MODE("HP-OUT pin mode", 0x15, ALC_PIN_DIR_INOUT),
  11910. ALC_PIN_MODE("MIC1 pin mode", 0x18, ALC_PIN_DIR_INOUT),
  11911. ALC_PIN_MODE("LINE1 pin mode", 0x1a, ALC_PIN_DIR_INOUT),
  11912. /* Controls for GPIO pins, assuming they are configured as outputs */
  11913. ALC_GPIO_DATA_SWITCH("GPIO pin 0", 0x01, 0x01),
  11914. ALC_GPIO_DATA_SWITCH("GPIO pin 1", 0x01, 0x02),
  11915. ALC_GPIO_DATA_SWITCH("GPIO pin 2", 0x01, 0x04),
  11916. ALC_GPIO_DATA_SWITCH("GPIO pin 3", 0x01, 0x08),
  11917. /* Switches to allow the digital SPDIF output pin to be enabled.
  11918. * The ALC268 does not have an SPDIF input.
  11919. */
  11920. ALC_SPDIF_CTRL_SWITCH("SPDIF Playback Switch", 0x06, 0x01),
  11921. /* A switch allowing EAPD to be enabled. Some laptops seem to use
  11922. * this output to turn on an external amplifier.
  11923. */
  11924. ALC_EAPD_CTRL_SWITCH("LINE-OUT EAPD Enable Switch", 0x0f, 0x02),
  11925. ALC_EAPD_CTRL_SWITCH("HP-OUT EAPD Enable Switch", 0x10, 0x02),
  11926. { } /* end */
  11927. };
  11928. #endif
  11929. /* create input playback/capture controls for the given pin */
  11930. static int alc268_new_analog_output(struct alc_spec *spec, hda_nid_t nid,
  11931. const char *ctlname, int idx)
  11932. {
  11933. hda_nid_t dac;
  11934. int err;
  11935. switch (nid) {
  11936. case 0x14:
  11937. case 0x16:
  11938. dac = 0x02;
  11939. break;
  11940. case 0x15:
  11941. case 0x1a: /* ALC259/269 only */
  11942. case 0x1b: /* ALC259/269 only */
  11943. case 0x21: /* ALC269vb has this pin, too */
  11944. dac = 0x03;
  11945. break;
  11946. default:
  11947. snd_printd(KERN_WARNING "hda_codec: "
  11948. "ignoring pin 0x%x as unknown\n", nid);
  11949. return 0;
  11950. }
  11951. if (spec->multiout.dac_nids[0] != dac &&
  11952. spec->multiout.dac_nids[1] != dac) {
  11953. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, ctlname,
  11954. HDA_COMPOSE_AMP_VAL(dac, 3, idx,
  11955. HDA_OUTPUT));
  11956. if (err < 0)
  11957. return err;
  11958. spec->multiout.dac_nids[spec->multiout.num_dacs++] = dac;
  11959. }
  11960. if (nid != 0x16)
  11961. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, ctlname,
  11962. HDA_COMPOSE_AMP_VAL(nid, 3, idx, HDA_OUTPUT));
  11963. else /* mono */
  11964. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, ctlname,
  11965. HDA_COMPOSE_AMP_VAL(nid, 2, idx, HDA_OUTPUT));
  11966. if (err < 0)
  11967. return err;
  11968. return 0;
  11969. }
  11970. /* add playback controls from the parsed DAC table */
  11971. static int alc268_auto_create_multi_out_ctls(struct alc_spec *spec,
  11972. const struct auto_pin_cfg *cfg)
  11973. {
  11974. hda_nid_t nid;
  11975. int err;
  11976. spec->multiout.dac_nids = spec->private_dac_nids;
  11977. nid = cfg->line_out_pins[0];
  11978. if (nid) {
  11979. const char *name;
  11980. if (cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  11981. name = "Speaker";
  11982. else
  11983. name = "Front";
  11984. err = alc268_new_analog_output(spec, nid, name, 0);
  11985. if (err < 0)
  11986. return err;
  11987. }
  11988. nid = cfg->speaker_pins[0];
  11989. if (nid == 0x1d) {
  11990. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, "Speaker",
  11991. HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_INPUT));
  11992. if (err < 0)
  11993. return err;
  11994. } else if (nid) {
  11995. err = alc268_new_analog_output(spec, nid, "Speaker", 0);
  11996. if (err < 0)
  11997. return err;
  11998. }
  11999. nid = cfg->hp_pins[0];
  12000. if (nid) {
  12001. err = alc268_new_analog_output(spec, nid, "Headphone", 0);
  12002. if (err < 0)
  12003. return err;
  12004. }
  12005. nid = cfg->line_out_pins[1] | cfg->line_out_pins[2];
  12006. if (nid == 0x16) {
  12007. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, "Mono",
  12008. HDA_COMPOSE_AMP_VAL(nid, 2, 0, HDA_OUTPUT));
  12009. if (err < 0)
  12010. return err;
  12011. }
  12012. return 0;
  12013. }
  12014. /* create playback/capture controls for input pins */
  12015. static int alc268_auto_create_input_ctls(struct hda_codec *codec,
  12016. const struct auto_pin_cfg *cfg)
  12017. {
  12018. return alc_auto_create_input_ctls(codec, cfg, 0, 0x23, 0x24);
  12019. }
  12020. static void alc268_auto_set_output_and_unmute(struct hda_codec *codec,
  12021. hda_nid_t nid, int pin_type)
  12022. {
  12023. int idx;
  12024. alc_set_pin_output(codec, nid, pin_type);
  12025. if (nid == 0x14 || nid == 0x16)
  12026. idx = 0;
  12027. else
  12028. idx = 1;
  12029. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, idx);
  12030. }
  12031. static void alc268_auto_init_multi_out(struct hda_codec *codec)
  12032. {
  12033. struct alc_spec *spec = codec->spec;
  12034. hda_nid_t nid = spec->autocfg.line_out_pins[0];
  12035. if (nid) {
  12036. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  12037. alc268_auto_set_output_and_unmute(codec, nid, pin_type);
  12038. }
  12039. }
  12040. static void alc268_auto_init_hp_out(struct hda_codec *codec)
  12041. {
  12042. struct alc_spec *spec = codec->spec;
  12043. hda_nid_t pin;
  12044. pin = spec->autocfg.hp_pins[0];
  12045. if (pin)
  12046. alc268_auto_set_output_and_unmute(codec, pin, PIN_HP);
  12047. pin = spec->autocfg.speaker_pins[0];
  12048. if (pin)
  12049. alc268_auto_set_output_and_unmute(codec, pin, PIN_OUT);
  12050. }
  12051. static void alc268_auto_init_mono_speaker_out(struct hda_codec *codec)
  12052. {
  12053. struct alc_spec *spec = codec->spec;
  12054. hda_nid_t speaker_nid = spec->autocfg.speaker_pins[0];
  12055. hda_nid_t hp_nid = spec->autocfg.hp_pins[0];
  12056. hda_nid_t line_nid = spec->autocfg.line_out_pins[0];
  12057. unsigned int dac_vol1, dac_vol2;
  12058. if (line_nid == 0x1d || speaker_nid == 0x1d) {
  12059. snd_hda_codec_write(codec, speaker_nid, 0,
  12060. AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
  12061. /* mute mixer inputs from 0x1d */
  12062. snd_hda_codec_write(codec, 0x0f, 0,
  12063. AC_VERB_SET_AMP_GAIN_MUTE,
  12064. AMP_IN_UNMUTE(1));
  12065. snd_hda_codec_write(codec, 0x10, 0,
  12066. AC_VERB_SET_AMP_GAIN_MUTE,
  12067. AMP_IN_UNMUTE(1));
  12068. } else {
  12069. /* unmute mixer inputs from 0x1d */
  12070. snd_hda_codec_write(codec, 0x0f, 0,
  12071. AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1));
  12072. snd_hda_codec_write(codec, 0x10, 0,
  12073. AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1));
  12074. }
  12075. dac_vol1 = dac_vol2 = 0xb000 | 0x40; /* set max volume */
  12076. if (line_nid == 0x14)
  12077. dac_vol2 = AMP_OUT_ZERO;
  12078. else if (line_nid == 0x15)
  12079. dac_vol1 = AMP_OUT_ZERO;
  12080. if (hp_nid == 0x14)
  12081. dac_vol2 = AMP_OUT_ZERO;
  12082. else if (hp_nid == 0x15)
  12083. dac_vol1 = AMP_OUT_ZERO;
  12084. if (line_nid != 0x16 || hp_nid != 0x16 ||
  12085. spec->autocfg.line_out_pins[1] != 0x16 ||
  12086. spec->autocfg.line_out_pins[2] != 0x16)
  12087. dac_vol1 = dac_vol2 = AMP_OUT_ZERO;
  12088. snd_hda_codec_write(codec, 0x02, 0,
  12089. AC_VERB_SET_AMP_GAIN_MUTE, dac_vol1);
  12090. snd_hda_codec_write(codec, 0x03, 0,
  12091. AC_VERB_SET_AMP_GAIN_MUTE, dac_vol2);
  12092. }
  12093. /* pcm configuration: identical with ALC880 */
  12094. #define alc268_pcm_analog_playback alc880_pcm_analog_playback
  12095. #define alc268_pcm_analog_capture alc880_pcm_analog_capture
  12096. #define alc268_pcm_analog_alt_capture alc880_pcm_analog_alt_capture
  12097. #define alc268_pcm_digital_playback alc880_pcm_digital_playback
  12098. /*
  12099. * BIOS auto configuration
  12100. */
  12101. static int alc268_parse_auto_config(struct hda_codec *codec)
  12102. {
  12103. struct alc_spec *spec = codec->spec;
  12104. int err;
  12105. static hda_nid_t alc268_ignore[] = { 0 };
  12106. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  12107. alc268_ignore);
  12108. if (err < 0)
  12109. return err;
  12110. if (!spec->autocfg.line_outs) {
  12111. if (spec->autocfg.dig_outs || spec->autocfg.dig_in_pin) {
  12112. spec->multiout.max_channels = 2;
  12113. spec->no_analog = 1;
  12114. goto dig_only;
  12115. }
  12116. return 0; /* can't find valid BIOS pin config */
  12117. }
  12118. err = alc268_auto_create_multi_out_ctls(spec, &spec->autocfg);
  12119. if (err < 0)
  12120. return err;
  12121. err = alc268_auto_create_input_ctls(codec, &spec->autocfg);
  12122. if (err < 0)
  12123. return err;
  12124. spec->multiout.max_channels = 2;
  12125. dig_only:
  12126. /* digital only support output */
  12127. alc_auto_parse_digital(codec);
  12128. if (spec->kctls.list)
  12129. add_mixer(spec, spec->kctls.list);
  12130. if (!spec->no_analog && spec->autocfg.speaker_pins[0] != 0x1d)
  12131. add_mixer(spec, alc268_beep_mixer);
  12132. add_verb(spec, alc268_volume_init_verbs);
  12133. spec->num_mux_defs = 2;
  12134. spec->input_mux = &spec->private_imux[0];
  12135. err = alc_auto_add_mic_boost(codec);
  12136. if (err < 0)
  12137. return err;
  12138. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
  12139. return 1;
  12140. }
  12141. #define alc268_auto_init_analog_input alc882_auto_init_analog_input
  12142. /* init callback for auto-configuration model -- overriding the default init */
  12143. static void alc268_auto_init(struct hda_codec *codec)
  12144. {
  12145. struct alc_spec *spec = codec->spec;
  12146. alc268_auto_init_multi_out(codec);
  12147. alc268_auto_init_hp_out(codec);
  12148. alc268_auto_init_mono_speaker_out(codec);
  12149. alc268_auto_init_analog_input(codec);
  12150. alc_auto_init_digital(codec);
  12151. if (spec->unsol_event)
  12152. alc_inithook(codec);
  12153. }
  12154. /*
  12155. * configuration and preset
  12156. */
  12157. static const char *alc268_models[ALC268_MODEL_LAST] = {
  12158. [ALC267_QUANTA_IL1] = "quanta-il1",
  12159. [ALC268_3ST] = "3stack",
  12160. [ALC268_TOSHIBA] = "toshiba",
  12161. [ALC268_ACER] = "acer",
  12162. [ALC268_ACER_DMIC] = "acer-dmic",
  12163. [ALC268_ACER_ASPIRE_ONE] = "acer-aspire",
  12164. [ALC268_DELL] = "dell",
  12165. [ALC268_ZEPTO] = "zepto",
  12166. #ifdef CONFIG_SND_DEBUG
  12167. [ALC268_TEST] = "test",
  12168. #endif
  12169. [ALC268_AUTO] = "auto",
  12170. };
  12171. static struct snd_pci_quirk alc268_cfg_tbl[] = {
  12172. SND_PCI_QUIRK(0x1025, 0x011e, "Acer Aspire 5720z", ALC268_ACER),
  12173. SND_PCI_QUIRK(0x1025, 0x0126, "Acer", ALC268_ACER),
  12174. SND_PCI_QUIRK(0x1025, 0x012e, "Acer Aspire 5310", ALC268_ACER),
  12175. SND_PCI_QUIRK(0x1025, 0x0130, "Acer Extensa 5210", ALC268_ACER),
  12176. SND_PCI_QUIRK(0x1025, 0x0136, "Acer Aspire 5315", ALC268_ACER),
  12177. SND_PCI_QUIRK(0x1025, 0x015b, "Acer Aspire One",
  12178. ALC268_ACER_ASPIRE_ONE),
  12179. SND_PCI_QUIRK(0x1028, 0x0253, "Dell OEM", ALC268_DELL),
  12180. SND_PCI_QUIRK_MASK(0x1028, 0xfff0, 0x02b0,
  12181. "Dell Inspiron Mini9/Vostro A90", ALC268_DELL),
  12182. /* almost compatible with toshiba but with optional digital outs;
  12183. * auto-probing seems working fine
  12184. */
  12185. SND_PCI_QUIRK_MASK(0x103c, 0xff00, 0x3000, "HP TX25xx series",
  12186. ALC268_AUTO),
  12187. SND_PCI_QUIRK(0x1043, 0x1205, "ASUS W7J", ALC268_3ST),
  12188. SND_PCI_QUIRK(0x1170, 0x0040, "ZEPTO", ALC268_ZEPTO),
  12189. SND_PCI_QUIRK(0x14c0, 0x0025, "COMPAL IFL90/JFL-92", ALC268_TOSHIBA),
  12190. SND_PCI_QUIRK(0x152d, 0x0763, "Diverse (CPR2000)", ALC268_ACER),
  12191. SND_PCI_QUIRK(0x152d, 0x0771, "Quanta IL1", ALC267_QUANTA_IL1),
  12192. {}
  12193. };
  12194. /* Toshiba laptops have no unique PCI SSID but only codec SSID */
  12195. static struct snd_pci_quirk alc268_ssid_cfg_tbl[] = {
  12196. SND_PCI_QUIRK(0x1179, 0xff0a, "TOSHIBA X-200", ALC268_AUTO),
  12197. SND_PCI_QUIRK(0x1179, 0xff0e, "TOSHIBA X-200 HDMI", ALC268_AUTO),
  12198. SND_PCI_QUIRK_MASK(0x1179, 0xff00, 0xff00, "TOSHIBA A/Lx05",
  12199. ALC268_TOSHIBA),
  12200. {}
  12201. };
  12202. static struct alc_config_preset alc268_presets[] = {
  12203. [ALC267_QUANTA_IL1] = {
  12204. .mixers = { alc267_quanta_il1_mixer, alc268_beep_mixer,
  12205. alc268_capture_nosrc_mixer },
  12206. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12207. alc267_quanta_il1_verbs },
  12208. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12209. .dac_nids = alc268_dac_nids,
  12210. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12211. .adc_nids = alc268_adc_nids_alt,
  12212. .hp_nid = 0x03,
  12213. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12214. .channel_mode = alc268_modes,
  12215. .unsol_event = alc_sku_unsol_event,
  12216. .setup = alc267_quanta_il1_setup,
  12217. .init_hook = alc_inithook,
  12218. },
  12219. [ALC268_3ST] = {
  12220. .mixers = { alc268_base_mixer, alc268_capture_alt_mixer,
  12221. alc268_beep_mixer },
  12222. .init_verbs = { alc268_base_init_verbs },
  12223. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12224. .dac_nids = alc268_dac_nids,
  12225. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12226. .adc_nids = alc268_adc_nids_alt,
  12227. .capsrc_nids = alc268_capsrc_nids,
  12228. .hp_nid = 0x03,
  12229. .dig_out_nid = ALC268_DIGOUT_NID,
  12230. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12231. .channel_mode = alc268_modes,
  12232. .input_mux = &alc268_capture_source,
  12233. },
  12234. [ALC268_TOSHIBA] = {
  12235. .mixers = { alc268_toshiba_mixer, alc268_capture_alt_mixer,
  12236. alc268_beep_mixer },
  12237. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12238. alc268_toshiba_verbs },
  12239. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12240. .dac_nids = alc268_dac_nids,
  12241. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12242. .adc_nids = alc268_adc_nids_alt,
  12243. .capsrc_nids = alc268_capsrc_nids,
  12244. .hp_nid = 0x03,
  12245. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12246. .channel_mode = alc268_modes,
  12247. .input_mux = &alc268_capture_source,
  12248. .unsol_event = alc268_toshiba_unsol_event,
  12249. .setup = alc268_toshiba_setup,
  12250. .init_hook = alc268_toshiba_automute,
  12251. },
  12252. [ALC268_ACER] = {
  12253. .mixers = { alc268_acer_mixer, alc268_capture_alt_mixer,
  12254. alc268_beep_mixer },
  12255. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12256. alc268_acer_verbs },
  12257. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12258. .dac_nids = alc268_dac_nids,
  12259. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12260. .adc_nids = alc268_adc_nids_alt,
  12261. .capsrc_nids = alc268_capsrc_nids,
  12262. .hp_nid = 0x02,
  12263. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12264. .channel_mode = alc268_modes,
  12265. .input_mux = &alc268_acer_capture_source,
  12266. .unsol_event = alc268_acer_unsol_event,
  12267. .init_hook = alc268_acer_init_hook,
  12268. },
  12269. [ALC268_ACER_DMIC] = {
  12270. .mixers = { alc268_acer_dmic_mixer, alc268_capture_alt_mixer,
  12271. alc268_beep_mixer },
  12272. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12273. alc268_acer_verbs },
  12274. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12275. .dac_nids = alc268_dac_nids,
  12276. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12277. .adc_nids = alc268_adc_nids_alt,
  12278. .capsrc_nids = alc268_capsrc_nids,
  12279. .hp_nid = 0x02,
  12280. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12281. .channel_mode = alc268_modes,
  12282. .input_mux = &alc268_acer_dmic_capture_source,
  12283. .unsol_event = alc268_acer_unsol_event,
  12284. .init_hook = alc268_acer_init_hook,
  12285. },
  12286. [ALC268_ACER_ASPIRE_ONE] = {
  12287. .mixers = { alc268_acer_aspire_one_mixer,
  12288. alc268_beep_mixer,
  12289. alc268_capture_nosrc_mixer },
  12290. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12291. alc268_acer_aspire_one_verbs },
  12292. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12293. .dac_nids = alc268_dac_nids,
  12294. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12295. .adc_nids = alc268_adc_nids_alt,
  12296. .capsrc_nids = alc268_capsrc_nids,
  12297. .hp_nid = 0x03,
  12298. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12299. .channel_mode = alc268_modes,
  12300. .unsol_event = alc268_acer_lc_unsol_event,
  12301. .setup = alc268_acer_lc_setup,
  12302. .init_hook = alc268_acer_lc_init_hook,
  12303. },
  12304. [ALC268_DELL] = {
  12305. .mixers = { alc268_dell_mixer, alc268_beep_mixer,
  12306. alc268_capture_nosrc_mixer },
  12307. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12308. alc268_dell_verbs },
  12309. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12310. .dac_nids = alc268_dac_nids,
  12311. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12312. .adc_nids = alc268_adc_nids_alt,
  12313. .capsrc_nids = alc268_capsrc_nids,
  12314. .hp_nid = 0x02,
  12315. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12316. .channel_mode = alc268_modes,
  12317. .unsol_event = alc_sku_unsol_event,
  12318. .setup = alc268_dell_setup,
  12319. .init_hook = alc_inithook,
  12320. },
  12321. [ALC268_ZEPTO] = {
  12322. .mixers = { alc268_base_mixer, alc268_capture_alt_mixer,
  12323. alc268_beep_mixer },
  12324. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12325. alc268_toshiba_verbs },
  12326. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12327. .dac_nids = alc268_dac_nids,
  12328. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12329. .adc_nids = alc268_adc_nids_alt,
  12330. .capsrc_nids = alc268_capsrc_nids,
  12331. .hp_nid = 0x03,
  12332. .dig_out_nid = ALC268_DIGOUT_NID,
  12333. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12334. .channel_mode = alc268_modes,
  12335. .input_mux = &alc268_capture_source,
  12336. .setup = alc268_toshiba_setup,
  12337. .init_hook = alc268_toshiba_automute,
  12338. },
  12339. #ifdef CONFIG_SND_DEBUG
  12340. [ALC268_TEST] = {
  12341. .mixers = { alc268_test_mixer, alc268_capture_mixer },
  12342. .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs,
  12343. alc268_volume_init_verbs },
  12344. .num_dacs = ARRAY_SIZE(alc268_dac_nids),
  12345. .dac_nids = alc268_dac_nids,
  12346. .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt),
  12347. .adc_nids = alc268_adc_nids_alt,
  12348. .capsrc_nids = alc268_capsrc_nids,
  12349. .hp_nid = 0x03,
  12350. .dig_out_nid = ALC268_DIGOUT_NID,
  12351. .num_channel_mode = ARRAY_SIZE(alc268_modes),
  12352. .channel_mode = alc268_modes,
  12353. .input_mux = &alc268_capture_source,
  12354. },
  12355. #endif
  12356. };
  12357. static int patch_alc268(struct hda_codec *codec)
  12358. {
  12359. struct alc_spec *spec;
  12360. int board_config;
  12361. int i, has_beep, err;
  12362. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  12363. if (spec == NULL)
  12364. return -ENOMEM;
  12365. codec->spec = spec;
  12366. board_config = snd_hda_check_board_config(codec, ALC268_MODEL_LAST,
  12367. alc268_models,
  12368. alc268_cfg_tbl);
  12369. if (board_config < 0 || board_config >= ALC268_MODEL_LAST)
  12370. board_config = snd_hda_check_board_codec_sid_config(codec,
  12371. ALC268_MODEL_LAST, alc268_models, alc268_ssid_cfg_tbl);
  12372. if (board_config < 0 || board_config >= ALC268_MODEL_LAST) {
  12373. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  12374. codec->chip_name);
  12375. board_config = ALC268_AUTO;
  12376. }
  12377. if (board_config == ALC268_AUTO) {
  12378. /* automatic parse from the BIOS config */
  12379. err = alc268_parse_auto_config(codec);
  12380. if (err < 0) {
  12381. alc_free(codec);
  12382. return err;
  12383. } else if (!err) {
  12384. printk(KERN_INFO
  12385. "hda_codec: Cannot set up configuration "
  12386. "from BIOS. Using base mode...\n");
  12387. board_config = ALC268_3ST;
  12388. }
  12389. }
  12390. if (board_config != ALC268_AUTO)
  12391. setup_preset(codec, &alc268_presets[board_config]);
  12392. spec->stream_analog_playback = &alc268_pcm_analog_playback;
  12393. spec->stream_analog_capture = &alc268_pcm_analog_capture;
  12394. spec->stream_analog_alt_capture = &alc268_pcm_analog_alt_capture;
  12395. spec->stream_digital_playback = &alc268_pcm_digital_playback;
  12396. has_beep = 0;
  12397. for (i = 0; i < spec->num_mixers; i++) {
  12398. if (spec->mixers[i] == alc268_beep_mixer) {
  12399. has_beep = 1;
  12400. break;
  12401. }
  12402. }
  12403. if (has_beep) {
  12404. err = snd_hda_attach_beep_device(codec, 0x1);
  12405. if (err < 0) {
  12406. alc_free(codec);
  12407. return err;
  12408. }
  12409. if (!query_amp_caps(codec, 0x1d, HDA_INPUT))
  12410. /* override the amp caps for beep generator */
  12411. snd_hda_override_amp_caps(codec, 0x1d, HDA_INPUT,
  12412. (0x0c << AC_AMPCAP_OFFSET_SHIFT) |
  12413. (0x0c << AC_AMPCAP_NUM_STEPS_SHIFT) |
  12414. (0x07 << AC_AMPCAP_STEP_SIZE_SHIFT) |
  12415. (0 << AC_AMPCAP_MUTE_SHIFT));
  12416. }
  12417. if (!spec->no_analog && !spec->adc_nids && spec->input_mux) {
  12418. /* check whether NID 0x07 is valid */
  12419. unsigned int wcap = get_wcaps(codec, 0x07);
  12420. int i;
  12421. spec->capsrc_nids = alc268_capsrc_nids;
  12422. /* get type */
  12423. wcap = get_wcaps_type(wcap);
  12424. if (spec->auto_mic ||
  12425. wcap != AC_WID_AUD_IN || spec->input_mux->num_items == 1) {
  12426. spec->adc_nids = alc268_adc_nids_alt;
  12427. spec->num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt);
  12428. if (spec->auto_mic)
  12429. fixup_automic_adc(codec);
  12430. if (spec->auto_mic || spec->input_mux->num_items == 1)
  12431. add_mixer(spec, alc268_capture_nosrc_mixer);
  12432. else
  12433. add_mixer(spec, alc268_capture_alt_mixer);
  12434. } else {
  12435. spec->adc_nids = alc268_adc_nids;
  12436. spec->num_adc_nids = ARRAY_SIZE(alc268_adc_nids);
  12437. add_mixer(spec, alc268_capture_mixer);
  12438. }
  12439. /* set default input source */
  12440. for (i = 0; i < spec->num_adc_nids; i++)
  12441. snd_hda_codec_write_cache(codec, alc268_capsrc_nids[i],
  12442. 0, AC_VERB_SET_CONNECT_SEL,
  12443. i < spec->num_mux_defs ?
  12444. spec->input_mux[i].items[0].index :
  12445. spec->input_mux->items[0].index);
  12446. }
  12447. spec->vmaster_nid = 0x02;
  12448. codec->patch_ops = alc_patch_ops;
  12449. if (board_config == ALC268_AUTO)
  12450. spec->init_hook = alc268_auto_init;
  12451. return 0;
  12452. }
  12453. /*
  12454. * ALC269 channel source setting (2 channel)
  12455. */
  12456. #define ALC269_DIGOUT_NID ALC880_DIGOUT_NID
  12457. #define alc269_dac_nids alc260_dac_nids
  12458. static hda_nid_t alc269_adc_nids[1] = {
  12459. /* ADC1 */
  12460. 0x08,
  12461. };
  12462. static hda_nid_t alc269_capsrc_nids[1] = {
  12463. 0x23,
  12464. };
  12465. static hda_nid_t alc269vb_adc_nids[1] = {
  12466. /* ADC1 */
  12467. 0x09,
  12468. };
  12469. static hda_nid_t alc269vb_capsrc_nids[1] = {
  12470. 0x22,
  12471. };
  12472. static hda_nid_t alc269_adc_candidates[] = {
  12473. 0x08, 0x09, 0x07,
  12474. };
  12475. #define alc269_modes alc260_modes
  12476. #define alc269_capture_source alc880_lg_lw_capture_source
  12477. static struct snd_kcontrol_new alc269_base_mixer[] = {
  12478. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  12479. HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  12480. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  12481. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  12482. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  12483. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  12484. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  12485. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  12486. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  12487. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  12488. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  12489. HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x16, 2, 0x0, HDA_OUTPUT),
  12490. { } /* end */
  12491. };
  12492. static struct snd_kcontrol_new alc269_quanta_fl1_mixer[] = {
  12493. /* output mixer control */
  12494. HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol),
  12495. {
  12496. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  12497. .name = "Master Playback Switch",
  12498. .subdevice = HDA_SUBDEV_AMP_FLAG,
  12499. .info = snd_hda_mixer_amp_switch_info,
  12500. .get = snd_hda_mixer_amp_switch_get,
  12501. .put = alc268_acer_master_sw_put,
  12502. .private_value = HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  12503. },
  12504. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  12505. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  12506. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  12507. HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  12508. HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  12509. HDA_CODEC_VOLUME("Internal Mic Boost", 0x19, 0, HDA_INPUT),
  12510. { }
  12511. };
  12512. static struct snd_kcontrol_new alc269_lifebook_mixer[] = {
  12513. /* output mixer control */
  12514. HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol),
  12515. {
  12516. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  12517. .name = "Master Playback Switch",
  12518. .subdevice = HDA_SUBDEV_AMP_FLAG,
  12519. .info = snd_hda_mixer_amp_switch_info,
  12520. .get = snd_hda_mixer_amp_switch_get,
  12521. .put = alc268_acer_master_sw_put,
  12522. .private_value = HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  12523. },
  12524. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  12525. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  12526. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  12527. HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  12528. HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  12529. HDA_CODEC_VOLUME("Internal Mic Boost", 0x19, 0, HDA_INPUT),
  12530. HDA_CODEC_VOLUME("Dock Mic Playback Volume", 0x0b, 0x03, HDA_INPUT),
  12531. HDA_CODEC_MUTE("Dock Mic Playback Switch", 0x0b, 0x03, HDA_INPUT),
  12532. HDA_CODEC_VOLUME("Dock Mic Boost", 0x1b, 0, HDA_INPUT),
  12533. { }
  12534. };
  12535. static struct snd_kcontrol_new alc269_laptop_mixer[] = {
  12536. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  12537. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  12538. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  12539. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  12540. { } /* end */
  12541. };
  12542. static struct snd_kcontrol_new alc269vb_laptop_mixer[] = {
  12543. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  12544. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  12545. HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
  12546. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  12547. { } /* end */
  12548. };
  12549. static struct snd_kcontrol_new alc269_asus_mixer[] = {
  12550. HDA_CODEC_VOLUME("Master Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  12551. HDA_CODEC_MUTE("Master Playback Switch", 0x0c, 0x0, HDA_INPUT),
  12552. { } /* end */
  12553. };
  12554. /* capture mixer elements */
  12555. static struct snd_kcontrol_new alc269_laptop_analog_capture_mixer[] = {
  12556. HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
  12557. HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
  12558. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  12559. HDA_CODEC_VOLUME("IntMic Boost", 0x19, 0, HDA_INPUT),
  12560. { } /* end */
  12561. };
  12562. static struct snd_kcontrol_new alc269_laptop_digital_capture_mixer[] = {
  12563. HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
  12564. HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
  12565. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  12566. { } /* end */
  12567. };
  12568. static struct snd_kcontrol_new alc269vb_laptop_analog_capture_mixer[] = {
  12569. HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
  12570. HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
  12571. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  12572. HDA_CODEC_VOLUME("IntMic Boost", 0x19, 0, HDA_INPUT),
  12573. { } /* end */
  12574. };
  12575. static struct snd_kcontrol_new alc269vb_laptop_digital_capture_mixer[] = {
  12576. HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
  12577. HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
  12578. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  12579. { } /* end */
  12580. };
  12581. /* FSC amilo */
  12582. #define alc269_fujitsu_mixer alc269_laptop_mixer
  12583. static struct hda_verb alc269_quanta_fl1_verbs[] = {
  12584. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  12585. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12586. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  12587. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  12588. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  12589. {0x1d, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12590. { }
  12591. };
  12592. static struct hda_verb alc269_lifebook_verbs[] = {
  12593. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  12594. {0x1a, AC_VERB_SET_CONNECT_SEL, 0x01},
  12595. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12596. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  12597. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  12598. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  12599. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  12600. {0x1a, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  12601. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  12602. {0x1d, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12603. { }
  12604. };
  12605. /* toggle speaker-output according to the hp-jack state */
  12606. static void alc269_quanta_fl1_speaker_automute(struct hda_codec *codec)
  12607. {
  12608. unsigned int present;
  12609. unsigned char bits;
  12610. present = snd_hda_jack_detect(codec, 0x15);
  12611. bits = present ? HDA_AMP_MUTE : 0;
  12612. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  12613. HDA_AMP_MUTE, bits);
  12614. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  12615. HDA_AMP_MUTE, bits);
  12616. snd_hda_codec_write(codec, 0x20, 0,
  12617. AC_VERB_SET_COEF_INDEX, 0x0c);
  12618. snd_hda_codec_write(codec, 0x20, 0,
  12619. AC_VERB_SET_PROC_COEF, 0x680);
  12620. snd_hda_codec_write(codec, 0x20, 0,
  12621. AC_VERB_SET_COEF_INDEX, 0x0c);
  12622. snd_hda_codec_write(codec, 0x20, 0,
  12623. AC_VERB_SET_PROC_COEF, 0x480);
  12624. }
  12625. /* toggle speaker-output according to the hp-jacks state */
  12626. static void alc269_lifebook_speaker_automute(struct hda_codec *codec)
  12627. {
  12628. unsigned int present;
  12629. unsigned char bits;
  12630. /* Check laptop headphone socket */
  12631. present = snd_hda_jack_detect(codec, 0x15);
  12632. /* Check port replicator headphone socket */
  12633. present |= snd_hda_jack_detect(codec, 0x1a);
  12634. bits = present ? HDA_AMP_MUTE : 0;
  12635. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  12636. HDA_AMP_MUTE, bits);
  12637. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  12638. HDA_AMP_MUTE, bits);
  12639. snd_hda_codec_write(codec, 0x20, 0,
  12640. AC_VERB_SET_COEF_INDEX, 0x0c);
  12641. snd_hda_codec_write(codec, 0x20, 0,
  12642. AC_VERB_SET_PROC_COEF, 0x680);
  12643. snd_hda_codec_write(codec, 0x20, 0,
  12644. AC_VERB_SET_COEF_INDEX, 0x0c);
  12645. snd_hda_codec_write(codec, 0x20, 0,
  12646. AC_VERB_SET_PROC_COEF, 0x480);
  12647. }
  12648. static void alc269_lifebook_mic_autoswitch(struct hda_codec *codec)
  12649. {
  12650. unsigned int present_laptop;
  12651. unsigned int present_dock;
  12652. present_laptop = snd_hda_jack_detect(codec, 0x18);
  12653. present_dock = snd_hda_jack_detect(codec, 0x1b);
  12654. /* Laptop mic port overrides dock mic port, design decision */
  12655. if (present_dock)
  12656. snd_hda_codec_write(codec, 0x23, 0,
  12657. AC_VERB_SET_CONNECT_SEL, 0x3);
  12658. if (present_laptop)
  12659. snd_hda_codec_write(codec, 0x23, 0,
  12660. AC_VERB_SET_CONNECT_SEL, 0x0);
  12661. if (!present_dock && !present_laptop)
  12662. snd_hda_codec_write(codec, 0x23, 0,
  12663. AC_VERB_SET_CONNECT_SEL, 0x1);
  12664. }
  12665. static void alc269_quanta_fl1_unsol_event(struct hda_codec *codec,
  12666. unsigned int res)
  12667. {
  12668. switch (res >> 26) {
  12669. case ALC880_HP_EVENT:
  12670. alc269_quanta_fl1_speaker_automute(codec);
  12671. break;
  12672. case ALC880_MIC_EVENT:
  12673. alc_mic_automute(codec);
  12674. break;
  12675. }
  12676. }
  12677. static void alc269_lifebook_unsol_event(struct hda_codec *codec,
  12678. unsigned int res)
  12679. {
  12680. if ((res >> 26) == ALC880_HP_EVENT)
  12681. alc269_lifebook_speaker_automute(codec);
  12682. if ((res >> 26) == ALC880_MIC_EVENT)
  12683. alc269_lifebook_mic_autoswitch(codec);
  12684. }
  12685. static void alc269_quanta_fl1_setup(struct hda_codec *codec)
  12686. {
  12687. struct alc_spec *spec = codec->spec;
  12688. spec->autocfg.hp_pins[0] = 0x15;
  12689. spec->autocfg.speaker_pins[0] = 0x14;
  12690. spec->ext_mic.pin = 0x18;
  12691. spec->ext_mic.mux_idx = 0;
  12692. spec->int_mic.pin = 0x19;
  12693. spec->int_mic.mux_idx = 1;
  12694. spec->auto_mic = 1;
  12695. }
  12696. static void alc269_quanta_fl1_init_hook(struct hda_codec *codec)
  12697. {
  12698. alc269_quanta_fl1_speaker_automute(codec);
  12699. alc_mic_automute(codec);
  12700. }
  12701. static void alc269_lifebook_init_hook(struct hda_codec *codec)
  12702. {
  12703. alc269_lifebook_speaker_automute(codec);
  12704. alc269_lifebook_mic_autoswitch(codec);
  12705. }
  12706. static struct hda_verb alc269_laptop_dmic_init_verbs[] = {
  12707. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  12708. {0x23, AC_VERB_SET_CONNECT_SEL, 0x05},
  12709. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
  12710. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, (0x7019 | (0x00 << 8))},
  12711. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12712. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  12713. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  12714. {}
  12715. };
  12716. static struct hda_verb alc269_laptop_amic_init_verbs[] = {
  12717. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  12718. {0x23, AC_VERB_SET_CONNECT_SEL, 0x01},
  12719. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
  12720. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, (0x701b | (0x00 << 8))},
  12721. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  12722. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  12723. {}
  12724. };
  12725. static struct hda_verb alc269vb_laptop_dmic_init_verbs[] = {
  12726. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},
  12727. {0x22, AC_VERB_SET_CONNECT_SEL, 0x06},
  12728. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
  12729. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7019 | (0x00 << 8))},
  12730. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12731. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  12732. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  12733. {}
  12734. };
  12735. static struct hda_verb alc269vb_laptop_amic_init_verbs[] = {
  12736. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01},
  12737. {0x22, AC_VERB_SET_CONNECT_SEL, 0x01},
  12738. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, 0xb026 },
  12739. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, (0x7019 | (0x00 << 8))},
  12740. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12741. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  12742. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  12743. {}
  12744. };
  12745. static struct hda_verb alc271_acer_dmic_verbs[] = {
  12746. {0x20, AC_VERB_SET_COEF_INDEX, 0x0d},
  12747. {0x20, AC_VERB_SET_PROC_COEF, 0x4000},
  12748. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12749. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  12750. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  12751. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  12752. {0x21, AC_VERB_SET_CONNECT_SEL, 0x00},
  12753. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  12754. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  12755. {0x22, AC_VERB_SET_CONNECT_SEL, 6},
  12756. { }
  12757. };
  12758. /* toggle speaker-output according to the hp-jack state */
  12759. static void alc269_speaker_automute(struct hda_codec *codec)
  12760. {
  12761. struct alc_spec *spec = codec->spec;
  12762. unsigned int nid = spec->autocfg.hp_pins[0];
  12763. unsigned int present;
  12764. unsigned char bits;
  12765. present = snd_hda_jack_detect(codec, nid);
  12766. bits = present ? HDA_AMP_MUTE : 0;
  12767. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  12768. HDA_AMP_MUTE, bits);
  12769. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  12770. HDA_AMP_MUTE, bits);
  12771. }
  12772. /* unsolicited event for HP jack sensing */
  12773. static void alc269_laptop_unsol_event(struct hda_codec *codec,
  12774. unsigned int res)
  12775. {
  12776. switch (res >> 26) {
  12777. case ALC880_HP_EVENT:
  12778. alc269_speaker_automute(codec);
  12779. break;
  12780. case ALC880_MIC_EVENT:
  12781. alc_mic_automute(codec);
  12782. break;
  12783. }
  12784. }
  12785. static void alc269_laptop_amic_setup(struct hda_codec *codec)
  12786. {
  12787. struct alc_spec *spec = codec->spec;
  12788. spec->autocfg.hp_pins[0] = 0x15;
  12789. spec->autocfg.speaker_pins[0] = 0x14;
  12790. spec->ext_mic.pin = 0x18;
  12791. spec->ext_mic.mux_idx = 0;
  12792. spec->int_mic.pin = 0x19;
  12793. spec->int_mic.mux_idx = 1;
  12794. spec->auto_mic = 1;
  12795. }
  12796. static void alc269_laptop_dmic_setup(struct hda_codec *codec)
  12797. {
  12798. struct alc_spec *spec = codec->spec;
  12799. spec->autocfg.hp_pins[0] = 0x15;
  12800. spec->autocfg.speaker_pins[0] = 0x14;
  12801. spec->ext_mic.pin = 0x18;
  12802. spec->ext_mic.mux_idx = 0;
  12803. spec->int_mic.pin = 0x12;
  12804. spec->int_mic.mux_idx = 5;
  12805. spec->auto_mic = 1;
  12806. }
  12807. static void alc269vb_laptop_amic_setup(struct hda_codec *codec)
  12808. {
  12809. struct alc_spec *spec = codec->spec;
  12810. spec->autocfg.hp_pins[0] = 0x21;
  12811. spec->autocfg.speaker_pins[0] = 0x14;
  12812. spec->ext_mic.pin = 0x18;
  12813. spec->ext_mic.mux_idx = 0;
  12814. spec->int_mic.pin = 0x19;
  12815. spec->int_mic.mux_idx = 1;
  12816. spec->auto_mic = 1;
  12817. }
  12818. static void alc269vb_laptop_dmic_setup(struct hda_codec *codec)
  12819. {
  12820. struct alc_spec *spec = codec->spec;
  12821. spec->autocfg.hp_pins[0] = 0x21;
  12822. spec->autocfg.speaker_pins[0] = 0x14;
  12823. spec->ext_mic.pin = 0x18;
  12824. spec->ext_mic.mux_idx = 0;
  12825. spec->int_mic.pin = 0x12;
  12826. spec->int_mic.mux_idx = 6;
  12827. spec->auto_mic = 1;
  12828. }
  12829. static void alc269_laptop_inithook(struct hda_codec *codec)
  12830. {
  12831. alc269_speaker_automute(codec);
  12832. alc_mic_automute(codec);
  12833. }
  12834. /*
  12835. * generic initialization of ADC, input mixers and output mixers
  12836. */
  12837. static struct hda_verb alc269_init_verbs[] = {
  12838. /*
  12839. * Unmute ADC0 and set the default input to mic-in
  12840. */
  12841. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12842. /*
  12843. * Set up output mixers (0x02 - 0x03)
  12844. */
  12845. /* set vol=0 to output mixers */
  12846. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  12847. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  12848. /* set up input amps for analog loopback */
  12849. /* Amp Indices: DAC = 0, mixer = 1 */
  12850. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12851. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  12852. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12853. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  12854. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12855. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  12856. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  12857. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  12858. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  12859. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  12860. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  12861. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12862. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12863. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  12864. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  12865. /* FIXME: use Mux-type input source selection */
  12866. /* Mixer elements: 0x18, 19, 1a, 1b, 1d, 0b */
  12867. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  12868. {0x23, AC_VERB_SET_CONNECT_SEL, 0x00},
  12869. /* set EAPD */
  12870. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  12871. { }
  12872. };
  12873. static struct hda_verb alc269vb_init_verbs[] = {
  12874. /*
  12875. * Unmute ADC0 and set the default input to mic-in
  12876. */
  12877. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12878. /*
  12879. * Set up output mixers (0x02 - 0x03)
  12880. */
  12881. /* set vol=0 to output mixers */
  12882. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  12883. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  12884. /* set up input amps for analog loopback */
  12885. /* Amp Indices: DAC = 0, mixer = 1 */
  12886. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12887. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  12888. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12889. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  12890. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  12891. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  12892. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  12893. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  12894. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  12895. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  12896. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  12897. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12898. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  12899. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  12900. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  12901. /* FIXME: use Mux-type input source selection */
  12902. /* Mixer elements: 0x18, 19, 1a, 1b, 1d, 0b */
  12903. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  12904. {0x22, AC_VERB_SET_CONNECT_SEL, 0x00},
  12905. /* set EAPD */
  12906. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  12907. { }
  12908. };
  12909. #define alc269_auto_create_multi_out_ctls \
  12910. alc268_auto_create_multi_out_ctls
  12911. #define alc269_auto_create_input_ctls \
  12912. alc268_auto_create_input_ctls
  12913. #ifdef CONFIG_SND_HDA_POWER_SAVE
  12914. #define alc269_loopbacks alc880_loopbacks
  12915. #endif
  12916. /* pcm configuration: identical with ALC880 */
  12917. #define alc269_pcm_analog_playback alc880_pcm_analog_playback
  12918. #define alc269_pcm_analog_capture alc880_pcm_analog_capture
  12919. #define alc269_pcm_digital_playback alc880_pcm_digital_playback
  12920. #define alc269_pcm_digital_capture alc880_pcm_digital_capture
  12921. static struct hda_pcm_stream alc269_44k_pcm_analog_playback = {
  12922. .substreams = 1,
  12923. .channels_min = 2,
  12924. .channels_max = 8,
  12925. .rates = SNDRV_PCM_RATE_44100, /* fixed rate */
  12926. /* NID is set in alc_build_pcms */
  12927. .ops = {
  12928. .open = alc880_playback_pcm_open,
  12929. .prepare = alc880_playback_pcm_prepare,
  12930. .cleanup = alc880_playback_pcm_cleanup
  12931. },
  12932. };
  12933. static struct hda_pcm_stream alc269_44k_pcm_analog_capture = {
  12934. .substreams = 1,
  12935. .channels_min = 2,
  12936. .channels_max = 2,
  12937. .rates = SNDRV_PCM_RATE_44100, /* fixed rate */
  12938. /* NID is set in alc_build_pcms */
  12939. };
  12940. #ifdef CONFIG_SND_HDA_POWER_SAVE
  12941. static int alc269_mic2_for_mute_led(struct hda_codec *codec)
  12942. {
  12943. switch (codec->subsystem_id) {
  12944. case 0x103c1586:
  12945. return 1;
  12946. }
  12947. return 0;
  12948. }
  12949. static int alc269_mic2_mute_check_ps(struct hda_codec *codec, hda_nid_t nid)
  12950. {
  12951. /* update mute-LED according to the speaker mute state */
  12952. if (nid == 0x01 || nid == 0x14) {
  12953. int pinval;
  12954. if (snd_hda_codec_amp_read(codec, 0x14, 0, HDA_OUTPUT, 0) &
  12955. HDA_AMP_MUTE)
  12956. pinval = 0x24;
  12957. else
  12958. pinval = 0x20;
  12959. /* mic2 vref pin is used for mute LED control */
  12960. snd_hda_codec_update_cache(codec, 0x19, 0,
  12961. AC_VERB_SET_PIN_WIDGET_CONTROL,
  12962. pinval);
  12963. }
  12964. return alc_check_power_status(codec, nid);
  12965. }
  12966. #endif /* CONFIG_SND_HDA_POWER_SAVE */
  12967. static int alc275_setup_dual_adc(struct hda_codec *codec)
  12968. {
  12969. struct alc_spec *spec = codec->spec;
  12970. if (codec->vendor_id != 0x10ec0275 || !spec->auto_mic)
  12971. return 0;
  12972. if ((spec->ext_mic.pin >= 0x18 && spec->int_mic.pin <= 0x13) ||
  12973. (spec->ext_mic.pin <= 0x12 && spec->int_mic.pin >= 0x18)) {
  12974. if (spec->ext_mic.pin <= 0x12) {
  12975. spec->private_adc_nids[0] = 0x08;
  12976. spec->private_adc_nids[1] = 0x11;
  12977. spec->private_capsrc_nids[0] = 0x23;
  12978. spec->private_capsrc_nids[1] = 0x22;
  12979. } else {
  12980. spec->private_adc_nids[0] = 0x11;
  12981. spec->private_adc_nids[1] = 0x08;
  12982. spec->private_capsrc_nids[0] = 0x22;
  12983. spec->private_capsrc_nids[1] = 0x23;
  12984. }
  12985. spec->adc_nids = spec->private_adc_nids;
  12986. spec->capsrc_nids = spec->private_capsrc_nids;
  12987. spec->num_adc_nids = 2;
  12988. spec->dual_adc_switch = 1;
  12989. snd_printdd("realtek: enabling dual ADC switchg (%02x:%02x)\n",
  12990. spec->adc_nids[0], spec->adc_nids[1]);
  12991. return 1;
  12992. }
  12993. return 0;
  12994. }
  12995. /*
  12996. * BIOS auto configuration
  12997. */
  12998. static int alc269_parse_auto_config(struct hda_codec *codec)
  12999. {
  13000. struct alc_spec *spec = codec->spec;
  13001. int err;
  13002. static hda_nid_t alc269_ignore[] = { 0x1d, 0 };
  13003. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  13004. alc269_ignore);
  13005. if (err < 0)
  13006. return err;
  13007. err = alc269_auto_create_multi_out_ctls(spec, &spec->autocfg);
  13008. if (err < 0)
  13009. return err;
  13010. err = alc269_auto_create_input_ctls(codec, &spec->autocfg);
  13011. if (err < 0)
  13012. return err;
  13013. spec->multiout.max_channels = spec->multiout.num_dacs * 2;
  13014. alc_auto_parse_digital(codec);
  13015. if (spec->kctls.list)
  13016. add_mixer(spec, spec->kctls.list);
  13017. if ((alc_read_coef_idx(codec, 0) & 0x00f0) == 0x0010) {
  13018. add_verb(spec, alc269vb_init_verbs);
  13019. alc_ssid_check(codec, 0, 0x1b, 0x14, 0x21);
  13020. } else {
  13021. add_verb(spec, alc269_init_verbs);
  13022. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
  13023. }
  13024. spec->num_mux_defs = 1;
  13025. spec->input_mux = &spec->private_imux[0];
  13026. if (!alc275_setup_dual_adc(codec))
  13027. fillup_priv_adc_nids(codec, alc269_adc_candidates,
  13028. sizeof(alc269_adc_candidates));
  13029. /* set default input source */
  13030. if (!spec->dual_adc_switch)
  13031. select_or_unmute_capsrc(codec, spec->capsrc_nids[0],
  13032. spec->input_mux->items[0].index);
  13033. err = alc_auto_add_mic_boost(codec);
  13034. if (err < 0)
  13035. return err;
  13036. if (!spec->cap_mixer && !spec->no_analog)
  13037. set_capture_mixer(codec);
  13038. return 1;
  13039. }
  13040. #define alc269_auto_init_multi_out alc268_auto_init_multi_out
  13041. #define alc269_auto_init_hp_out alc268_auto_init_hp_out
  13042. #define alc269_auto_init_analog_input alc882_auto_init_analog_input
  13043. /* init callback for auto-configuration model -- overriding the default init */
  13044. static void alc269_auto_init(struct hda_codec *codec)
  13045. {
  13046. struct alc_spec *spec = codec->spec;
  13047. alc269_auto_init_multi_out(codec);
  13048. alc269_auto_init_hp_out(codec);
  13049. alc269_auto_init_analog_input(codec);
  13050. alc_auto_init_digital(codec);
  13051. if (spec->unsol_event)
  13052. alc_inithook(codec);
  13053. }
  13054. enum {
  13055. ALC269_FIXUP_SONY_VAIO,
  13056. ALC269_FIXUP_DELL_M101Z,
  13057. };
  13058. static const struct hda_verb alc269_sony_vaio_fixup_verbs[] = {
  13059. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREFGRD},
  13060. {}
  13061. };
  13062. static const struct alc_fixup alc269_fixups[] = {
  13063. [ALC269_FIXUP_SONY_VAIO] = {
  13064. .verbs = alc269_sony_vaio_fixup_verbs
  13065. },
  13066. [ALC269_FIXUP_DELL_M101Z] = {
  13067. .verbs = (const struct hda_verb[]) {
  13068. /* Enables internal speaker */
  13069. {0x20, AC_VERB_SET_COEF_INDEX, 13},
  13070. {0x20, AC_VERB_SET_PROC_COEF, 0x4040},
  13071. {}
  13072. }
  13073. },
  13074. };
  13075. static struct snd_pci_quirk alc269_fixup_tbl[] = {
  13076. SND_PCI_QUIRK(0x104d, 0x9071, "Sony VAIO", ALC269_FIXUP_SONY_VAIO),
  13077. SND_PCI_QUIRK(0x104d, 0x9077, "Sony VAIO", ALC269_FIXUP_SONY_VAIO),
  13078. SND_PCI_QUIRK(0x1028, 0x0470, "Dell M101z", ALC269_FIXUP_DELL_M101Z),
  13079. {}
  13080. };
  13081. /*
  13082. * configuration and preset
  13083. */
  13084. static const char *alc269_models[ALC269_MODEL_LAST] = {
  13085. [ALC269_BASIC] = "basic",
  13086. [ALC269_QUANTA_FL1] = "quanta",
  13087. [ALC269_AMIC] = "laptop-amic",
  13088. [ALC269_DMIC] = "laptop-dmic",
  13089. [ALC269_FUJITSU] = "fujitsu",
  13090. [ALC269_LIFEBOOK] = "lifebook",
  13091. [ALC269_AUTO] = "auto",
  13092. };
  13093. static struct snd_pci_quirk alc269_cfg_tbl[] = {
  13094. SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_QUANTA_FL1),
  13095. SND_PCI_QUIRK(0x1025, 0x047c, "ACER ZGA", ALC271_ACER),
  13096. SND_PCI_QUIRK(0x1043, 0x8330, "ASUS Eeepc P703 P900A",
  13097. ALC269_AMIC),
  13098. SND_PCI_QUIRK(0x1043, 0x1013, "ASUS N61Da", ALC269VB_AMIC),
  13099. SND_PCI_QUIRK(0x1043, 0x1113, "ASUS N63Jn", ALC269VB_AMIC),
  13100. SND_PCI_QUIRK(0x1043, 0x1143, "ASUS B53f", ALC269VB_AMIC),
  13101. SND_PCI_QUIRK(0x1043, 0x1133, "ASUS UJ20ft", ALC269_AMIC),
  13102. SND_PCI_QUIRK(0x1043, 0x1183, "ASUS K72DR", ALC269VB_AMIC),
  13103. SND_PCI_QUIRK(0x1043, 0x11b3, "ASUS K52DR", ALC269VB_AMIC),
  13104. SND_PCI_QUIRK(0x1043, 0x11e3, "ASUS U33Jc", ALC269VB_AMIC),
  13105. SND_PCI_QUIRK(0x1043, 0x1273, "ASUS UL80Jt", ALC269VB_AMIC),
  13106. SND_PCI_QUIRK(0x1043, 0x1283, "ASUS U53Jc", ALC269_AMIC),
  13107. SND_PCI_QUIRK(0x1043, 0x12b3, "ASUS N82Jv", ALC269_AMIC),
  13108. SND_PCI_QUIRK(0x1043, 0x12d3, "ASUS N61Jv", ALC269_AMIC),
  13109. SND_PCI_QUIRK(0x1043, 0x13a3, "ASUS UL30Vt", ALC269_AMIC),
  13110. SND_PCI_QUIRK(0x1043, 0x1373, "ASUS G73JX", ALC269_AMIC),
  13111. SND_PCI_QUIRK(0x1043, 0x1383, "ASUS UJ30Jc", ALC269_AMIC),
  13112. SND_PCI_QUIRK(0x1043, 0x13d3, "ASUS N61JA", ALC269_AMIC),
  13113. SND_PCI_QUIRK(0x1043, 0x1413, "ASUS UL50", ALC269_AMIC),
  13114. SND_PCI_QUIRK(0x1043, 0x1443, "ASUS UL30", ALC269_AMIC),
  13115. SND_PCI_QUIRK(0x1043, 0x1453, "ASUS M60Jv", ALC269_AMIC),
  13116. SND_PCI_QUIRK(0x1043, 0x1483, "ASUS UL80", ALC269_AMIC),
  13117. SND_PCI_QUIRK(0x1043, 0x14f3, "ASUS F83Vf", ALC269_AMIC),
  13118. SND_PCI_QUIRK(0x1043, 0x14e3, "ASUS UL20", ALC269_AMIC),
  13119. SND_PCI_QUIRK(0x1043, 0x1513, "ASUS UX30", ALC269_AMIC),
  13120. SND_PCI_QUIRK(0x1043, 0x1593, "ASUS N51Vn", ALC269_AMIC),
  13121. SND_PCI_QUIRK(0x1043, 0x15a3, "ASUS N60Jv", ALC269_AMIC),
  13122. SND_PCI_QUIRK(0x1043, 0x15b3, "ASUS N60Dp", ALC269_AMIC),
  13123. SND_PCI_QUIRK(0x1043, 0x15c3, "ASUS N70De", ALC269_AMIC),
  13124. SND_PCI_QUIRK(0x1043, 0x15e3, "ASUS F83T", ALC269_AMIC),
  13125. SND_PCI_QUIRK(0x1043, 0x1643, "ASUS M60J", ALC269_AMIC),
  13126. SND_PCI_QUIRK(0x1043, 0x1653, "ASUS U50", ALC269_AMIC),
  13127. SND_PCI_QUIRK(0x1043, 0x1693, "ASUS F50N", ALC269_AMIC),
  13128. SND_PCI_QUIRK(0x1043, 0x16a3, "ASUS F5Q", ALC269_AMIC),
  13129. SND_PCI_QUIRK(0x1043, 0x16e3, "ASUS UX50", ALC269_DMIC),
  13130. SND_PCI_QUIRK(0x1043, 0x1723, "ASUS P80", ALC269_AMIC),
  13131. SND_PCI_QUIRK(0x1043, 0x1743, "ASUS U80", ALC269_AMIC),
  13132. SND_PCI_QUIRK(0x1043, 0x1773, "ASUS U20A", ALC269_AMIC),
  13133. SND_PCI_QUIRK(0x1043, 0x1883, "ASUS F81Se", ALC269_AMIC),
  13134. SND_PCI_QUIRK(0x1043, 0x831a, "ASUS Eeepc P901",
  13135. ALC269_DMIC),
  13136. SND_PCI_QUIRK(0x1043, 0x834a, "ASUS Eeepc S101",
  13137. ALC269_DMIC),
  13138. SND_PCI_QUIRK(0x1043, 0x8398, "ASUS P1005HA", ALC269_DMIC),
  13139. SND_PCI_QUIRK(0x1043, 0x83ce, "ASUS P1005HA", ALC269_DMIC),
  13140. SND_PCI_QUIRK(0x104d, 0x9071, "Sony VAIO", ALC269_AUTO),
  13141. SND_PCI_QUIRK(0x10cf, 0x1475, "Lifebook ICH9M-based", ALC269_LIFEBOOK),
  13142. SND_PCI_QUIRK(0x152d, 0x1778, "Quanta ON1", ALC269_DMIC),
  13143. SND_PCI_QUIRK(0x1734, 0x115d, "FSC Amilo", ALC269_FUJITSU),
  13144. SND_PCI_QUIRK(0x17aa, 0x3be9, "Quanta Wistron", ALC269_AMIC),
  13145. SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_AMIC),
  13146. SND_PCI_QUIRK(0x17ff, 0x059a, "Quanta EL3", ALC269_DMIC),
  13147. SND_PCI_QUIRK(0x17ff, 0x059b, "Quanta JR1", ALC269_DMIC),
  13148. {}
  13149. };
  13150. static struct alc_config_preset alc269_presets[] = {
  13151. [ALC269_BASIC] = {
  13152. .mixers = { alc269_base_mixer },
  13153. .init_verbs = { alc269_init_verbs },
  13154. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13155. .dac_nids = alc269_dac_nids,
  13156. .hp_nid = 0x03,
  13157. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13158. .channel_mode = alc269_modes,
  13159. .input_mux = &alc269_capture_source,
  13160. },
  13161. [ALC269_QUANTA_FL1] = {
  13162. .mixers = { alc269_quanta_fl1_mixer },
  13163. .init_verbs = { alc269_init_verbs, alc269_quanta_fl1_verbs },
  13164. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13165. .dac_nids = alc269_dac_nids,
  13166. .hp_nid = 0x03,
  13167. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13168. .channel_mode = alc269_modes,
  13169. .input_mux = &alc269_capture_source,
  13170. .unsol_event = alc269_quanta_fl1_unsol_event,
  13171. .setup = alc269_quanta_fl1_setup,
  13172. .init_hook = alc269_quanta_fl1_init_hook,
  13173. },
  13174. [ALC269_AMIC] = {
  13175. .mixers = { alc269_laptop_mixer },
  13176. .cap_mixer = alc269_laptop_analog_capture_mixer,
  13177. .init_verbs = { alc269_init_verbs,
  13178. alc269_laptop_amic_init_verbs },
  13179. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13180. .dac_nids = alc269_dac_nids,
  13181. .hp_nid = 0x03,
  13182. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13183. .channel_mode = alc269_modes,
  13184. .unsol_event = alc269_laptop_unsol_event,
  13185. .setup = alc269_laptop_amic_setup,
  13186. .init_hook = alc269_laptop_inithook,
  13187. },
  13188. [ALC269_DMIC] = {
  13189. .mixers = { alc269_laptop_mixer },
  13190. .cap_mixer = alc269_laptop_digital_capture_mixer,
  13191. .init_verbs = { alc269_init_verbs,
  13192. alc269_laptop_dmic_init_verbs },
  13193. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13194. .dac_nids = alc269_dac_nids,
  13195. .hp_nid = 0x03,
  13196. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13197. .channel_mode = alc269_modes,
  13198. .unsol_event = alc269_laptop_unsol_event,
  13199. .setup = alc269_laptop_dmic_setup,
  13200. .init_hook = alc269_laptop_inithook,
  13201. },
  13202. [ALC269VB_AMIC] = {
  13203. .mixers = { alc269vb_laptop_mixer },
  13204. .cap_mixer = alc269vb_laptop_analog_capture_mixer,
  13205. .init_verbs = { alc269vb_init_verbs,
  13206. alc269vb_laptop_amic_init_verbs },
  13207. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13208. .dac_nids = alc269_dac_nids,
  13209. .hp_nid = 0x03,
  13210. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13211. .channel_mode = alc269_modes,
  13212. .unsol_event = alc269_laptop_unsol_event,
  13213. .setup = alc269vb_laptop_amic_setup,
  13214. .init_hook = alc269_laptop_inithook,
  13215. },
  13216. [ALC269VB_DMIC] = {
  13217. .mixers = { alc269vb_laptop_mixer },
  13218. .cap_mixer = alc269vb_laptop_digital_capture_mixer,
  13219. .init_verbs = { alc269vb_init_verbs,
  13220. alc269vb_laptop_dmic_init_verbs },
  13221. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13222. .dac_nids = alc269_dac_nids,
  13223. .hp_nid = 0x03,
  13224. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13225. .channel_mode = alc269_modes,
  13226. .unsol_event = alc269_laptop_unsol_event,
  13227. .setup = alc269vb_laptop_dmic_setup,
  13228. .init_hook = alc269_laptop_inithook,
  13229. },
  13230. [ALC269_FUJITSU] = {
  13231. .mixers = { alc269_fujitsu_mixer },
  13232. .cap_mixer = alc269_laptop_digital_capture_mixer,
  13233. .init_verbs = { alc269_init_verbs,
  13234. alc269_laptop_dmic_init_verbs },
  13235. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13236. .dac_nids = alc269_dac_nids,
  13237. .hp_nid = 0x03,
  13238. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13239. .channel_mode = alc269_modes,
  13240. .unsol_event = alc269_laptop_unsol_event,
  13241. .setup = alc269_laptop_dmic_setup,
  13242. .init_hook = alc269_laptop_inithook,
  13243. },
  13244. [ALC269_LIFEBOOK] = {
  13245. .mixers = { alc269_lifebook_mixer },
  13246. .init_verbs = { alc269_init_verbs, alc269_lifebook_verbs },
  13247. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13248. .dac_nids = alc269_dac_nids,
  13249. .hp_nid = 0x03,
  13250. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13251. .channel_mode = alc269_modes,
  13252. .input_mux = &alc269_capture_source,
  13253. .unsol_event = alc269_lifebook_unsol_event,
  13254. .init_hook = alc269_lifebook_init_hook,
  13255. },
  13256. [ALC271_ACER] = {
  13257. .mixers = { alc269_asus_mixer },
  13258. .cap_mixer = alc269vb_laptop_digital_capture_mixer,
  13259. .init_verbs = { alc269_init_verbs, alc271_acer_dmic_verbs },
  13260. .num_dacs = ARRAY_SIZE(alc269_dac_nids),
  13261. .dac_nids = alc269_dac_nids,
  13262. .adc_nids = alc262_dmic_adc_nids,
  13263. .num_adc_nids = ARRAY_SIZE(alc262_dmic_adc_nids),
  13264. .capsrc_nids = alc262_dmic_capsrc_nids,
  13265. .num_channel_mode = ARRAY_SIZE(alc269_modes),
  13266. .channel_mode = alc269_modes,
  13267. .input_mux = &alc269_capture_source,
  13268. .dig_out_nid = ALC880_DIGOUT_NID,
  13269. .unsol_event = alc_sku_unsol_event,
  13270. .setup = alc269vb_laptop_dmic_setup,
  13271. .init_hook = alc_inithook,
  13272. },
  13273. };
  13274. static int patch_alc269(struct hda_codec *codec)
  13275. {
  13276. struct alc_spec *spec;
  13277. int board_config;
  13278. int err;
  13279. int is_alc269vb = 0;
  13280. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  13281. if (spec == NULL)
  13282. return -ENOMEM;
  13283. codec->spec = spec;
  13284. alc_auto_parse_customize_define(codec);
  13285. if ((alc_read_coef_idx(codec, 0) & 0x00f0) == 0x0010){
  13286. if (codec->bus->pci->subsystem_vendor == 0x1025 &&
  13287. spec->cdefine.platform_type == 1)
  13288. alc_codec_rename(codec, "ALC271X");
  13289. else
  13290. alc_codec_rename(codec, "ALC259");
  13291. is_alc269vb = 1;
  13292. } else
  13293. alc_fix_pll_init(codec, 0x20, 0x04, 15);
  13294. board_config = snd_hda_check_board_config(codec, ALC269_MODEL_LAST,
  13295. alc269_models,
  13296. alc269_cfg_tbl);
  13297. if (board_config < 0) {
  13298. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  13299. codec->chip_name);
  13300. board_config = ALC269_AUTO;
  13301. }
  13302. if (board_config == ALC269_AUTO)
  13303. alc_pick_fixup(codec, alc269_fixup_tbl, alc269_fixups, 1);
  13304. if (board_config == ALC269_AUTO) {
  13305. /* automatic parse from the BIOS config */
  13306. err = alc269_parse_auto_config(codec);
  13307. if (err < 0) {
  13308. alc_free(codec);
  13309. return err;
  13310. } else if (!err) {
  13311. printk(KERN_INFO
  13312. "hda_codec: Cannot set up configuration "
  13313. "from BIOS. Using base mode...\n");
  13314. board_config = ALC269_BASIC;
  13315. }
  13316. }
  13317. if (has_cdefine_beep(codec)) {
  13318. err = snd_hda_attach_beep_device(codec, 0x1);
  13319. if (err < 0) {
  13320. alc_free(codec);
  13321. return err;
  13322. }
  13323. }
  13324. if (board_config != ALC269_AUTO)
  13325. setup_preset(codec, &alc269_presets[board_config]);
  13326. if (board_config == ALC269_QUANTA_FL1) {
  13327. /* Due to a hardware problem on Lenovo Ideadpad, we need to
  13328. * fix the sample rate of analog I/O to 44.1kHz
  13329. */
  13330. spec->stream_analog_playback = &alc269_44k_pcm_analog_playback;
  13331. spec->stream_analog_capture = &alc269_44k_pcm_analog_capture;
  13332. } else if (spec->dual_adc_switch) {
  13333. spec->stream_analog_playback = &alc269_pcm_analog_playback;
  13334. /* switch ADC dynamically */
  13335. spec->stream_analog_capture = &dualmic_pcm_analog_capture;
  13336. } else {
  13337. spec->stream_analog_playback = &alc269_pcm_analog_playback;
  13338. spec->stream_analog_capture = &alc269_pcm_analog_capture;
  13339. }
  13340. spec->stream_digital_playback = &alc269_pcm_digital_playback;
  13341. spec->stream_digital_capture = &alc269_pcm_digital_capture;
  13342. if (!spec->adc_nids) { /* wasn't filled automatically? use default */
  13343. if (!is_alc269vb) {
  13344. spec->adc_nids = alc269_adc_nids;
  13345. spec->num_adc_nids = ARRAY_SIZE(alc269_adc_nids);
  13346. spec->capsrc_nids = alc269_capsrc_nids;
  13347. } else {
  13348. spec->adc_nids = alc269vb_adc_nids;
  13349. spec->num_adc_nids = ARRAY_SIZE(alc269vb_adc_nids);
  13350. spec->capsrc_nids = alc269vb_capsrc_nids;
  13351. }
  13352. }
  13353. if (!spec->cap_mixer)
  13354. set_capture_mixer(codec);
  13355. if (has_cdefine_beep(codec))
  13356. set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT);
  13357. if (board_config == ALC269_AUTO)
  13358. alc_pick_fixup(codec, alc269_fixup_tbl, alc269_fixups, 0);
  13359. spec->vmaster_nid = 0x02;
  13360. codec->patch_ops = alc_patch_ops;
  13361. if (board_config == ALC269_AUTO)
  13362. spec->init_hook = alc269_auto_init;
  13363. #ifdef CONFIG_SND_HDA_POWER_SAVE
  13364. if (!spec->loopback.amplist)
  13365. spec->loopback.amplist = alc269_loopbacks;
  13366. if (alc269_mic2_for_mute_led(codec))
  13367. codec->patch_ops.check_power_status = alc269_mic2_mute_check_ps;
  13368. #endif
  13369. return 0;
  13370. }
  13371. /*
  13372. * ALC861 channel source setting (2/6 channel selection for 3-stack)
  13373. */
  13374. /*
  13375. * set the path ways for 2 channel output
  13376. * need to set the codec line out and mic 1 pin widgets to inputs
  13377. */
  13378. static struct hda_verb alc861_threestack_ch2_init[] = {
  13379. /* set pin widget 1Ah (line in) for input */
  13380. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13381. /* set pin widget 18h (mic1/2) for input, for mic also enable
  13382. * the vref
  13383. */
  13384. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13385. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c },
  13386. #if 0
  13387. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8)) }, /*mic*/
  13388. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x02 << 8)) }, /*line-in*/
  13389. #endif
  13390. { } /* end */
  13391. };
  13392. /*
  13393. * 6ch mode
  13394. * need to set the codec line out and mic 1 pin widgets to outputs
  13395. */
  13396. static struct hda_verb alc861_threestack_ch6_init[] = {
  13397. /* set pin widget 1Ah (line in) for output (Back Surround)*/
  13398. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13399. /* set pin widget 18h (mic1) for output (CLFE)*/
  13400. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13401. { 0x0c, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13402. { 0x0d, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13403. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080 },
  13404. #if 0
  13405. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x01 << 8)) }, /*mic*/
  13406. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8)) }, /*line in*/
  13407. #endif
  13408. { } /* end */
  13409. };
  13410. static struct hda_channel_mode alc861_threestack_modes[2] = {
  13411. { 2, alc861_threestack_ch2_init },
  13412. { 6, alc861_threestack_ch6_init },
  13413. };
  13414. /* Set mic1 as input and unmute the mixer */
  13415. static struct hda_verb alc861_uniwill_m31_ch2_init[] = {
  13416. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13417. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x01 << 8)) }, /*mic*/
  13418. { } /* end */
  13419. };
  13420. /* Set mic1 as output and mute mixer */
  13421. static struct hda_verb alc861_uniwill_m31_ch4_init[] = {
  13422. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13423. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8)) }, /*mic*/
  13424. { } /* end */
  13425. };
  13426. static struct hda_channel_mode alc861_uniwill_m31_modes[2] = {
  13427. { 2, alc861_uniwill_m31_ch2_init },
  13428. { 4, alc861_uniwill_m31_ch4_init },
  13429. };
  13430. /* Set mic1 and line-in as input and unmute the mixer */
  13431. static struct hda_verb alc861_asus_ch2_init[] = {
  13432. /* set pin widget 1Ah (line in) for input */
  13433. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13434. /* set pin widget 18h (mic1/2) for input, for mic also enable
  13435. * the vref
  13436. */
  13437. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13438. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c },
  13439. #if 0
  13440. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x01 << 8)) }, /*mic*/
  13441. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x02 << 8)) }, /*line-in*/
  13442. #endif
  13443. { } /* end */
  13444. };
  13445. /* Set mic1 nad line-in as output and mute mixer */
  13446. static struct hda_verb alc861_asus_ch6_init[] = {
  13447. /* set pin widget 1Ah (line in) for output (Back Surround)*/
  13448. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13449. /* { 0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE }, */
  13450. /* set pin widget 18h (mic1) for output (CLFE)*/
  13451. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13452. /* { 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE }, */
  13453. { 0x0c, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13454. { 0x0d, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13455. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080 },
  13456. #if 0
  13457. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x01 << 8)) }, /*mic*/
  13458. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8)) }, /*line in*/
  13459. #endif
  13460. { } /* end */
  13461. };
  13462. static struct hda_channel_mode alc861_asus_modes[2] = {
  13463. { 2, alc861_asus_ch2_init },
  13464. { 6, alc861_asus_ch6_init },
  13465. };
  13466. /* patch-ALC861 */
  13467. static struct snd_kcontrol_new alc861_base_mixer[] = {
  13468. /* output mixer control */
  13469. HDA_CODEC_MUTE("Front Playback Switch", 0x03, 0x0, HDA_OUTPUT),
  13470. HDA_CODEC_MUTE("Surround Playback Switch", 0x06, 0x0, HDA_OUTPUT),
  13471. HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x05, 1, 0x0, HDA_OUTPUT),
  13472. HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x05, 2, 0x0, HDA_OUTPUT),
  13473. HDA_CODEC_MUTE("Side Playback Switch", 0x04, 0x0, HDA_OUTPUT),
  13474. /*Input mixer control */
  13475. /* HDA_CODEC_VOLUME("Input Playback Volume", 0x15, 0x0, HDA_OUTPUT),
  13476. HDA_CODEC_MUTE("Input Playback Switch", 0x15, 0x0, HDA_OUTPUT), */
  13477. HDA_CODEC_VOLUME("CD Playback Volume", 0x15, 0x0, HDA_INPUT),
  13478. HDA_CODEC_MUTE("CD Playback Switch", 0x15, 0x0, HDA_INPUT),
  13479. HDA_CODEC_VOLUME("Line Playback Volume", 0x15, 0x02, HDA_INPUT),
  13480. HDA_CODEC_MUTE("Line Playback Switch", 0x15, 0x02, HDA_INPUT),
  13481. HDA_CODEC_VOLUME("Mic Playback Volume", 0x15, 0x01, HDA_INPUT),
  13482. HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT),
  13483. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT),
  13484. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT),
  13485. { } /* end */
  13486. };
  13487. static struct snd_kcontrol_new alc861_3ST_mixer[] = {
  13488. /* output mixer control */
  13489. HDA_CODEC_MUTE("Front Playback Switch", 0x03, 0x0, HDA_OUTPUT),
  13490. HDA_CODEC_MUTE("Surround Playback Switch", 0x06, 0x0, HDA_OUTPUT),
  13491. HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x05, 1, 0x0, HDA_OUTPUT),
  13492. HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x05, 2, 0x0, HDA_OUTPUT),
  13493. /*HDA_CODEC_MUTE("Side Playback Switch", 0x04, 0x0, HDA_OUTPUT), */
  13494. /* Input mixer control */
  13495. /* HDA_CODEC_VOLUME("Input Playback Volume", 0x15, 0x0, HDA_OUTPUT),
  13496. HDA_CODEC_MUTE("Input Playback Switch", 0x15, 0x0, HDA_OUTPUT), */
  13497. HDA_CODEC_VOLUME("CD Playback Volume", 0x15, 0x0, HDA_INPUT),
  13498. HDA_CODEC_MUTE("CD Playback Switch", 0x15, 0x0, HDA_INPUT),
  13499. HDA_CODEC_VOLUME("Line Playback Volume", 0x15, 0x02, HDA_INPUT),
  13500. HDA_CODEC_MUTE("Line Playback Switch", 0x15, 0x02, HDA_INPUT),
  13501. HDA_CODEC_VOLUME("Mic Playback Volume", 0x15, 0x01, HDA_INPUT),
  13502. HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT),
  13503. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT),
  13504. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT),
  13505. {
  13506. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  13507. .name = "Channel Mode",
  13508. .info = alc_ch_mode_info,
  13509. .get = alc_ch_mode_get,
  13510. .put = alc_ch_mode_put,
  13511. .private_value = ARRAY_SIZE(alc861_threestack_modes),
  13512. },
  13513. { } /* end */
  13514. };
  13515. static struct snd_kcontrol_new alc861_toshiba_mixer[] = {
  13516. /* output mixer control */
  13517. HDA_CODEC_MUTE("Master Playback Switch", 0x03, 0x0, HDA_OUTPUT),
  13518. HDA_CODEC_VOLUME("Mic Playback Volume", 0x15, 0x01, HDA_INPUT),
  13519. HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT),
  13520. { } /* end */
  13521. };
  13522. static struct snd_kcontrol_new alc861_uniwill_m31_mixer[] = {
  13523. /* output mixer control */
  13524. HDA_CODEC_MUTE("Front Playback Switch", 0x03, 0x0, HDA_OUTPUT),
  13525. HDA_CODEC_MUTE("Surround Playback Switch", 0x06, 0x0, HDA_OUTPUT),
  13526. HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x05, 1, 0x0, HDA_OUTPUT),
  13527. HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x05, 2, 0x0, HDA_OUTPUT),
  13528. /*HDA_CODEC_MUTE("Side Playback Switch", 0x04, 0x0, HDA_OUTPUT), */
  13529. /* Input mixer control */
  13530. /* HDA_CODEC_VOLUME("Input Playback Volume", 0x15, 0x0, HDA_OUTPUT),
  13531. HDA_CODEC_MUTE("Input Playback Switch", 0x15, 0x0, HDA_OUTPUT), */
  13532. HDA_CODEC_VOLUME("CD Playback Volume", 0x15, 0x0, HDA_INPUT),
  13533. HDA_CODEC_MUTE("CD Playback Switch", 0x15, 0x0, HDA_INPUT),
  13534. HDA_CODEC_VOLUME("Line Playback Volume", 0x15, 0x02, HDA_INPUT),
  13535. HDA_CODEC_MUTE("Line Playback Switch", 0x15, 0x02, HDA_INPUT),
  13536. HDA_CODEC_VOLUME("Mic Playback Volume", 0x15, 0x01, HDA_INPUT),
  13537. HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT),
  13538. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT),
  13539. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_INPUT),
  13540. {
  13541. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  13542. .name = "Channel Mode",
  13543. .info = alc_ch_mode_info,
  13544. .get = alc_ch_mode_get,
  13545. .put = alc_ch_mode_put,
  13546. .private_value = ARRAY_SIZE(alc861_uniwill_m31_modes),
  13547. },
  13548. { } /* end */
  13549. };
  13550. static struct snd_kcontrol_new alc861_asus_mixer[] = {
  13551. /* output mixer control */
  13552. HDA_CODEC_MUTE("Front Playback Switch", 0x03, 0x0, HDA_OUTPUT),
  13553. HDA_CODEC_MUTE("Surround Playback Switch", 0x06, 0x0, HDA_OUTPUT),
  13554. HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x05, 1, 0x0, HDA_OUTPUT),
  13555. HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x05, 2, 0x0, HDA_OUTPUT),
  13556. HDA_CODEC_MUTE("Side Playback Switch", 0x04, 0x0, HDA_OUTPUT),
  13557. /* Input mixer control */
  13558. HDA_CODEC_VOLUME("Input Playback Volume", 0x15, 0x0, HDA_OUTPUT),
  13559. HDA_CODEC_MUTE("Input Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  13560. HDA_CODEC_VOLUME("CD Playback Volume", 0x15, 0x0, HDA_INPUT),
  13561. HDA_CODEC_MUTE("CD Playback Switch", 0x15, 0x0, HDA_INPUT),
  13562. HDA_CODEC_VOLUME("Line Playback Volume", 0x15, 0x02, HDA_INPUT),
  13563. HDA_CODEC_MUTE("Line Playback Switch", 0x15, 0x02, HDA_INPUT),
  13564. HDA_CODEC_VOLUME("Mic Playback Volume", 0x15, 0x01, HDA_INPUT),
  13565. HDA_CODEC_MUTE("Mic Playback Switch", 0x15, 0x01, HDA_INPUT),
  13566. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x10, 0x01, HDA_OUTPUT),
  13567. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1a, 0x03, HDA_OUTPUT),
  13568. {
  13569. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  13570. .name = "Channel Mode",
  13571. .info = alc_ch_mode_info,
  13572. .get = alc_ch_mode_get,
  13573. .put = alc_ch_mode_put,
  13574. .private_value = ARRAY_SIZE(alc861_asus_modes),
  13575. },
  13576. { }
  13577. };
  13578. /* additional mixer */
  13579. static struct snd_kcontrol_new alc861_asus_laptop_mixer[] = {
  13580. HDA_CODEC_VOLUME("CD Playback Volume", 0x15, 0x0, HDA_INPUT),
  13581. HDA_CODEC_MUTE("CD Playback Switch", 0x15, 0x0, HDA_INPUT),
  13582. { }
  13583. };
  13584. /*
  13585. * generic initialization of ADC, input mixers and output mixers
  13586. */
  13587. static struct hda_verb alc861_base_init_verbs[] = {
  13588. /*
  13589. * Unmute ADC0 and set the default input to mic-in
  13590. */
  13591. /* port-A for surround (rear panel) */
  13592. { 0x0e, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13593. { 0x0e, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13594. /* port-B for mic-in (rear panel) with vref */
  13595. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13596. /* port-C for line-in (rear panel) */
  13597. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13598. /* port-D for Front */
  13599. { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13600. { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13601. /* port-E for HP out (front panel) */
  13602. { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0 },
  13603. /* route front PCM to HP */
  13604. { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13605. /* port-F for mic-in (front panel) with vref */
  13606. { 0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13607. /* port-G for CLFE (rear panel) */
  13608. { 0x1f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13609. { 0x1f, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13610. /* port-H for side (rear panel) */
  13611. { 0x20, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13612. { 0x20, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13613. /* CD-in */
  13614. { 0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13615. /* route front mic to ADC1*/
  13616. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  13617. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13618. /* Unmute DAC0~3 & spdif out*/
  13619. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13620. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13621. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13622. {0x06, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13623. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13624. /* Unmute Mixer 14 (mic) 1c (Line in)*/
  13625. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13626. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13627. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13628. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13629. /* Unmute Stereo Mixer 15 */
  13630. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13631. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13632. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13633. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */
  13634. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13635. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13636. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13637. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13638. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13639. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13640. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13641. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13642. /* hp used DAC 3 (Front) */
  13643. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)},
  13644. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13645. { }
  13646. };
  13647. static struct hda_verb alc861_threestack_init_verbs[] = {
  13648. /*
  13649. * Unmute ADC0 and set the default input to mic-in
  13650. */
  13651. /* port-A for surround (rear panel) */
  13652. { 0x0e, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  13653. /* port-B for mic-in (rear panel) with vref */
  13654. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13655. /* port-C for line-in (rear panel) */
  13656. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13657. /* port-D for Front */
  13658. { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13659. { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13660. /* port-E for HP out (front panel) */
  13661. { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0 },
  13662. /* route front PCM to HP */
  13663. { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13664. /* port-F for mic-in (front panel) with vref */
  13665. { 0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13666. /* port-G for CLFE (rear panel) */
  13667. { 0x1f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  13668. /* port-H for side (rear panel) */
  13669. { 0x20, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  13670. /* CD-in */
  13671. { 0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13672. /* route front mic to ADC1*/
  13673. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  13674. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13675. /* Unmute DAC0~3 & spdif out*/
  13676. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13677. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13678. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13679. {0x06, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13680. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13681. /* Unmute Mixer 14 (mic) 1c (Line in)*/
  13682. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13683. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13684. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13685. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13686. /* Unmute Stereo Mixer 15 */
  13687. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13688. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13689. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13690. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */
  13691. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13692. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13693. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13694. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13695. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13696. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13697. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13698. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13699. /* hp used DAC 3 (Front) */
  13700. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)},
  13701. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13702. { }
  13703. };
  13704. static struct hda_verb alc861_uniwill_m31_init_verbs[] = {
  13705. /*
  13706. * Unmute ADC0 and set the default input to mic-in
  13707. */
  13708. /* port-A for surround (rear panel) */
  13709. { 0x0e, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  13710. /* port-B for mic-in (rear panel) with vref */
  13711. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13712. /* port-C for line-in (rear panel) */
  13713. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13714. /* port-D for Front */
  13715. { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13716. { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13717. /* port-E for HP out (front panel) */
  13718. /* this has to be set to VREF80 */
  13719. { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13720. /* route front PCM to HP */
  13721. { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13722. /* port-F for mic-in (front panel) with vref */
  13723. { 0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13724. /* port-G for CLFE (rear panel) */
  13725. { 0x1f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  13726. /* port-H for side (rear panel) */
  13727. { 0x20, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  13728. /* CD-in */
  13729. { 0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13730. /* route front mic to ADC1*/
  13731. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  13732. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13733. /* Unmute DAC0~3 & spdif out*/
  13734. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13735. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13736. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13737. {0x06, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13738. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13739. /* Unmute Mixer 14 (mic) 1c (Line in)*/
  13740. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13741. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13742. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13743. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13744. /* Unmute Stereo Mixer 15 */
  13745. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13746. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13747. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13748. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */
  13749. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13750. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13751. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13752. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13753. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13754. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13755. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13756. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13757. /* hp used DAC 3 (Front) */
  13758. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)},
  13759. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13760. { }
  13761. };
  13762. static struct hda_verb alc861_asus_init_verbs[] = {
  13763. /*
  13764. * Unmute ADC0 and set the default input to mic-in
  13765. */
  13766. /* port-A for surround (rear panel)
  13767. * according to codec#0 this is the HP jack
  13768. */
  13769. { 0x0e, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0 }, /* was 0x00 */
  13770. /* route front PCM to HP */
  13771. { 0x0e, AC_VERB_SET_CONNECT_SEL, 0x01 },
  13772. /* port-B for mic-in (rear panel) with vref */
  13773. { 0x0d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13774. /* port-C for line-in (rear panel) */
  13775. { 0x0c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13776. /* port-D for Front */
  13777. { 0x0b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13778. { 0x0b, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13779. /* port-E for HP out (front panel) */
  13780. /* this has to be set to VREF80 */
  13781. { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13782. /* route front PCM to HP */
  13783. { 0x0f, AC_VERB_SET_CONNECT_SEL, 0x00 },
  13784. /* port-F for mic-in (front panel) with vref */
  13785. { 0x10, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },
  13786. /* port-G for CLFE (rear panel) */
  13787. { 0x1f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13788. /* port-H for side (rear panel) */
  13789. { 0x20, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },
  13790. /* CD-in */
  13791. { 0x11, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },
  13792. /* route front mic to ADC1*/
  13793. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  13794. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13795. /* Unmute DAC0~3 & spdif out*/
  13796. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13797. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13798. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13799. {0x06, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13800. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13801. /* Unmute Mixer 14 (mic) 1c (Line in)*/
  13802. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13803. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13804. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13805. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13806. /* Unmute Stereo Mixer 15 */
  13807. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13808. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13809. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13810. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c}, /* Output 0~12 step */
  13811. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13812. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13813. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13814. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13815. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13816. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13817. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13818. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13819. /* hp used DAC 3 (Front) */
  13820. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(3)},
  13821. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13822. { }
  13823. };
  13824. /* additional init verbs for ASUS laptops */
  13825. static struct hda_verb alc861_asus_laptop_init_verbs[] = {
  13826. { 0x0f, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x45 }, /* HP-out */
  13827. { 0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2) }, /* mute line-in */
  13828. { }
  13829. };
  13830. /*
  13831. * generic initialization of ADC, input mixers and output mixers
  13832. */
  13833. static struct hda_verb alc861_auto_init_verbs[] = {
  13834. /*
  13835. * Unmute ADC0 and set the default input to mic-in
  13836. */
  13837. /* {0x08, AC_VERB_SET_CONNECT_SEL, 0x00}, */
  13838. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13839. /* Unmute DAC0~3 & spdif out*/
  13840. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  13841. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  13842. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  13843. {0x06, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  13844. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  13845. /* Unmute Mixer 14 (mic) 1c (Line in)*/
  13846. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13847. {0x014, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13848. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13849. {0x01c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13850. /* Unmute Stereo Mixer 15 */
  13851. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  13852. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  13853. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  13854. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb00c},
  13855. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  13856. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  13857. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  13858. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  13859. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  13860. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  13861. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  13862. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  13863. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  13864. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  13865. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  13866. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  13867. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  13868. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  13869. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  13870. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  13871. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00}, /* set Mic 1 */
  13872. { }
  13873. };
  13874. static struct hda_verb alc861_toshiba_init_verbs[] = {
  13875. {0x0f, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  13876. { }
  13877. };
  13878. /* toggle speaker-output according to the hp-jack state */
  13879. static void alc861_toshiba_automute(struct hda_codec *codec)
  13880. {
  13881. unsigned int present = snd_hda_jack_detect(codec, 0x0f);
  13882. snd_hda_codec_amp_stereo(codec, 0x16, HDA_INPUT, 0,
  13883. HDA_AMP_MUTE, present ? HDA_AMP_MUTE : 0);
  13884. snd_hda_codec_amp_stereo(codec, 0x1a, HDA_INPUT, 3,
  13885. HDA_AMP_MUTE, present ? 0 : HDA_AMP_MUTE);
  13886. }
  13887. static void alc861_toshiba_unsol_event(struct hda_codec *codec,
  13888. unsigned int res)
  13889. {
  13890. if ((res >> 26) == ALC880_HP_EVENT)
  13891. alc861_toshiba_automute(codec);
  13892. }
  13893. /* pcm configuration: identical with ALC880 */
  13894. #define alc861_pcm_analog_playback alc880_pcm_analog_playback
  13895. #define alc861_pcm_analog_capture alc880_pcm_analog_capture
  13896. #define alc861_pcm_digital_playback alc880_pcm_digital_playback
  13897. #define alc861_pcm_digital_capture alc880_pcm_digital_capture
  13898. #define ALC861_DIGOUT_NID 0x07
  13899. static struct hda_channel_mode alc861_8ch_modes[1] = {
  13900. { 8, NULL }
  13901. };
  13902. static hda_nid_t alc861_dac_nids[4] = {
  13903. /* front, surround, clfe, side */
  13904. 0x03, 0x06, 0x05, 0x04
  13905. };
  13906. static hda_nid_t alc660_dac_nids[3] = {
  13907. /* front, clfe, surround */
  13908. 0x03, 0x05, 0x06
  13909. };
  13910. static hda_nid_t alc861_adc_nids[1] = {
  13911. /* ADC0-2 */
  13912. 0x08,
  13913. };
  13914. static struct hda_input_mux alc861_capture_source = {
  13915. .num_items = 5,
  13916. .items = {
  13917. { "Mic", 0x0 },
  13918. { "Front Mic", 0x3 },
  13919. { "Line", 0x1 },
  13920. { "CD", 0x4 },
  13921. { "Mixer", 0x5 },
  13922. },
  13923. };
  13924. static hda_nid_t alc861_look_for_dac(struct hda_codec *codec, hda_nid_t pin)
  13925. {
  13926. struct alc_spec *spec = codec->spec;
  13927. hda_nid_t mix, srcs[5];
  13928. int i, j, num;
  13929. if (snd_hda_get_connections(codec, pin, &mix, 1) != 1)
  13930. return 0;
  13931. num = snd_hda_get_connections(codec, mix, srcs, ARRAY_SIZE(srcs));
  13932. if (num < 0)
  13933. return 0;
  13934. for (i = 0; i < num; i++) {
  13935. unsigned int type;
  13936. type = get_wcaps_type(get_wcaps(codec, srcs[i]));
  13937. if (type != AC_WID_AUD_OUT)
  13938. continue;
  13939. for (j = 0; j < spec->multiout.num_dacs; j++)
  13940. if (spec->multiout.dac_nids[j] == srcs[i])
  13941. break;
  13942. if (j >= spec->multiout.num_dacs)
  13943. return srcs[i];
  13944. }
  13945. return 0;
  13946. }
  13947. /* fill in the dac_nids table from the parsed pin configuration */
  13948. static int alc861_auto_fill_dac_nids(struct hda_codec *codec,
  13949. const struct auto_pin_cfg *cfg)
  13950. {
  13951. struct alc_spec *spec = codec->spec;
  13952. int i;
  13953. hda_nid_t nid, dac;
  13954. spec->multiout.dac_nids = spec->private_dac_nids;
  13955. for (i = 0; i < cfg->line_outs; i++) {
  13956. nid = cfg->line_out_pins[i];
  13957. dac = alc861_look_for_dac(codec, nid);
  13958. if (!dac)
  13959. continue;
  13960. spec->multiout.dac_nids[spec->multiout.num_dacs++] = dac;
  13961. }
  13962. return 0;
  13963. }
  13964. static int alc861_create_out_sw(struct hda_codec *codec, const char *pfx,
  13965. hda_nid_t nid, unsigned int chs)
  13966. {
  13967. return add_pb_sw_ctrl(codec->spec, ALC_CTL_WIDGET_MUTE, pfx,
  13968. HDA_COMPOSE_AMP_VAL(nid, chs, 0, HDA_OUTPUT));
  13969. }
  13970. /* add playback controls from the parsed DAC table */
  13971. static int alc861_auto_create_multi_out_ctls(struct hda_codec *codec,
  13972. const struct auto_pin_cfg *cfg)
  13973. {
  13974. struct alc_spec *spec = codec->spec;
  13975. static const char *chname[4] = {
  13976. "Front", "Surround", NULL /*CLFE*/, "Side"
  13977. };
  13978. hda_nid_t nid;
  13979. int i, err;
  13980. if (cfg->line_outs == 1) {
  13981. const char *pfx = NULL;
  13982. if (!cfg->hp_outs)
  13983. pfx = "Master";
  13984. else if (cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  13985. pfx = "Speaker";
  13986. if (pfx) {
  13987. nid = spec->multiout.dac_nids[0];
  13988. return alc861_create_out_sw(codec, pfx, nid, 3);
  13989. }
  13990. }
  13991. for (i = 0; i < cfg->line_outs; i++) {
  13992. nid = spec->multiout.dac_nids[i];
  13993. if (!nid)
  13994. continue;
  13995. if (i == 2) {
  13996. /* Center/LFE */
  13997. err = alc861_create_out_sw(codec, "Center", nid, 1);
  13998. if (err < 0)
  13999. return err;
  14000. err = alc861_create_out_sw(codec, "LFE", nid, 2);
  14001. if (err < 0)
  14002. return err;
  14003. } else {
  14004. err = alc861_create_out_sw(codec, chname[i], nid, 3);
  14005. if (err < 0)
  14006. return err;
  14007. }
  14008. }
  14009. return 0;
  14010. }
  14011. static int alc861_auto_create_hp_ctls(struct hda_codec *codec, hda_nid_t pin)
  14012. {
  14013. struct alc_spec *spec = codec->spec;
  14014. int err;
  14015. hda_nid_t nid;
  14016. if (!pin)
  14017. return 0;
  14018. if ((pin >= 0x0b && pin <= 0x10) || pin == 0x1f || pin == 0x20) {
  14019. nid = alc861_look_for_dac(codec, pin);
  14020. if (nid) {
  14021. err = alc861_create_out_sw(codec, "Headphone", nid, 3);
  14022. if (err < 0)
  14023. return err;
  14024. spec->multiout.hp_nid = nid;
  14025. }
  14026. }
  14027. return 0;
  14028. }
  14029. /* create playback/capture controls for input pins */
  14030. static int alc861_auto_create_input_ctls(struct hda_codec *codec,
  14031. const struct auto_pin_cfg *cfg)
  14032. {
  14033. return alc_auto_create_input_ctls(codec, cfg, 0x15, 0x08, 0);
  14034. }
  14035. static void alc861_auto_set_output_and_unmute(struct hda_codec *codec,
  14036. hda_nid_t nid,
  14037. int pin_type, hda_nid_t dac)
  14038. {
  14039. hda_nid_t mix, srcs[5];
  14040. int i, num;
  14041. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_PIN_WIDGET_CONTROL,
  14042. pin_type);
  14043. snd_hda_codec_write(codec, dac, 0, AC_VERB_SET_AMP_GAIN_MUTE,
  14044. AMP_OUT_UNMUTE);
  14045. if (snd_hda_get_connections(codec, nid, &mix, 1) != 1)
  14046. return;
  14047. num = snd_hda_get_connections(codec, mix, srcs, ARRAY_SIZE(srcs));
  14048. if (num < 0)
  14049. return;
  14050. for (i = 0; i < num; i++) {
  14051. unsigned int mute;
  14052. if (srcs[i] == dac || srcs[i] == 0x15)
  14053. mute = AMP_IN_UNMUTE(i);
  14054. else
  14055. mute = AMP_IN_MUTE(i);
  14056. snd_hda_codec_write(codec, mix, 0, AC_VERB_SET_AMP_GAIN_MUTE,
  14057. mute);
  14058. }
  14059. }
  14060. static void alc861_auto_init_multi_out(struct hda_codec *codec)
  14061. {
  14062. struct alc_spec *spec = codec->spec;
  14063. int i;
  14064. for (i = 0; i < spec->autocfg.line_outs; i++) {
  14065. hda_nid_t nid = spec->autocfg.line_out_pins[i];
  14066. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  14067. if (nid)
  14068. alc861_auto_set_output_and_unmute(codec, nid, pin_type,
  14069. spec->multiout.dac_nids[i]);
  14070. }
  14071. }
  14072. static void alc861_auto_init_hp_out(struct hda_codec *codec)
  14073. {
  14074. struct alc_spec *spec = codec->spec;
  14075. if (spec->autocfg.hp_outs)
  14076. alc861_auto_set_output_and_unmute(codec,
  14077. spec->autocfg.hp_pins[0],
  14078. PIN_HP,
  14079. spec->multiout.hp_nid);
  14080. if (spec->autocfg.speaker_outs)
  14081. alc861_auto_set_output_and_unmute(codec,
  14082. spec->autocfg.speaker_pins[0],
  14083. PIN_OUT,
  14084. spec->multiout.dac_nids[0]);
  14085. }
  14086. static void alc861_auto_init_analog_input(struct hda_codec *codec)
  14087. {
  14088. struct alc_spec *spec = codec->spec;
  14089. int i;
  14090. for (i = 0; i < AUTO_PIN_LAST; i++) {
  14091. hda_nid_t nid = spec->autocfg.input_pins[i];
  14092. if (nid >= 0x0c && nid <= 0x11)
  14093. alc_set_input_pin(codec, nid, i);
  14094. }
  14095. }
  14096. /* parse the BIOS configuration and set up the alc_spec */
  14097. /* return 1 if successful, 0 if the proper config is not found,
  14098. * or a negative error code
  14099. */
  14100. static int alc861_parse_auto_config(struct hda_codec *codec)
  14101. {
  14102. struct alc_spec *spec = codec->spec;
  14103. int err;
  14104. static hda_nid_t alc861_ignore[] = { 0x1d, 0 };
  14105. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  14106. alc861_ignore);
  14107. if (err < 0)
  14108. return err;
  14109. if (!spec->autocfg.line_outs)
  14110. return 0; /* can't find valid BIOS pin config */
  14111. err = alc861_auto_fill_dac_nids(codec, &spec->autocfg);
  14112. if (err < 0)
  14113. return err;
  14114. err = alc861_auto_create_multi_out_ctls(codec, &spec->autocfg);
  14115. if (err < 0)
  14116. return err;
  14117. err = alc861_auto_create_hp_ctls(codec, spec->autocfg.hp_pins[0]);
  14118. if (err < 0)
  14119. return err;
  14120. err = alc861_auto_create_input_ctls(codec, &spec->autocfg);
  14121. if (err < 0)
  14122. return err;
  14123. spec->multiout.max_channels = spec->multiout.num_dacs * 2;
  14124. alc_auto_parse_digital(codec);
  14125. if (spec->kctls.list)
  14126. add_mixer(spec, spec->kctls.list);
  14127. add_verb(spec, alc861_auto_init_verbs);
  14128. spec->num_mux_defs = 1;
  14129. spec->input_mux = &spec->private_imux[0];
  14130. spec->adc_nids = alc861_adc_nids;
  14131. spec->num_adc_nids = ARRAY_SIZE(alc861_adc_nids);
  14132. set_capture_mixer(codec);
  14133. alc_ssid_check(codec, 0x0e, 0x0f, 0x0b, 0);
  14134. return 1;
  14135. }
  14136. /* additional initialization for auto-configuration model */
  14137. static void alc861_auto_init(struct hda_codec *codec)
  14138. {
  14139. struct alc_spec *spec = codec->spec;
  14140. alc861_auto_init_multi_out(codec);
  14141. alc861_auto_init_hp_out(codec);
  14142. alc861_auto_init_analog_input(codec);
  14143. alc_auto_init_digital(codec);
  14144. if (spec->unsol_event)
  14145. alc_inithook(codec);
  14146. }
  14147. #ifdef CONFIG_SND_HDA_POWER_SAVE
  14148. static struct hda_amp_list alc861_loopbacks[] = {
  14149. { 0x15, HDA_INPUT, 0 },
  14150. { 0x15, HDA_INPUT, 1 },
  14151. { 0x15, HDA_INPUT, 2 },
  14152. { 0x15, HDA_INPUT, 3 },
  14153. { } /* end */
  14154. };
  14155. #endif
  14156. /*
  14157. * configuration and preset
  14158. */
  14159. static const char *alc861_models[ALC861_MODEL_LAST] = {
  14160. [ALC861_3ST] = "3stack",
  14161. [ALC660_3ST] = "3stack-660",
  14162. [ALC861_3ST_DIG] = "3stack-dig",
  14163. [ALC861_6ST_DIG] = "6stack-dig",
  14164. [ALC861_UNIWILL_M31] = "uniwill-m31",
  14165. [ALC861_TOSHIBA] = "toshiba",
  14166. [ALC861_ASUS] = "asus",
  14167. [ALC861_ASUS_LAPTOP] = "asus-laptop",
  14168. [ALC861_AUTO] = "auto",
  14169. };
  14170. static struct snd_pci_quirk alc861_cfg_tbl[] = {
  14171. SND_PCI_QUIRK(0x1043, 0x1205, "ASUS W7J", ALC861_3ST),
  14172. SND_PCI_QUIRK(0x1043, 0x1335, "ASUS F2/3", ALC861_ASUS_LAPTOP),
  14173. SND_PCI_QUIRK(0x1043, 0x1338, "ASUS F2/3", ALC861_ASUS_LAPTOP),
  14174. SND_PCI_QUIRK(0x1043, 0x1393, "ASUS", ALC861_ASUS),
  14175. SND_PCI_QUIRK(0x1043, 0x13d7, "ASUS A9rp", ALC861_ASUS_LAPTOP),
  14176. SND_PCI_QUIRK(0x1043, 0x81cb, "ASUS P1-AH2", ALC861_3ST_DIG),
  14177. SND_PCI_QUIRK(0x1179, 0xff00, "Toshiba", ALC861_TOSHIBA),
  14178. /* FIXME: the entry below breaks Toshiba A100 (model=auto works!)
  14179. * Any other models that need this preset?
  14180. */
  14181. /* SND_PCI_QUIRK(0x1179, 0xff10, "Toshiba", ALC861_TOSHIBA), */
  14182. SND_PCI_QUIRK(0x1462, 0x7254, "HP dx2200 (MSI MS-7254)", ALC861_3ST),
  14183. SND_PCI_QUIRK(0x1462, 0x7297, "HP dx2250 (MSI MS-7297)", ALC861_3ST),
  14184. SND_PCI_QUIRK(0x1584, 0x2b01, "Uniwill X40AIx", ALC861_UNIWILL_M31),
  14185. SND_PCI_QUIRK(0x1584, 0x9072, "Uniwill m31", ALC861_UNIWILL_M31),
  14186. SND_PCI_QUIRK(0x1584, 0x9075, "Airis Praxis N1212", ALC861_ASUS_LAPTOP),
  14187. /* FIXME: the below seems conflict */
  14188. /* SND_PCI_QUIRK(0x1584, 0x9075, "Uniwill", ALC861_UNIWILL_M31), */
  14189. SND_PCI_QUIRK(0x1849, 0x0660, "Asrock 939SLI32", ALC660_3ST),
  14190. SND_PCI_QUIRK(0x8086, 0xd600, "Intel", ALC861_3ST),
  14191. {}
  14192. };
  14193. static struct alc_config_preset alc861_presets[] = {
  14194. [ALC861_3ST] = {
  14195. .mixers = { alc861_3ST_mixer },
  14196. .init_verbs = { alc861_threestack_init_verbs },
  14197. .num_dacs = ARRAY_SIZE(alc861_dac_nids),
  14198. .dac_nids = alc861_dac_nids,
  14199. .num_channel_mode = ARRAY_SIZE(alc861_threestack_modes),
  14200. .channel_mode = alc861_threestack_modes,
  14201. .need_dac_fix = 1,
  14202. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14203. .adc_nids = alc861_adc_nids,
  14204. .input_mux = &alc861_capture_source,
  14205. },
  14206. [ALC861_3ST_DIG] = {
  14207. .mixers = { alc861_base_mixer },
  14208. .init_verbs = { alc861_threestack_init_verbs },
  14209. .num_dacs = ARRAY_SIZE(alc861_dac_nids),
  14210. .dac_nids = alc861_dac_nids,
  14211. .dig_out_nid = ALC861_DIGOUT_NID,
  14212. .num_channel_mode = ARRAY_SIZE(alc861_threestack_modes),
  14213. .channel_mode = alc861_threestack_modes,
  14214. .need_dac_fix = 1,
  14215. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14216. .adc_nids = alc861_adc_nids,
  14217. .input_mux = &alc861_capture_source,
  14218. },
  14219. [ALC861_6ST_DIG] = {
  14220. .mixers = { alc861_base_mixer },
  14221. .init_verbs = { alc861_base_init_verbs },
  14222. .num_dacs = ARRAY_SIZE(alc861_dac_nids),
  14223. .dac_nids = alc861_dac_nids,
  14224. .dig_out_nid = ALC861_DIGOUT_NID,
  14225. .num_channel_mode = ARRAY_SIZE(alc861_8ch_modes),
  14226. .channel_mode = alc861_8ch_modes,
  14227. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14228. .adc_nids = alc861_adc_nids,
  14229. .input_mux = &alc861_capture_source,
  14230. },
  14231. [ALC660_3ST] = {
  14232. .mixers = { alc861_3ST_mixer },
  14233. .init_verbs = { alc861_threestack_init_verbs },
  14234. .num_dacs = ARRAY_SIZE(alc660_dac_nids),
  14235. .dac_nids = alc660_dac_nids,
  14236. .num_channel_mode = ARRAY_SIZE(alc861_threestack_modes),
  14237. .channel_mode = alc861_threestack_modes,
  14238. .need_dac_fix = 1,
  14239. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14240. .adc_nids = alc861_adc_nids,
  14241. .input_mux = &alc861_capture_source,
  14242. },
  14243. [ALC861_UNIWILL_M31] = {
  14244. .mixers = { alc861_uniwill_m31_mixer },
  14245. .init_verbs = { alc861_uniwill_m31_init_verbs },
  14246. .num_dacs = ARRAY_SIZE(alc861_dac_nids),
  14247. .dac_nids = alc861_dac_nids,
  14248. .dig_out_nid = ALC861_DIGOUT_NID,
  14249. .num_channel_mode = ARRAY_SIZE(alc861_uniwill_m31_modes),
  14250. .channel_mode = alc861_uniwill_m31_modes,
  14251. .need_dac_fix = 1,
  14252. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14253. .adc_nids = alc861_adc_nids,
  14254. .input_mux = &alc861_capture_source,
  14255. },
  14256. [ALC861_TOSHIBA] = {
  14257. .mixers = { alc861_toshiba_mixer },
  14258. .init_verbs = { alc861_base_init_verbs,
  14259. alc861_toshiba_init_verbs },
  14260. .num_dacs = ARRAY_SIZE(alc861_dac_nids),
  14261. .dac_nids = alc861_dac_nids,
  14262. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  14263. .channel_mode = alc883_3ST_2ch_modes,
  14264. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14265. .adc_nids = alc861_adc_nids,
  14266. .input_mux = &alc861_capture_source,
  14267. .unsol_event = alc861_toshiba_unsol_event,
  14268. .init_hook = alc861_toshiba_automute,
  14269. },
  14270. [ALC861_ASUS] = {
  14271. .mixers = { alc861_asus_mixer },
  14272. .init_verbs = { alc861_asus_init_verbs },
  14273. .num_dacs = ARRAY_SIZE(alc861_dac_nids),
  14274. .dac_nids = alc861_dac_nids,
  14275. .dig_out_nid = ALC861_DIGOUT_NID,
  14276. .num_channel_mode = ARRAY_SIZE(alc861_asus_modes),
  14277. .channel_mode = alc861_asus_modes,
  14278. .need_dac_fix = 1,
  14279. .hp_nid = 0x06,
  14280. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14281. .adc_nids = alc861_adc_nids,
  14282. .input_mux = &alc861_capture_source,
  14283. },
  14284. [ALC861_ASUS_LAPTOP] = {
  14285. .mixers = { alc861_toshiba_mixer, alc861_asus_laptop_mixer },
  14286. .init_verbs = { alc861_asus_init_verbs,
  14287. alc861_asus_laptop_init_verbs },
  14288. .num_dacs = ARRAY_SIZE(alc861_dac_nids),
  14289. .dac_nids = alc861_dac_nids,
  14290. .dig_out_nid = ALC861_DIGOUT_NID,
  14291. .num_channel_mode = ARRAY_SIZE(alc883_3ST_2ch_modes),
  14292. .channel_mode = alc883_3ST_2ch_modes,
  14293. .need_dac_fix = 1,
  14294. .num_adc_nids = ARRAY_SIZE(alc861_adc_nids),
  14295. .adc_nids = alc861_adc_nids,
  14296. .input_mux = &alc861_capture_source,
  14297. },
  14298. };
  14299. /* Pin config fixes */
  14300. enum {
  14301. PINFIX_FSC_AMILO_PI1505,
  14302. };
  14303. static struct alc_pincfg alc861_fsc_amilo_pi1505_pinfix[] = {
  14304. { 0x0b, 0x0221101f }, /* HP */
  14305. { 0x0f, 0x90170310 }, /* speaker */
  14306. { }
  14307. };
  14308. static const struct alc_fixup alc861_fixups[] = {
  14309. [PINFIX_FSC_AMILO_PI1505] = {
  14310. .pins = alc861_fsc_amilo_pi1505_pinfix
  14311. },
  14312. };
  14313. static struct snd_pci_quirk alc861_fixup_tbl[] = {
  14314. SND_PCI_QUIRK(0x1734, 0x10c7, "FSC Amilo Pi1505", PINFIX_FSC_AMILO_PI1505),
  14315. {}
  14316. };
  14317. static int patch_alc861(struct hda_codec *codec)
  14318. {
  14319. struct alc_spec *spec;
  14320. int board_config;
  14321. int err;
  14322. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  14323. if (spec == NULL)
  14324. return -ENOMEM;
  14325. codec->spec = spec;
  14326. board_config = snd_hda_check_board_config(codec, ALC861_MODEL_LAST,
  14327. alc861_models,
  14328. alc861_cfg_tbl);
  14329. if (board_config < 0) {
  14330. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  14331. codec->chip_name);
  14332. board_config = ALC861_AUTO;
  14333. }
  14334. if (board_config == ALC861_AUTO)
  14335. alc_pick_fixup(codec, alc861_fixup_tbl, alc861_fixups, 1);
  14336. if (board_config == ALC861_AUTO) {
  14337. /* automatic parse from the BIOS config */
  14338. err = alc861_parse_auto_config(codec);
  14339. if (err < 0) {
  14340. alc_free(codec);
  14341. return err;
  14342. } else if (!err) {
  14343. printk(KERN_INFO
  14344. "hda_codec: Cannot set up configuration "
  14345. "from BIOS. Using base mode...\n");
  14346. board_config = ALC861_3ST_DIG;
  14347. }
  14348. }
  14349. err = snd_hda_attach_beep_device(codec, 0x23);
  14350. if (err < 0) {
  14351. alc_free(codec);
  14352. return err;
  14353. }
  14354. if (board_config != ALC861_AUTO)
  14355. setup_preset(codec, &alc861_presets[board_config]);
  14356. spec->stream_analog_playback = &alc861_pcm_analog_playback;
  14357. spec->stream_analog_capture = &alc861_pcm_analog_capture;
  14358. spec->stream_digital_playback = &alc861_pcm_digital_playback;
  14359. spec->stream_digital_capture = &alc861_pcm_digital_capture;
  14360. if (!spec->cap_mixer)
  14361. set_capture_mixer(codec);
  14362. set_beep_amp(spec, 0x23, 0, HDA_OUTPUT);
  14363. spec->vmaster_nid = 0x03;
  14364. if (board_config == ALC861_AUTO)
  14365. alc_pick_fixup(codec, alc861_fixup_tbl, alc861_fixups, 0);
  14366. codec->patch_ops = alc_patch_ops;
  14367. if (board_config == ALC861_AUTO) {
  14368. spec->init_hook = alc861_auto_init;
  14369. #ifdef CONFIG_SND_HDA_POWER_SAVE
  14370. spec->power_hook = alc_power_eapd;
  14371. #endif
  14372. }
  14373. #ifdef CONFIG_SND_HDA_POWER_SAVE
  14374. if (!spec->loopback.amplist)
  14375. spec->loopback.amplist = alc861_loopbacks;
  14376. #endif
  14377. return 0;
  14378. }
  14379. /*
  14380. * ALC861-VD support
  14381. *
  14382. * Based on ALC882
  14383. *
  14384. * In addition, an independent DAC
  14385. */
  14386. #define ALC861VD_DIGOUT_NID 0x06
  14387. static hda_nid_t alc861vd_dac_nids[4] = {
  14388. /* front, surr, clfe, side surr */
  14389. 0x02, 0x03, 0x04, 0x05
  14390. };
  14391. /* dac_nids for ALC660vd are in a different order - according to
  14392. * Realtek's driver.
  14393. * This should probably result in a different mixer for 6stack models
  14394. * of ALC660vd codecs, but for now there is only 3stack mixer
  14395. * - and it is the same as in 861vd.
  14396. * adc_nids in ALC660vd are (is) the same as in 861vd
  14397. */
  14398. static hda_nid_t alc660vd_dac_nids[3] = {
  14399. /* front, rear, clfe, rear_surr */
  14400. 0x02, 0x04, 0x03
  14401. };
  14402. static hda_nid_t alc861vd_adc_nids[1] = {
  14403. /* ADC0 */
  14404. 0x09,
  14405. };
  14406. static hda_nid_t alc861vd_capsrc_nids[1] = { 0x22 };
  14407. /* input MUX */
  14408. /* FIXME: should be a matrix-type input source selection */
  14409. static struct hda_input_mux alc861vd_capture_source = {
  14410. .num_items = 4,
  14411. .items = {
  14412. { "Mic", 0x0 },
  14413. { "Front Mic", 0x1 },
  14414. { "Line", 0x2 },
  14415. { "CD", 0x4 },
  14416. },
  14417. };
  14418. static struct hda_input_mux alc861vd_dallas_capture_source = {
  14419. .num_items = 2,
  14420. .items = {
  14421. { "Ext Mic", 0x0 },
  14422. { "Int Mic", 0x1 },
  14423. },
  14424. };
  14425. static struct hda_input_mux alc861vd_hp_capture_source = {
  14426. .num_items = 2,
  14427. .items = {
  14428. { "Front Mic", 0x0 },
  14429. { "ATAPI Mic", 0x1 },
  14430. },
  14431. };
  14432. /*
  14433. * 2ch mode
  14434. */
  14435. static struct hda_channel_mode alc861vd_3stack_2ch_modes[1] = {
  14436. { 2, NULL }
  14437. };
  14438. /*
  14439. * 6ch mode
  14440. */
  14441. static struct hda_verb alc861vd_6stack_ch6_init[] = {
  14442. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  14443. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  14444. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  14445. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  14446. { } /* end */
  14447. };
  14448. /*
  14449. * 8ch mode
  14450. */
  14451. static struct hda_verb alc861vd_6stack_ch8_init[] = {
  14452. { 0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  14453. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  14454. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  14455. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  14456. { } /* end */
  14457. };
  14458. static struct hda_channel_mode alc861vd_6stack_modes[2] = {
  14459. { 6, alc861vd_6stack_ch6_init },
  14460. { 8, alc861vd_6stack_ch8_init },
  14461. };
  14462. static struct snd_kcontrol_new alc861vd_chmode_mixer[] = {
  14463. {
  14464. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  14465. .name = "Channel Mode",
  14466. .info = alc_ch_mode_info,
  14467. .get = alc_ch_mode_get,
  14468. .put = alc_ch_mode_put,
  14469. },
  14470. { } /* end */
  14471. };
  14472. /* Pin assignment: Front=0x14, Rear=0x15, CLFE=0x16, Side=0x17
  14473. * Mic=0x18, Front Mic=0x19, Line-In=0x1a, HP=0x1b
  14474. */
  14475. static struct snd_kcontrol_new alc861vd_6st_mixer[] = {
  14476. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  14477. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  14478. HDA_CODEC_VOLUME("Surround Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  14479. HDA_BIND_MUTE("Surround Playback Switch", 0x0d, 2, HDA_INPUT),
  14480. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0,
  14481. HDA_OUTPUT),
  14482. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0,
  14483. HDA_OUTPUT),
  14484. HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),
  14485. HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),
  14486. HDA_CODEC_VOLUME("Side Playback Volume", 0x05, 0x0, HDA_OUTPUT),
  14487. HDA_BIND_MUTE("Side Playback Switch", 0x0f, 2, HDA_INPUT),
  14488. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  14489. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  14490. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  14491. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  14492. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  14493. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  14494. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  14495. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  14496. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  14497. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  14498. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  14499. { } /* end */
  14500. };
  14501. static struct snd_kcontrol_new alc861vd_3st_mixer[] = {
  14502. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  14503. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  14504. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  14505. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  14506. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  14507. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  14508. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  14509. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  14510. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  14511. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  14512. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  14513. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  14514. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  14515. { } /* end */
  14516. };
  14517. static struct snd_kcontrol_new alc861vd_lenovo_mixer[] = {
  14518. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  14519. /*HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),*/
  14520. HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  14521. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  14522. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  14523. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  14524. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  14525. HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
  14526. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  14527. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  14528. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  14529. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  14530. { } /* end */
  14531. };
  14532. /* Pin assignment: Speaker=0x14, HP = 0x15,
  14533. * Ext Mic=0x18, Int Mic = 0x19, CD = 0x1c, PC Beep = 0x1d
  14534. */
  14535. static struct snd_kcontrol_new alc861vd_dallas_mixer[] = {
  14536. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  14537. HDA_BIND_MUTE("Speaker Playback Switch", 0x0c, 2, HDA_INPUT),
  14538. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  14539. HDA_BIND_MUTE("Headphone Playback Switch", 0x0d, 2, HDA_INPUT),
  14540. HDA_CODEC_VOLUME("Ext Mic Boost", 0x18, 0, HDA_INPUT),
  14541. HDA_CODEC_VOLUME("Ext Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  14542. HDA_CODEC_MUTE("Ext Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  14543. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  14544. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  14545. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  14546. { } /* end */
  14547. };
  14548. /* Pin assignment: Speaker=0x14, Line-out = 0x15,
  14549. * Front Mic=0x18, ATAPI Mic = 0x19,
  14550. */
  14551. static struct snd_kcontrol_new alc861vd_hp_mixer[] = {
  14552. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  14553. HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),
  14554. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  14555. HDA_BIND_MUTE("Headphone Playback Switch", 0x0d, 2, HDA_INPUT),
  14556. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  14557. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  14558. HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  14559. HDA_CODEC_MUTE("ATAPI Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  14560. { } /* end */
  14561. };
  14562. /*
  14563. * generic initialization of ADC, input mixers and output mixers
  14564. */
  14565. static struct hda_verb alc861vd_volume_init_verbs[] = {
  14566. /*
  14567. * Unmute ADC0 and set the default input to mic-in
  14568. */
  14569. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  14570. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  14571. /* Unmute input amps (CD, Line In, Mic 1 & Mic 2) of
  14572. * the analog-loopback mixer widget
  14573. */
  14574. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  14575. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14576. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14577. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  14578. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  14579. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  14580. /* Capture mixer: unmute Mic, F-Mic, Line, CD inputs */
  14581. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  14582. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  14583. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(2)},
  14584. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(4)},
  14585. /*
  14586. * Set up output mixers (0x02 - 0x05)
  14587. */
  14588. /* set vol=0 to output mixers */
  14589. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14590. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14591. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14592. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14593. /* set up input amps for analog loopback */
  14594. /* Amp Indices: DAC = 0, mixer = 1 */
  14595. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14596. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14597. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14598. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14599. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14600. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14601. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14602. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14603. { }
  14604. };
  14605. /*
  14606. * 3-stack pin configuration:
  14607. * front = 0x14, mic/clfe = 0x18, HP = 0x19, line/surr = 0x1a, f-mic = 0x1b
  14608. */
  14609. static struct hda_verb alc861vd_3stack_init_verbs[] = {
  14610. /*
  14611. * Set pin mode and muting
  14612. */
  14613. /* set front pin widgets 0x14 for output */
  14614. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14615. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14616. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  14617. /* Mic (rear) pin: input vref at 80% */
  14618. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  14619. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14620. /* Front Mic pin: input vref at 80% */
  14621. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  14622. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14623. /* Line In pin: input */
  14624. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14625. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14626. /* Line-2 In: Headphone output (output 0 - 0x0c) */
  14627. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  14628. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14629. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  14630. /* CD pin widget for input */
  14631. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14632. { }
  14633. };
  14634. /*
  14635. * 6-stack pin configuration:
  14636. */
  14637. static struct hda_verb alc861vd_6stack_init_verbs[] = {
  14638. /*
  14639. * Set pin mode and muting
  14640. */
  14641. /* set front pin widgets 0x14 for output */
  14642. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14643. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14644. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  14645. /* Rear Pin: output 1 (0x0d) */
  14646. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14647. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14648. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  14649. /* CLFE Pin: output 2 (0x0e) */
  14650. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14651. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14652. {0x16, AC_VERB_SET_CONNECT_SEL, 0x02},
  14653. /* Side Pin: output 3 (0x0f) */
  14654. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14655. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14656. {0x17, AC_VERB_SET_CONNECT_SEL, 0x03},
  14657. /* Mic (rear) pin: input vref at 80% */
  14658. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  14659. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14660. /* Front Mic pin: input vref at 80% */
  14661. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  14662. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14663. /* Line In pin: input */
  14664. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14665. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14666. /* Line-2 In: Headphone output (output 0 - 0x0c) */
  14667. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  14668. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14669. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  14670. /* CD pin widget for input */
  14671. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14672. { }
  14673. };
  14674. static struct hda_verb alc861vd_eapd_verbs[] = {
  14675. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  14676. { }
  14677. };
  14678. static struct hda_verb alc660vd_eapd_verbs[] = {
  14679. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  14680. {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
  14681. { }
  14682. };
  14683. static struct hda_verb alc861vd_lenovo_unsol_verbs[] = {
  14684. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  14685. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  14686. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)},
  14687. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  14688. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  14689. {}
  14690. };
  14691. static void alc861vd_lenovo_mic_automute(struct hda_codec *codec)
  14692. {
  14693. unsigned int present;
  14694. unsigned char bits;
  14695. present = snd_hda_jack_detect(codec, 0x18);
  14696. bits = present ? HDA_AMP_MUTE : 0;
  14697. snd_hda_codec_amp_stereo(codec, 0x0b, HDA_INPUT, 1,
  14698. HDA_AMP_MUTE, bits);
  14699. }
  14700. static void alc861vd_lenovo_setup(struct hda_codec *codec)
  14701. {
  14702. struct alc_spec *spec = codec->spec;
  14703. spec->autocfg.hp_pins[0] = 0x1b;
  14704. spec->autocfg.speaker_pins[0] = 0x14;
  14705. }
  14706. static void alc861vd_lenovo_init_hook(struct hda_codec *codec)
  14707. {
  14708. alc_automute_amp(codec);
  14709. alc861vd_lenovo_mic_automute(codec);
  14710. }
  14711. static void alc861vd_lenovo_unsol_event(struct hda_codec *codec,
  14712. unsigned int res)
  14713. {
  14714. switch (res >> 26) {
  14715. case ALC880_MIC_EVENT:
  14716. alc861vd_lenovo_mic_automute(codec);
  14717. break;
  14718. default:
  14719. alc_automute_amp_unsol_event(codec, res);
  14720. break;
  14721. }
  14722. }
  14723. static struct hda_verb alc861vd_dallas_verbs[] = {
  14724. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14725. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14726. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14727. {0x05, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  14728. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  14729. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  14730. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14731. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14732. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14733. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14734. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14735. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  14736. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14737. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14738. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14739. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14740. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14741. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14742. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  14743. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  14744. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
  14745. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14746. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
  14747. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  14748. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14749. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14750. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14751. {0x1d, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  14752. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  14753. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  14754. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  14755. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  14756. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  14757. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  14758. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  14759. { } /* end */
  14760. };
  14761. /* toggle speaker-output according to the hp-jack state */
  14762. static void alc861vd_dallas_setup(struct hda_codec *codec)
  14763. {
  14764. struct alc_spec *spec = codec->spec;
  14765. spec->autocfg.hp_pins[0] = 0x15;
  14766. spec->autocfg.speaker_pins[0] = 0x14;
  14767. }
  14768. #ifdef CONFIG_SND_HDA_POWER_SAVE
  14769. #define alc861vd_loopbacks alc880_loopbacks
  14770. #endif
  14771. /* pcm configuration: identical with ALC880 */
  14772. #define alc861vd_pcm_analog_playback alc880_pcm_analog_playback
  14773. #define alc861vd_pcm_analog_capture alc880_pcm_analog_capture
  14774. #define alc861vd_pcm_digital_playback alc880_pcm_digital_playback
  14775. #define alc861vd_pcm_digital_capture alc880_pcm_digital_capture
  14776. /*
  14777. * configuration and preset
  14778. */
  14779. static const char *alc861vd_models[ALC861VD_MODEL_LAST] = {
  14780. [ALC660VD_3ST] = "3stack-660",
  14781. [ALC660VD_3ST_DIG] = "3stack-660-digout",
  14782. [ALC660VD_ASUS_V1S] = "asus-v1s",
  14783. [ALC861VD_3ST] = "3stack",
  14784. [ALC861VD_3ST_DIG] = "3stack-digout",
  14785. [ALC861VD_6ST_DIG] = "6stack-digout",
  14786. [ALC861VD_LENOVO] = "lenovo",
  14787. [ALC861VD_DALLAS] = "dallas",
  14788. [ALC861VD_HP] = "hp",
  14789. [ALC861VD_AUTO] = "auto",
  14790. };
  14791. static struct snd_pci_quirk alc861vd_cfg_tbl[] = {
  14792. SND_PCI_QUIRK(0x1019, 0xa88d, "Realtek ALC660 demo", ALC660VD_3ST),
  14793. SND_PCI_QUIRK(0x103c, 0x30bf, "HP TX1000", ALC861VD_HP),
  14794. SND_PCI_QUIRK(0x1043, 0x12e2, "Asus z35m", ALC660VD_3ST),
  14795. /*SND_PCI_QUIRK(0x1043, 0x1339, "Asus G1", ALC660VD_3ST),*/ /* auto */
  14796. SND_PCI_QUIRK(0x1043, 0x1633, "Asus V1Sn", ALC660VD_ASUS_V1S),
  14797. SND_PCI_QUIRK(0x1043, 0x81e7, "ASUS", ALC660VD_3ST_DIG),
  14798. SND_PCI_QUIRK(0x10de, 0x03f0, "Realtek ALC660 demo", ALC660VD_3ST),
  14799. SND_PCI_QUIRK(0x1179, 0xff00, "Toshiba A135", ALC861VD_LENOVO),
  14800. /*SND_PCI_QUIRK(0x1179, 0xff00, "DALLAS", ALC861VD_DALLAS),*/ /*lenovo*/
  14801. SND_PCI_QUIRK(0x1179, 0xff01, "Toshiba A135", ALC861VD_LENOVO),
  14802. SND_PCI_QUIRK(0x1179, 0xff03, "Toshiba P205", ALC861VD_LENOVO),
  14803. SND_PCI_QUIRK(0x1179, 0xff31, "Toshiba L30-149", ALC861VD_DALLAS),
  14804. SND_PCI_QUIRK(0x1565, 0x820d, "Biostar NF61S SE", ALC861VD_6ST_DIG),
  14805. SND_PCI_QUIRK_VENDOR(0x17aa, "Lenovo", ALC861VD_LENOVO),
  14806. SND_PCI_QUIRK(0x1849, 0x0862, "ASRock K8NF6G-VSTA", ALC861VD_6ST_DIG),
  14807. {}
  14808. };
  14809. static struct alc_config_preset alc861vd_presets[] = {
  14810. [ALC660VD_3ST] = {
  14811. .mixers = { alc861vd_3st_mixer },
  14812. .init_verbs = { alc861vd_volume_init_verbs,
  14813. alc861vd_3stack_init_verbs },
  14814. .num_dacs = ARRAY_SIZE(alc660vd_dac_nids),
  14815. .dac_nids = alc660vd_dac_nids,
  14816. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14817. .channel_mode = alc861vd_3stack_2ch_modes,
  14818. .input_mux = &alc861vd_capture_source,
  14819. },
  14820. [ALC660VD_3ST_DIG] = {
  14821. .mixers = { alc861vd_3st_mixer },
  14822. .init_verbs = { alc861vd_volume_init_verbs,
  14823. alc861vd_3stack_init_verbs },
  14824. .num_dacs = ARRAY_SIZE(alc660vd_dac_nids),
  14825. .dac_nids = alc660vd_dac_nids,
  14826. .dig_out_nid = ALC861VD_DIGOUT_NID,
  14827. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14828. .channel_mode = alc861vd_3stack_2ch_modes,
  14829. .input_mux = &alc861vd_capture_source,
  14830. },
  14831. [ALC861VD_3ST] = {
  14832. .mixers = { alc861vd_3st_mixer },
  14833. .init_verbs = { alc861vd_volume_init_verbs,
  14834. alc861vd_3stack_init_verbs },
  14835. .num_dacs = ARRAY_SIZE(alc861vd_dac_nids),
  14836. .dac_nids = alc861vd_dac_nids,
  14837. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14838. .channel_mode = alc861vd_3stack_2ch_modes,
  14839. .input_mux = &alc861vd_capture_source,
  14840. },
  14841. [ALC861VD_3ST_DIG] = {
  14842. .mixers = { alc861vd_3st_mixer },
  14843. .init_verbs = { alc861vd_volume_init_verbs,
  14844. alc861vd_3stack_init_verbs },
  14845. .num_dacs = ARRAY_SIZE(alc861vd_dac_nids),
  14846. .dac_nids = alc861vd_dac_nids,
  14847. .dig_out_nid = ALC861VD_DIGOUT_NID,
  14848. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14849. .channel_mode = alc861vd_3stack_2ch_modes,
  14850. .input_mux = &alc861vd_capture_source,
  14851. },
  14852. [ALC861VD_6ST_DIG] = {
  14853. .mixers = { alc861vd_6st_mixer, alc861vd_chmode_mixer },
  14854. .init_verbs = { alc861vd_volume_init_verbs,
  14855. alc861vd_6stack_init_verbs },
  14856. .num_dacs = ARRAY_SIZE(alc861vd_dac_nids),
  14857. .dac_nids = alc861vd_dac_nids,
  14858. .dig_out_nid = ALC861VD_DIGOUT_NID,
  14859. .num_channel_mode = ARRAY_SIZE(alc861vd_6stack_modes),
  14860. .channel_mode = alc861vd_6stack_modes,
  14861. .input_mux = &alc861vd_capture_source,
  14862. },
  14863. [ALC861VD_LENOVO] = {
  14864. .mixers = { alc861vd_lenovo_mixer },
  14865. .init_verbs = { alc861vd_volume_init_verbs,
  14866. alc861vd_3stack_init_verbs,
  14867. alc861vd_eapd_verbs,
  14868. alc861vd_lenovo_unsol_verbs },
  14869. .num_dacs = ARRAY_SIZE(alc660vd_dac_nids),
  14870. .dac_nids = alc660vd_dac_nids,
  14871. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14872. .channel_mode = alc861vd_3stack_2ch_modes,
  14873. .input_mux = &alc861vd_capture_source,
  14874. .unsol_event = alc861vd_lenovo_unsol_event,
  14875. .setup = alc861vd_lenovo_setup,
  14876. .init_hook = alc861vd_lenovo_init_hook,
  14877. },
  14878. [ALC861VD_DALLAS] = {
  14879. .mixers = { alc861vd_dallas_mixer },
  14880. .init_verbs = { alc861vd_dallas_verbs },
  14881. .num_dacs = ARRAY_SIZE(alc861vd_dac_nids),
  14882. .dac_nids = alc861vd_dac_nids,
  14883. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14884. .channel_mode = alc861vd_3stack_2ch_modes,
  14885. .input_mux = &alc861vd_dallas_capture_source,
  14886. .unsol_event = alc_automute_amp_unsol_event,
  14887. .setup = alc861vd_dallas_setup,
  14888. .init_hook = alc_automute_amp,
  14889. },
  14890. [ALC861VD_HP] = {
  14891. .mixers = { alc861vd_hp_mixer },
  14892. .init_verbs = { alc861vd_dallas_verbs, alc861vd_eapd_verbs },
  14893. .num_dacs = ARRAY_SIZE(alc861vd_dac_nids),
  14894. .dac_nids = alc861vd_dac_nids,
  14895. .dig_out_nid = ALC861VD_DIGOUT_NID,
  14896. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14897. .channel_mode = alc861vd_3stack_2ch_modes,
  14898. .input_mux = &alc861vd_hp_capture_source,
  14899. .unsol_event = alc_automute_amp_unsol_event,
  14900. .setup = alc861vd_dallas_setup,
  14901. .init_hook = alc_automute_amp,
  14902. },
  14903. [ALC660VD_ASUS_V1S] = {
  14904. .mixers = { alc861vd_lenovo_mixer },
  14905. .init_verbs = { alc861vd_volume_init_verbs,
  14906. alc861vd_3stack_init_verbs,
  14907. alc861vd_eapd_verbs,
  14908. alc861vd_lenovo_unsol_verbs },
  14909. .num_dacs = ARRAY_SIZE(alc660vd_dac_nids),
  14910. .dac_nids = alc660vd_dac_nids,
  14911. .dig_out_nid = ALC861VD_DIGOUT_NID,
  14912. .num_channel_mode = ARRAY_SIZE(alc861vd_3stack_2ch_modes),
  14913. .channel_mode = alc861vd_3stack_2ch_modes,
  14914. .input_mux = &alc861vd_capture_source,
  14915. .unsol_event = alc861vd_lenovo_unsol_event,
  14916. .setup = alc861vd_lenovo_setup,
  14917. .init_hook = alc861vd_lenovo_init_hook,
  14918. },
  14919. };
  14920. /*
  14921. * BIOS auto configuration
  14922. */
  14923. static int alc861vd_auto_create_input_ctls(struct hda_codec *codec,
  14924. const struct auto_pin_cfg *cfg)
  14925. {
  14926. return alc_auto_create_input_ctls(codec, cfg, 0x15, 0x09, 0);
  14927. }
  14928. static void alc861vd_auto_set_output_and_unmute(struct hda_codec *codec,
  14929. hda_nid_t nid, int pin_type, int dac_idx)
  14930. {
  14931. alc_set_pin_output(codec, nid, pin_type);
  14932. }
  14933. static void alc861vd_auto_init_multi_out(struct hda_codec *codec)
  14934. {
  14935. struct alc_spec *spec = codec->spec;
  14936. int i;
  14937. for (i = 0; i <= HDA_SIDE; i++) {
  14938. hda_nid_t nid = spec->autocfg.line_out_pins[i];
  14939. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  14940. if (nid)
  14941. alc861vd_auto_set_output_and_unmute(codec, nid,
  14942. pin_type, i);
  14943. }
  14944. }
  14945. static void alc861vd_auto_init_hp_out(struct hda_codec *codec)
  14946. {
  14947. struct alc_spec *spec = codec->spec;
  14948. hda_nid_t pin;
  14949. pin = spec->autocfg.hp_pins[0];
  14950. if (pin) /* connect to front and use dac 0 */
  14951. alc861vd_auto_set_output_and_unmute(codec, pin, PIN_HP, 0);
  14952. pin = spec->autocfg.speaker_pins[0];
  14953. if (pin)
  14954. alc861vd_auto_set_output_and_unmute(codec, pin, PIN_OUT, 0);
  14955. }
  14956. #define ALC861VD_PIN_CD_NID ALC880_PIN_CD_NID
  14957. static void alc861vd_auto_init_analog_input(struct hda_codec *codec)
  14958. {
  14959. struct alc_spec *spec = codec->spec;
  14960. int i;
  14961. for (i = 0; i < AUTO_PIN_LAST; i++) {
  14962. hda_nid_t nid = spec->autocfg.input_pins[i];
  14963. if (alc_is_input_pin(codec, nid)) {
  14964. alc_set_input_pin(codec, nid, i);
  14965. if (nid != ALC861VD_PIN_CD_NID &&
  14966. (get_wcaps(codec, nid) & AC_WCAP_OUT_AMP))
  14967. snd_hda_codec_write(codec, nid, 0,
  14968. AC_VERB_SET_AMP_GAIN_MUTE,
  14969. AMP_OUT_MUTE);
  14970. }
  14971. }
  14972. }
  14973. #define alc861vd_auto_init_input_src alc882_auto_init_input_src
  14974. #define alc861vd_idx_to_mixer_vol(nid) ((nid) + 0x02)
  14975. #define alc861vd_idx_to_mixer_switch(nid) ((nid) + 0x0c)
  14976. /* add playback controls from the parsed DAC table */
  14977. /* Based on ALC880 version. But ALC861VD has separate,
  14978. * different NIDs for mute/unmute switch and volume control */
  14979. static int alc861vd_auto_create_multi_out_ctls(struct alc_spec *spec,
  14980. const struct auto_pin_cfg *cfg)
  14981. {
  14982. static const char *chname[4] = {"Front", "Surround", "CLFE", "Side"};
  14983. hda_nid_t nid_v, nid_s;
  14984. int i, err;
  14985. for (i = 0; i < cfg->line_outs; i++) {
  14986. if (!spec->multiout.dac_nids[i])
  14987. continue;
  14988. nid_v = alc861vd_idx_to_mixer_vol(
  14989. alc880_dac_to_idx(
  14990. spec->multiout.dac_nids[i]));
  14991. nid_s = alc861vd_idx_to_mixer_switch(
  14992. alc880_dac_to_idx(
  14993. spec->multiout.dac_nids[i]));
  14994. if (i == 2) {
  14995. /* Center/LFE */
  14996. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL,
  14997. "Center",
  14998. HDA_COMPOSE_AMP_VAL(nid_v, 1, 0,
  14999. HDA_OUTPUT));
  15000. if (err < 0)
  15001. return err;
  15002. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL,
  15003. "LFE",
  15004. HDA_COMPOSE_AMP_VAL(nid_v, 2, 0,
  15005. HDA_OUTPUT));
  15006. if (err < 0)
  15007. return err;
  15008. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE,
  15009. "Center",
  15010. HDA_COMPOSE_AMP_VAL(nid_s, 1, 2,
  15011. HDA_INPUT));
  15012. if (err < 0)
  15013. return err;
  15014. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE,
  15015. "LFE",
  15016. HDA_COMPOSE_AMP_VAL(nid_s, 2, 2,
  15017. HDA_INPUT));
  15018. if (err < 0)
  15019. return err;
  15020. } else {
  15021. const char *pfx;
  15022. if (cfg->line_outs == 1 &&
  15023. cfg->line_out_type == AUTO_PIN_SPEAKER_OUT) {
  15024. if (!cfg->hp_pins)
  15025. pfx = "Speaker";
  15026. else
  15027. pfx = "PCM";
  15028. } else
  15029. pfx = chname[i];
  15030. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, pfx,
  15031. HDA_COMPOSE_AMP_VAL(nid_v, 3, 0,
  15032. HDA_OUTPUT));
  15033. if (err < 0)
  15034. return err;
  15035. if (cfg->line_outs == 1 &&
  15036. cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  15037. pfx = "Speaker";
  15038. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE, pfx,
  15039. HDA_COMPOSE_AMP_VAL(nid_s, 3, 2,
  15040. HDA_INPUT));
  15041. if (err < 0)
  15042. return err;
  15043. }
  15044. }
  15045. return 0;
  15046. }
  15047. /* add playback controls for speaker and HP outputs */
  15048. /* Based on ALC880 version. But ALC861VD has separate,
  15049. * different NIDs for mute/unmute switch and volume control */
  15050. static int alc861vd_auto_create_extra_out(struct alc_spec *spec,
  15051. hda_nid_t pin, const char *pfx)
  15052. {
  15053. hda_nid_t nid_v, nid_s;
  15054. int err;
  15055. if (!pin)
  15056. return 0;
  15057. if (alc880_is_fixed_pin(pin)) {
  15058. nid_v = alc880_idx_to_dac(alc880_fixed_pin_idx(pin));
  15059. /* specify the DAC as the extra output */
  15060. if (!spec->multiout.hp_nid)
  15061. spec->multiout.hp_nid = nid_v;
  15062. else
  15063. spec->multiout.extra_out_nid[0] = nid_v;
  15064. /* control HP volume/switch on the output mixer amp */
  15065. nid_v = alc861vd_idx_to_mixer_vol(
  15066. alc880_fixed_pin_idx(pin));
  15067. nid_s = alc861vd_idx_to_mixer_switch(
  15068. alc880_fixed_pin_idx(pin));
  15069. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, pfx,
  15070. HDA_COMPOSE_AMP_VAL(nid_v, 3, 0, HDA_OUTPUT));
  15071. if (err < 0)
  15072. return err;
  15073. err = add_pb_sw_ctrl(spec, ALC_CTL_BIND_MUTE, pfx,
  15074. HDA_COMPOSE_AMP_VAL(nid_s, 3, 2, HDA_INPUT));
  15075. if (err < 0)
  15076. return err;
  15077. } else if (alc880_is_multi_pin(pin)) {
  15078. /* set manual connection */
  15079. /* we have only a switch on HP-out PIN */
  15080. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, pfx,
  15081. HDA_COMPOSE_AMP_VAL(pin, 3, 0, HDA_OUTPUT));
  15082. if (err < 0)
  15083. return err;
  15084. }
  15085. return 0;
  15086. }
  15087. /* parse the BIOS configuration and set up the alc_spec
  15088. * return 1 if successful, 0 if the proper config is not found,
  15089. * or a negative error code
  15090. * Based on ALC880 version - had to change it to override
  15091. * alc880_auto_create_extra_out and alc880_auto_create_multi_out_ctls */
  15092. static int alc861vd_parse_auto_config(struct hda_codec *codec)
  15093. {
  15094. struct alc_spec *spec = codec->spec;
  15095. int err;
  15096. static hda_nid_t alc861vd_ignore[] = { 0x1d, 0 };
  15097. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  15098. alc861vd_ignore);
  15099. if (err < 0)
  15100. return err;
  15101. if (!spec->autocfg.line_outs)
  15102. return 0; /* can't find valid BIOS pin config */
  15103. err = alc880_auto_fill_dac_nids(spec, &spec->autocfg);
  15104. if (err < 0)
  15105. return err;
  15106. err = alc861vd_auto_create_multi_out_ctls(spec, &spec->autocfg);
  15107. if (err < 0)
  15108. return err;
  15109. err = alc861vd_auto_create_extra_out(spec,
  15110. spec->autocfg.speaker_pins[0],
  15111. "Speaker");
  15112. if (err < 0)
  15113. return err;
  15114. err = alc861vd_auto_create_extra_out(spec,
  15115. spec->autocfg.hp_pins[0],
  15116. "Headphone");
  15117. if (err < 0)
  15118. return err;
  15119. err = alc861vd_auto_create_input_ctls(codec, &spec->autocfg);
  15120. if (err < 0)
  15121. return err;
  15122. spec->multiout.max_channels = spec->multiout.num_dacs * 2;
  15123. alc_auto_parse_digital(codec);
  15124. if (spec->kctls.list)
  15125. add_mixer(spec, spec->kctls.list);
  15126. add_verb(spec, alc861vd_volume_init_verbs);
  15127. spec->num_mux_defs = 1;
  15128. spec->input_mux = &spec->private_imux[0];
  15129. err = alc_auto_add_mic_boost(codec);
  15130. if (err < 0)
  15131. return err;
  15132. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
  15133. return 1;
  15134. }
  15135. /* additional initialization for auto-configuration model */
  15136. static void alc861vd_auto_init(struct hda_codec *codec)
  15137. {
  15138. struct alc_spec *spec = codec->spec;
  15139. alc861vd_auto_init_multi_out(codec);
  15140. alc861vd_auto_init_hp_out(codec);
  15141. alc861vd_auto_init_analog_input(codec);
  15142. alc861vd_auto_init_input_src(codec);
  15143. alc_auto_init_digital(codec);
  15144. if (spec->unsol_event)
  15145. alc_inithook(codec);
  15146. }
  15147. enum {
  15148. ALC660VD_FIX_ASUS_GPIO1
  15149. };
  15150. /* reset GPIO1 */
  15151. static const struct hda_verb alc660vd_fix_asus_gpio1_verbs[] = {
  15152. {0x01, AC_VERB_SET_GPIO_MASK, 0x03},
  15153. {0x01, AC_VERB_SET_GPIO_DIRECTION, 0x01},
  15154. {0x01, AC_VERB_SET_GPIO_DATA, 0x01},
  15155. { }
  15156. };
  15157. static const struct alc_fixup alc861vd_fixups[] = {
  15158. [ALC660VD_FIX_ASUS_GPIO1] = {
  15159. .verbs = alc660vd_fix_asus_gpio1_verbs,
  15160. },
  15161. };
  15162. static struct snd_pci_quirk alc861vd_fixup_tbl[] = {
  15163. SND_PCI_QUIRK(0x1043, 0x1339, "ASUS A7-K", ALC660VD_FIX_ASUS_GPIO1),
  15164. {}
  15165. };
  15166. static int patch_alc861vd(struct hda_codec *codec)
  15167. {
  15168. struct alc_spec *spec;
  15169. int err, board_config;
  15170. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  15171. if (spec == NULL)
  15172. return -ENOMEM;
  15173. codec->spec = spec;
  15174. board_config = snd_hda_check_board_config(codec, ALC861VD_MODEL_LAST,
  15175. alc861vd_models,
  15176. alc861vd_cfg_tbl);
  15177. if (board_config < 0 || board_config >= ALC861VD_MODEL_LAST) {
  15178. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  15179. codec->chip_name);
  15180. board_config = ALC861VD_AUTO;
  15181. }
  15182. if (board_config == ALC861VD_AUTO)
  15183. alc_pick_fixup(codec, alc861vd_fixup_tbl, alc861vd_fixups, 1);
  15184. if (board_config == ALC861VD_AUTO) {
  15185. /* automatic parse from the BIOS config */
  15186. err = alc861vd_parse_auto_config(codec);
  15187. if (err < 0) {
  15188. alc_free(codec);
  15189. return err;
  15190. } else if (!err) {
  15191. printk(KERN_INFO
  15192. "hda_codec: Cannot set up configuration "
  15193. "from BIOS. Using base mode...\n");
  15194. board_config = ALC861VD_3ST;
  15195. }
  15196. }
  15197. err = snd_hda_attach_beep_device(codec, 0x23);
  15198. if (err < 0) {
  15199. alc_free(codec);
  15200. return err;
  15201. }
  15202. if (board_config != ALC861VD_AUTO)
  15203. setup_preset(codec, &alc861vd_presets[board_config]);
  15204. if (codec->vendor_id == 0x10ec0660) {
  15205. /* always turn on EAPD */
  15206. add_verb(spec, alc660vd_eapd_verbs);
  15207. }
  15208. spec->stream_analog_playback = &alc861vd_pcm_analog_playback;
  15209. spec->stream_analog_capture = &alc861vd_pcm_analog_capture;
  15210. spec->stream_digital_playback = &alc861vd_pcm_digital_playback;
  15211. spec->stream_digital_capture = &alc861vd_pcm_digital_capture;
  15212. if (!spec->adc_nids) {
  15213. spec->adc_nids = alc861vd_adc_nids;
  15214. spec->num_adc_nids = ARRAY_SIZE(alc861vd_adc_nids);
  15215. }
  15216. if (!spec->capsrc_nids)
  15217. spec->capsrc_nids = alc861vd_capsrc_nids;
  15218. set_capture_mixer(codec);
  15219. set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT);
  15220. spec->vmaster_nid = 0x02;
  15221. if (board_config == ALC861VD_AUTO)
  15222. alc_pick_fixup(codec, alc861vd_fixup_tbl, alc861vd_fixups, 0);
  15223. codec->patch_ops = alc_patch_ops;
  15224. if (board_config == ALC861VD_AUTO)
  15225. spec->init_hook = alc861vd_auto_init;
  15226. #ifdef CONFIG_SND_HDA_POWER_SAVE
  15227. if (!spec->loopback.amplist)
  15228. spec->loopback.amplist = alc861vd_loopbacks;
  15229. #endif
  15230. return 0;
  15231. }
  15232. /*
  15233. * ALC662 support
  15234. *
  15235. * ALC662 is almost identical with ALC880 but has cleaner and more flexible
  15236. * configuration. Each pin widget can choose any input DACs and a mixer.
  15237. * Each ADC is connected from a mixer of all inputs. This makes possible
  15238. * 6-channel independent captures.
  15239. *
  15240. * In addition, an independent DAC for the multi-playback (not used in this
  15241. * driver yet).
  15242. */
  15243. #define ALC662_DIGOUT_NID 0x06
  15244. #define ALC662_DIGIN_NID 0x0a
  15245. static hda_nid_t alc662_dac_nids[4] = {
  15246. /* front, rear, clfe, rear_surr */
  15247. 0x02, 0x03, 0x04
  15248. };
  15249. static hda_nid_t alc272_dac_nids[2] = {
  15250. 0x02, 0x03
  15251. };
  15252. static hda_nid_t alc662_adc_nids[2] = {
  15253. /* ADC1-2 */
  15254. 0x09, 0x08
  15255. };
  15256. static hda_nid_t alc272_adc_nids[1] = {
  15257. /* ADC1-2 */
  15258. 0x08,
  15259. };
  15260. static hda_nid_t alc662_capsrc_nids[2] = { 0x22, 0x23 };
  15261. static hda_nid_t alc272_capsrc_nids[1] = { 0x23 };
  15262. /* input MUX */
  15263. /* FIXME: should be a matrix-type input source selection */
  15264. static struct hda_input_mux alc662_capture_source = {
  15265. .num_items = 4,
  15266. .items = {
  15267. { "Mic", 0x0 },
  15268. { "Front Mic", 0x1 },
  15269. { "Line", 0x2 },
  15270. { "CD", 0x4 },
  15271. },
  15272. };
  15273. static struct hda_input_mux alc662_lenovo_101e_capture_source = {
  15274. .num_items = 2,
  15275. .items = {
  15276. { "Mic", 0x1 },
  15277. { "Line", 0x2 },
  15278. },
  15279. };
  15280. static struct hda_input_mux alc663_capture_source = {
  15281. .num_items = 3,
  15282. .items = {
  15283. { "Mic", 0x0 },
  15284. { "Front Mic", 0x1 },
  15285. { "Line", 0x2 },
  15286. },
  15287. };
  15288. #if 0 /* set to 1 for testing other input sources below */
  15289. static struct hda_input_mux alc272_nc10_capture_source = {
  15290. .num_items = 16,
  15291. .items = {
  15292. { "Autoselect Mic", 0x0 },
  15293. { "Internal Mic", 0x1 },
  15294. { "In-0x02", 0x2 },
  15295. { "In-0x03", 0x3 },
  15296. { "In-0x04", 0x4 },
  15297. { "In-0x05", 0x5 },
  15298. { "In-0x06", 0x6 },
  15299. { "In-0x07", 0x7 },
  15300. { "In-0x08", 0x8 },
  15301. { "In-0x09", 0x9 },
  15302. { "In-0x0a", 0x0a },
  15303. { "In-0x0b", 0x0b },
  15304. { "In-0x0c", 0x0c },
  15305. { "In-0x0d", 0x0d },
  15306. { "In-0x0e", 0x0e },
  15307. { "In-0x0f", 0x0f },
  15308. },
  15309. };
  15310. #endif
  15311. /*
  15312. * 2ch mode
  15313. */
  15314. static struct hda_channel_mode alc662_3ST_2ch_modes[1] = {
  15315. { 2, NULL }
  15316. };
  15317. /*
  15318. * 2ch mode
  15319. */
  15320. static struct hda_verb alc662_3ST_ch2_init[] = {
  15321. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },
  15322. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  15323. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },
  15324. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
  15325. { } /* end */
  15326. };
  15327. /*
  15328. * 6ch mode
  15329. */
  15330. static struct hda_verb alc662_3ST_ch6_init[] = {
  15331. { 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  15332. { 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  15333. { 0x18, AC_VERB_SET_CONNECT_SEL, 0x02 },
  15334. { 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  15335. { 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  15336. { 0x1a, AC_VERB_SET_CONNECT_SEL, 0x01 },
  15337. { } /* end */
  15338. };
  15339. static struct hda_channel_mode alc662_3ST_6ch_modes[2] = {
  15340. { 2, alc662_3ST_ch2_init },
  15341. { 6, alc662_3ST_ch6_init },
  15342. };
  15343. /*
  15344. * 2ch mode
  15345. */
  15346. static struct hda_verb alc662_sixstack_ch6_init[] = {
  15347. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  15348. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x00 },
  15349. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  15350. { } /* end */
  15351. };
  15352. /*
  15353. * 6ch mode
  15354. */
  15355. static struct hda_verb alc662_sixstack_ch8_init[] = {
  15356. { 0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  15357. { 0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  15358. { 0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },
  15359. { } /* end */
  15360. };
  15361. static struct hda_channel_mode alc662_5stack_modes[2] = {
  15362. { 2, alc662_sixstack_ch6_init },
  15363. { 6, alc662_sixstack_ch8_init },
  15364. };
  15365. /* Pin assignment: Front=0x14, Rear=0x15, CLFE=0x16, Side=0x17
  15366. * Mic=0x18, Front Mic=0x19, Line-In=0x1a, HP=0x1b
  15367. */
  15368. static struct snd_kcontrol_new alc662_base_mixer[] = {
  15369. /* output mixer control */
  15370. HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT),
  15371. HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
  15372. HDA_CODEC_VOLUME("Surround Playback Volume", 0x3, 0x0, HDA_OUTPUT),
  15373. HDA_CODEC_MUTE("Surround Playback Switch", 0x0d, 0x0, HDA_INPUT),
  15374. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
  15375. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
  15376. HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x0e, 1, 0x0, HDA_INPUT),
  15377. HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 0x0, HDA_INPUT),
  15378. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  15379. /*Input mixer control */
  15380. HDA_CODEC_VOLUME("CD Playback Volume", 0xb, 0x4, HDA_INPUT),
  15381. HDA_CODEC_MUTE("CD Playback Switch", 0xb, 0x4, HDA_INPUT),
  15382. HDA_CODEC_VOLUME("Line Playback Volume", 0xb, 0x02, HDA_INPUT),
  15383. HDA_CODEC_MUTE("Line Playback Switch", 0xb, 0x02, HDA_INPUT),
  15384. HDA_CODEC_VOLUME("Mic Playback Volume", 0xb, 0x0, HDA_INPUT),
  15385. HDA_CODEC_MUTE("Mic Playback Switch", 0xb, 0x0, HDA_INPUT),
  15386. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0xb, 0x01, HDA_INPUT),
  15387. HDA_CODEC_MUTE("Front Mic Playback Switch", 0xb, 0x01, HDA_INPUT),
  15388. { } /* end */
  15389. };
  15390. static struct snd_kcontrol_new alc662_3ST_2ch_mixer[] = {
  15391. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15392. HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
  15393. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  15394. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  15395. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  15396. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  15397. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  15398. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15399. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15400. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15401. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15402. { } /* end */
  15403. };
  15404. static struct snd_kcontrol_new alc662_3ST_6ch_mixer[] = {
  15405. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15406. HDA_CODEC_MUTE("Front Playback Switch", 0x0c, 0x0, HDA_INPUT),
  15407. HDA_CODEC_VOLUME("Surround Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  15408. HDA_CODEC_MUTE("Surround Playback Switch", 0x0d, 0x0, HDA_INPUT),
  15409. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
  15410. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
  15411. HDA_CODEC_MUTE_MONO("Center Playback Switch", 0x0e, 1, 0x0, HDA_INPUT),
  15412. HDA_CODEC_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 0x0, HDA_INPUT),
  15413. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  15414. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  15415. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  15416. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  15417. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  15418. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15419. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15420. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15421. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15422. { } /* end */
  15423. };
  15424. static struct snd_kcontrol_new alc662_lenovo_101e_mixer[] = {
  15425. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15426. HDA_BIND_MUTE("Front Playback Switch", 0x02, 2, HDA_INPUT),
  15427. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  15428. HDA_BIND_MUTE("Speaker Playback Switch", 0x03, 2, HDA_INPUT),
  15429. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  15430. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  15431. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  15432. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15433. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15434. { } /* end */
  15435. };
  15436. static struct snd_kcontrol_new alc662_eeepc_p701_mixer[] = {
  15437. HDA_CODEC_VOLUME("Master Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15438. ALC262_HIPPO_MASTER_SWITCH,
  15439. HDA_CODEC_VOLUME("e-Mic Boost", 0x18, 0, HDA_INPUT),
  15440. HDA_CODEC_VOLUME("e-Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15441. HDA_CODEC_MUTE("e-Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15442. HDA_CODEC_VOLUME("i-Mic Boost", 0x19, 0, HDA_INPUT),
  15443. HDA_CODEC_VOLUME("i-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15444. HDA_CODEC_MUTE("i-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15445. { } /* end */
  15446. };
  15447. static struct snd_kcontrol_new alc662_eeepc_ep20_mixer[] = {
  15448. ALC262_HIPPO_MASTER_SWITCH,
  15449. HDA_CODEC_VOLUME("Front Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15450. HDA_CODEC_VOLUME("Surround Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  15451. HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x04, 1, 0x0, HDA_OUTPUT),
  15452. HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x04, 2, 0x0, HDA_OUTPUT),
  15453. HDA_BIND_MUTE("MuteCtrl Playback Switch", 0x0c, 2, HDA_INPUT),
  15454. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  15455. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  15456. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15457. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15458. { } /* end */
  15459. };
  15460. static struct hda_bind_ctls alc663_asus_bind_master_vol = {
  15461. .ops = &snd_hda_bind_vol,
  15462. .values = {
  15463. HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT),
  15464. HDA_COMPOSE_AMP_VAL(0x03, 3, 0, HDA_OUTPUT),
  15465. 0
  15466. },
  15467. };
  15468. static struct hda_bind_ctls alc663_asus_one_bind_switch = {
  15469. .ops = &snd_hda_bind_sw,
  15470. .values = {
  15471. HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  15472. HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
  15473. 0
  15474. },
  15475. };
  15476. static struct snd_kcontrol_new alc663_m51va_mixer[] = {
  15477. HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
  15478. HDA_BIND_SW("Master Playback Switch", &alc663_asus_one_bind_switch),
  15479. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15480. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15481. { } /* end */
  15482. };
  15483. static struct hda_bind_ctls alc663_asus_tree_bind_switch = {
  15484. .ops = &snd_hda_bind_sw,
  15485. .values = {
  15486. HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  15487. HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
  15488. HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
  15489. 0
  15490. },
  15491. };
  15492. static struct snd_kcontrol_new alc663_two_hp_m1_mixer[] = {
  15493. HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
  15494. HDA_BIND_SW("Master Playback Switch", &alc663_asus_tree_bind_switch),
  15495. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15496. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15497. HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15498. HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15499. { } /* end */
  15500. };
  15501. static struct hda_bind_ctls alc663_asus_four_bind_switch = {
  15502. .ops = &snd_hda_bind_sw,
  15503. .values = {
  15504. HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  15505. HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
  15506. HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
  15507. 0
  15508. },
  15509. };
  15510. static struct snd_kcontrol_new alc663_two_hp_m2_mixer[] = {
  15511. HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
  15512. HDA_BIND_SW("Master Playback Switch", &alc663_asus_four_bind_switch),
  15513. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15514. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15515. HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15516. HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15517. { } /* end */
  15518. };
  15519. static struct snd_kcontrol_new alc662_1bjd_mixer[] = {
  15520. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15521. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  15522. HDA_CODEC_MUTE("Headphone Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  15523. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15524. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15525. HDA_CODEC_VOLUME("F-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15526. HDA_CODEC_MUTE("F-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15527. { } /* end */
  15528. };
  15529. static struct hda_bind_ctls alc663_asus_two_bind_master_vol = {
  15530. .ops = &snd_hda_bind_vol,
  15531. .values = {
  15532. HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT),
  15533. HDA_COMPOSE_AMP_VAL(0x04, 3, 0, HDA_OUTPUT),
  15534. 0
  15535. },
  15536. };
  15537. static struct hda_bind_ctls alc663_asus_two_bind_switch = {
  15538. .ops = &snd_hda_bind_sw,
  15539. .values = {
  15540. HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  15541. HDA_COMPOSE_AMP_VAL(0x16, 3, 0, HDA_OUTPUT),
  15542. 0
  15543. },
  15544. };
  15545. static struct snd_kcontrol_new alc663_asus_21jd_clfe_mixer[] = {
  15546. HDA_BIND_VOL("Master Playback Volume",
  15547. &alc663_asus_two_bind_master_vol),
  15548. HDA_BIND_SW("Master Playback Switch", &alc663_asus_two_bind_switch),
  15549. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  15550. HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
  15551. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15552. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15553. { } /* end */
  15554. };
  15555. static struct snd_kcontrol_new alc663_asus_15jd_clfe_mixer[] = {
  15556. HDA_BIND_VOL("Master Playback Volume", &alc663_asus_bind_master_vol),
  15557. HDA_BIND_SW("Master Playback Switch", &alc663_asus_two_bind_switch),
  15558. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  15559. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  15560. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15561. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15562. { } /* end */
  15563. };
  15564. static struct snd_kcontrol_new alc663_g71v_mixer[] = {
  15565. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15566. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  15567. HDA_CODEC_VOLUME("Front Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  15568. HDA_CODEC_MUTE("Front Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  15569. HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
  15570. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15571. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15572. HDA_CODEC_VOLUME("i-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15573. HDA_CODEC_MUTE("i-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15574. { } /* end */
  15575. };
  15576. static struct snd_kcontrol_new alc663_g50v_mixer[] = {
  15577. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  15578. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  15579. HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
  15580. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15581. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15582. HDA_CODEC_VOLUME("i-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15583. HDA_CODEC_MUTE("i-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15584. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  15585. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  15586. { } /* end */
  15587. };
  15588. static struct hda_bind_ctls alc663_asus_mode7_8_all_bind_switch = {
  15589. .ops = &snd_hda_bind_sw,
  15590. .values = {
  15591. HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  15592. HDA_COMPOSE_AMP_VAL(0x15, 3, 0, HDA_OUTPUT),
  15593. HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT),
  15594. HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
  15595. HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
  15596. 0
  15597. },
  15598. };
  15599. static struct hda_bind_ctls alc663_asus_mode7_8_sp_bind_switch = {
  15600. .ops = &snd_hda_bind_sw,
  15601. .values = {
  15602. HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
  15603. HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_OUTPUT),
  15604. 0
  15605. },
  15606. };
  15607. static struct snd_kcontrol_new alc663_mode7_mixer[] = {
  15608. HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch),
  15609. HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol),
  15610. HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch),
  15611. HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x1b, 0x0, HDA_OUTPUT),
  15612. HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT),
  15613. HDA_CODEC_VOLUME("IntMic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15614. HDA_CODEC_MUTE("IntMic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15615. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  15616. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  15617. { } /* end */
  15618. };
  15619. static struct snd_kcontrol_new alc663_mode8_mixer[] = {
  15620. HDA_BIND_SW("Master Playback Switch", &alc663_asus_mode7_8_all_bind_switch),
  15621. HDA_BIND_VOL("Speaker Playback Volume", &alc663_asus_bind_master_vol),
  15622. HDA_BIND_SW("Speaker Playback Switch", &alc663_asus_mode7_8_sp_bind_switch),
  15623. HDA_CODEC_MUTE("Headphone1 Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  15624. HDA_CODEC_MUTE("Headphone2 Playback Switch", 0x21, 0x0, HDA_OUTPUT),
  15625. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  15626. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  15627. { } /* end */
  15628. };
  15629. static struct snd_kcontrol_new alc662_chmode_mixer[] = {
  15630. {
  15631. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  15632. .name = "Channel Mode",
  15633. .info = alc_ch_mode_info,
  15634. .get = alc_ch_mode_get,
  15635. .put = alc_ch_mode_put,
  15636. },
  15637. { } /* end */
  15638. };
  15639. static struct hda_verb alc662_init_verbs[] = {
  15640. /* ADC: mute amp left and right */
  15641. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15642. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  15643. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  15644. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15645. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  15646. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15647. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  15648. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15649. /* Front Pin: output 0 (0x0c) */
  15650. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15651. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15652. /* Rear Pin: output 1 (0x0d) */
  15653. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15654. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15655. /* CLFE Pin: output 2 (0x0e) */
  15656. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15657. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15658. /* Mic (rear) pin: input vref at 80% */
  15659. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  15660. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  15661. /* Front Mic pin: input vref at 80% */
  15662. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  15663. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  15664. /* Line In pin: input */
  15665. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15666. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  15667. /* Line-2 In: Headphone output (output 0 - 0x0c) */
  15668. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15669. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15670. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  15671. /* CD pin widget for input */
  15672. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15673. /* FIXME: use matrix-type input source selection */
  15674. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  15675. /* Input mixer */
  15676. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  15677. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  15678. /* always trun on EAPD */
  15679. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  15680. {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
  15681. { }
  15682. };
  15683. static struct hda_verb alc663_init_verbs[] = {
  15684. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15685. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15686. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15687. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15688. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  15689. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15690. { }
  15691. };
  15692. static struct hda_verb alc272_init_verbs[] = {
  15693. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15694. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  15695. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15696. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15697. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15698. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15699. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  15700. {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15701. { }
  15702. };
  15703. static struct hda_verb alc662_sue_init_verbs[] = {
  15704. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_FRONT_EVENT},
  15705. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_HP_EVENT},
  15706. {}
  15707. };
  15708. static struct hda_verb alc662_eeepc_sue_init_verbs[] = {
  15709. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15710. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15711. {}
  15712. };
  15713. /* Set Unsolicited Event*/
  15714. static struct hda_verb alc662_eeepc_ep20_sue_init_verbs[] = {
  15715. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15716. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15717. {}
  15718. };
  15719. static struct hda_verb alc663_m51va_init_verbs[] = {
  15720. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15721. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15722. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15723. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15724. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15725. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15726. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
  15727. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15728. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15729. {}
  15730. };
  15731. static struct hda_verb alc663_21jd_amic_init_verbs[] = {
  15732. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15733. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15734. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15735. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15736. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15737. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15738. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15739. {}
  15740. };
  15741. static struct hda_verb alc662_1bjd_amic_init_verbs[] = {
  15742. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15743. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15744. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15745. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Headphone */
  15746. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15747. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15748. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15749. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15750. {}
  15751. };
  15752. static struct hda_verb alc663_15jd_amic_init_verbs[] = {
  15753. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15754. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15755. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15756. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15757. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15758. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15759. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15760. {}
  15761. };
  15762. static struct hda_verb alc663_two_hp_amic_m1_init_verbs[] = {
  15763. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15764. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15765. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15766. {0x21, AC_VERB_SET_CONNECT_SEL, 0x0}, /* Headphone */
  15767. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15768. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15769. {0x15, AC_VERB_SET_CONNECT_SEL, 0x0}, /* Headphone */
  15770. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15771. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15772. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15773. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15774. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15775. {}
  15776. };
  15777. static struct hda_verb alc663_two_hp_amic_m2_init_verbs[] = {
  15778. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15779. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15780. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15781. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15782. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15783. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15784. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15785. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15786. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  15787. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15788. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15789. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15790. {}
  15791. };
  15792. static struct hda_verb alc663_g71v_init_verbs[] = {
  15793. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15794. /* {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, */
  15795. /* {0x15, AC_VERB_SET_CONNECT_SEL, 0x01}, */ /* Headphone */
  15796. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15797. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15798. {0x21, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Headphone */
  15799. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_FRONT_EVENT},
  15800. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_MIC_EVENT},
  15801. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN|ALC880_HP_EVENT},
  15802. {}
  15803. };
  15804. static struct hda_verb alc663_g50v_init_verbs[] = {
  15805. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15806. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15807. {0x21, AC_VERB_SET_CONNECT_SEL, 0x00}, /* Headphone */
  15808. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15809. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15810. {}
  15811. };
  15812. static struct hda_verb alc662_ecs_init_verbs[] = {
  15813. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, 0x701f},
  15814. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15815. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15816. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15817. {}
  15818. };
  15819. static struct hda_verb alc272_dell_zm1_init_verbs[] = {
  15820. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15821. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15822. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15823. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15824. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15825. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15826. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15827. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15828. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
  15829. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15830. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15831. {}
  15832. };
  15833. static struct hda_verb alc272_dell_init_verbs[] = {
  15834. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15835. {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15836. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15837. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15838. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15839. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15840. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15841. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15842. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
  15843. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15844. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15845. {}
  15846. };
  15847. static struct hda_verb alc663_mode7_init_verbs[] = {
  15848. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15849. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15850. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15851. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15852. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15853. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15854. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x01},
  15855. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15856. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15857. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15858. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15859. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
  15860. {0x19, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15861. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15862. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15863. {}
  15864. };
  15865. static struct hda_verb alc663_mode8_init_verbs[] = {
  15866. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15867. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15868. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15869. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  15870. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15871. {0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  15872. {0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15873. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  15874. {0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  15875. {0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  15876. {0x21, AC_VERB_SET_CONNECT_SEL, 0x01}, /* Headphone */
  15877. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  15878. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
  15879. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15880. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
  15881. {0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
  15882. {}
  15883. };
  15884. static struct snd_kcontrol_new alc662_auto_capture_mixer[] = {
  15885. HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
  15886. HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
  15887. { } /* end */
  15888. };
  15889. static struct snd_kcontrol_new alc272_auto_capture_mixer[] = {
  15890. HDA_CODEC_VOLUME("Capture Volume", 0x08, 0x0, HDA_INPUT),
  15891. HDA_CODEC_MUTE("Capture Switch", 0x08, 0x0, HDA_INPUT),
  15892. { } /* end */
  15893. };
  15894. static void alc662_lenovo_101e_ispeaker_automute(struct hda_codec *codec)
  15895. {
  15896. unsigned int present;
  15897. unsigned char bits;
  15898. present = snd_hda_jack_detect(codec, 0x14);
  15899. bits = present ? HDA_AMP_MUTE : 0;
  15900. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  15901. HDA_AMP_MUTE, bits);
  15902. }
  15903. static void alc662_lenovo_101e_all_automute(struct hda_codec *codec)
  15904. {
  15905. unsigned int present;
  15906. unsigned char bits;
  15907. present = snd_hda_jack_detect(codec, 0x1b);
  15908. bits = present ? HDA_AMP_MUTE : 0;
  15909. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  15910. HDA_AMP_MUTE, bits);
  15911. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  15912. HDA_AMP_MUTE, bits);
  15913. }
  15914. static void alc662_lenovo_101e_unsol_event(struct hda_codec *codec,
  15915. unsigned int res)
  15916. {
  15917. if ((res >> 26) == ALC880_HP_EVENT)
  15918. alc662_lenovo_101e_all_automute(codec);
  15919. if ((res >> 26) == ALC880_FRONT_EVENT)
  15920. alc662_lenovo_101e_ispeaker_automute(codec);
  15921. }
  15922. /* unsolicited event for HP jack sensing */
  15923. static void alc662_eeepc_unsol_event(struct hda_codec *codec,
  15924. unsigned int res)
  15925. {
  15926. if ((res >> 26) == ALC880_MIC_EVENT)
  15927. alc_mic_automute(codec);
  15928. else
  15929. alc262_hippo_unsol_event(codec, res);
  15930. }
  15931. static void alc662_eeepc_setup(struct hda_codec *codec)
  15932. {
  15933. struct alc_spec *spec = codec->spec;
  15934. alc262_hippo1_setup(codec);
  15935. spec->ext_mic.pin = 0x18;
  15936. spec->ext_mic.mux_idx = 0;
  15937. spec->int_mic.pin = 0x19;
  15938. spec->int_mic.mux_idx = 1;
  15939. spec->auto_mic = 1;
  15940. }
  15941. static void alc662_eeepc_inithook(struct hda_codec *codec)
  15942. {
  15943. alc262_hippo_automute(codec);
  15944. alc_mic_automute(codec);
  15945. }
  15946. static void alc662_eeepc_ep20_setup(struct hda_codec *codec)
  15947. {
  15948. struct alc_spec *spec = codec->spec;
  15949. spec->autocfg.hp_pins[0] = 0x14;
  15950. spec->autocfg.speaker_pins[0] = 0x1b;
  15951. }
  15952. #define alc662_eeepc_ep20_inithook alc262_hippo_master_update
  15953. static void alc663_m51va_speaker_automute(struct hda_codec *codec)
  15954. {
  15955. unsigned int present;
  15956. unsigned char bits;
  15957. present = snd_hda_jack_detect(codec, 0x21);
  15958. bits = present ? HDA_AMP_MUTE : 0;
  15959. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  15960. HDA_AMP_MUTE, bits);
  15961. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  15962. HDA_AMP_MUTE, bits);
  15963. }
  15964. static void alc663_21jd_two_speaker_automute(struct hda_codec *codec)
  15965. {
  15966. unsigned int present;
  15967. unsigned char bits;
  15968. present = snd_hda_jack_detect(codec, 0x21);
  15969. bits = present ? HDA_AMP_MUTE : 0;
  15970. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  15971. HDA_AMP_MUTE, bits);
  15972. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  15973. HDA_AMP_MUTE, bits);
  15974. snd_hda_codec_amp_stereo(codec, 0x0e, HDA_INPUT, 0,
  15975. HDA_AMP_MUTE, bits);
  15976. snd_hda_codec_amp_stereo(codec, 0x0e, HDA_INPUT, 1,
  15977. HDA_AMP_MUTE, bits);
  15978. }
  15979. static void alc663_15jd_two_speaker_automute(struct hda_codec *codec)
  15980. {
  15981. unsigned int present;
  15982. unsigned char bits;
  15983. present = snd_hda_jack_detect(codec, 0x15);
  15984. bits = present ? HDA_AMP_MUTE : 0;
  15985. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  15986. HDA_AMP_MUTE, bits);
  15987. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  15988. HDA_AMP_MUTE, bits);
  15989. snd_hda_codec_amp_stereo(codec, 0x0e, HDA_INPUT, 0,
  15990. HDA_AMP_MUTE, bits);
  15991. snd_hda_codec_amp_stereo(codec, 0x0e, HDA_INPUT, 1,
  15992. HDA_AMP_MUTE, bits);
  15993. }
  15994. static void alc662_f5z_speaker_automute(struct hda_codec *codec)
  15995. {
  15996. unsigned int present;
  15997. unsigned char bits;
  15998. present = snd_hda_jack_detect(codec, 0x1b);
  15999. bits = present ? 0 : PIN_OUT;
  16000. snd_hda_codec_write(codec, 0x14, 0,
  16001. AC_VERB_SET_PIN_WIDGET_CONTROL, bits);
  16002. }
  16003. static void alc663_two_hp_m1_speaker_automute(struct hda_codec *codec)
  16004. {
  16005. unsigned int present1, present2;
  16006. present1 = snd_hda_jack_detect(codec, 0x21);
  16007. present2 = snd_hda_jack_detect(codec, 0x15);
  16008. if (present1 || present2) {
  16009. snd_hda_codec_write_cache(codec, 0x14, 0,
  16010. AC_VERB_SET_PIN_WIDGET_CONTROL, 0);
  16011. } else {
  16012. snd_hda_codec_write_cache(codec, 0x14, 0,
  16013. AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
  16014. }
  16015. }
  16016. static void alc663_two_hp_m2_speaker_automute(struct hda_codec *codec)
  16017. {
  16018. unsigned int present1, present2;
  16019. present1 = snd_hda_jack_detect(codec, 0x1b);
  16020. present2 = snd_hda_jack_detect(codec, 0x15);
  16021. if (present1 || present2) {
  16022. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  16023. HDA_AMP_MUTE, HDA_AMP_MUTE);
  16024. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  16025. HDA_AMP_MUTE, HDA_AMP_MUTE);
  16026. } else {
  16027. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 0,
  16028. HDA_AMP_MUTE, 0);
  16029. snd_hda_codec_amp_stereo(codec, 0x0c, HDA_INPUT, 1,
  16030. HDA_AMP_MUTE, 0);
  16031. }
  16032. }
  16033. static void alc663_two_hp_m7_speaker_automute(struct hda_codec *codec)
  16034. {
  16035. unsigned int present1, present2;
  16036. present1 = snd_hda_codec_read(codec, 0x1b, 0,
  16037. AC_VERB_GET_PIN_SENSE, 0)
  16038. & AC_PINSENSE_PRESENCE;
  16039. present2 = snd_hda_codec_read(codec, 0x21, 0,
  16040. AC_VERB_GET_PIN_SENSE, 0)
  16041. & AC_PINSENSE_PRESENCE;
  16042. if (present1 || present2) {
  16043. snd_hda_codec_write_cache(codec, 0x14, 0,
  16044. AC_VERB_SET_PIN_WIDGET_CONTROL, 0);
  16045. snd_hda_codec_write_cache(codec, 0x17, 0,
  16046. AC_VERB_SET_PIN_WIDGET_CONTROL, 0);
  16047. } else {
  16048. snd_hda_codec_write_cache(codec, 0x14, 0,
  16049. AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
  16050. snd_hda_codec_write_cache(codec, 0x17, 0,
  16051. AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
  16052. }
  16053. }
  16054. static void alc663_two_hp_m8_speaker_automute(struct hda_codec *codec)
  16055. {
  16056. unsigned int present1, present2;
  16057. present1 = snd_hda_codec_read(codec, 0x21, 0,
  16058. AC_VERB_GET_PIN_SENSE, 0)
  16059. & AC_PINSENSE_PRESENCE;
  16060. present2 = snd_hda_codec_read(codec, 0x15, 0,
  16061. AC_VERB_GET_PIN_SENSE, 0)
  16062. & AC_PINSENSE_PRESENCE;
  16063. if (present1 || present2) {
  16064. snd_hda_codec_write_cache(codec, 0x14, 0,
  16065. AC_VERB_SET_PIN_WIDGET_CONTROL, 0);
  16066. snd_hda_codec_write_cache(codec, 0x17, 0,
  16067. AC_VERB_SET_PIN_WIDGET_CONTROL, 0);
  16068. } else {
  16069. snd_hda_codec_write_cache(codec, 0x14, 0,
  16070. AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
  16071. snd_hda_codec_write_cache(codec, 0x17, 0,
  16072. AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT);
  16073. }
  16074. }
  16075. static void alc663_m51va_unsol_event(struct hda_codec *codec,
  16076. unsigned int res)
  16077. {
  16078. switch (res >> 26) {
  16079. case ALC880_HP_EVENT:
  16080. alc663_m51va_speaker_automute(codec);
  16081. break;
  16082. case ALC880_MIC_EVENT:
  16083. alc_mic_automute(codec);
  16084. break;
  16085. }
  16086. }
  16087. static void alc663_m51va_setup(struct hda_codec *codec)
  16088. {
  16089. struct alc_spec *spec = codec->spec;
  16090. spec->ext_mic.pin = 0x18;
  16091. spec->ext_mic.mux_idx = 0;
  16092. spec->int_mic.pin = 0x12;
  16093. spec->int_mic.mux_idx = 9;
  16094. spec->auto_mic = 1;
  16095. }
  16096. static void alc663_m51va_inithook(struct hda_codec *codec)
  16097. {
  16098. alc663_m51va_speaker_automute(codec);
  16099. alc_mic_automute(codec);
  16100. }
  16101. /* ***************** Mode1 ******************************/
  16102. #define alc663_mode1_unsol_event alc663_m51va_unsol_event
  16103. static void alc663_mode1_setup(struct hda_codec *codec)
  16104. {
  16105. struct alc_spec *spec = codec->spec;
  16106. spec->ext_mic.pin = 0x18;
  16107. spec->ext_mic.mux_idx = 0;
  16108. spec->int_mic.pin = 0x19;
  16109. spec->int_mic.mux_idx = 1;
  16110. spec->auto_mic = 1;
  16111. }
  16112. #define alc663_mode1_inithook alc663_m51va_inithook
  16113. /* ***************** Mode2 ******************************/
  16114. static void alc662_mode2_unsol_event(struct hda_codec *codec,
  16115. unsigned int res)
  16116. {
  16117. switch (res >> 26) {
  16118. case ALC880_HP_EVENT:
  16119. alc662_f5z_speaker_automute(codec);
  16120. break;
  16121. case ALC880_MIC_EVENT:
  16122. alc_mic_automute(codec);
  16123. break;
  16124. }
  16125. }
  16126. #define alc662_mode2_setup alc663_mode1_setup
  16127. static void alc662_mode2_inithook(struct hda_codec *codec)
  16128. {
  16129. alc662_f5z_speaker_automute(codec);
  16130. alc_mic_automute(codec);
  16131. }
  16132. /* ***************** Mode3 ******************************/
  16133. static void alc663_mode3_unsol_event(struct hda_codec *codec,
  16134. unsigned int res)
  16135. {
  16136. switch (res >> 26) {
  16137. case ALC880_HP_EVENT:
  16138. alc663_two_hp_m1_speaker_automute(codec);
  16139. break;
  16140. case ALC880_MIC_EVENT:
  16141. alc_mic_automute(codec);
  16142. break;
  16143. }
  16144. }
  16145. #define alc663_mode3_setup alc663_mode1_setup
  16146. static void alc663_mode3_inithook(struct hda_codec *codec)
  16147. {
  16148. alc663_two_hp_m1_speaker_automute(codec);
  16149. alc_mic_automute(codec);
  16150. }
  16151. /* ***************** Mode4 ******************************/
  16152. static void alc663_mode4_unsol_event(struct hda_codec *codec,
  16153. unsigned int res)
  16154. {
  16155. switch (res >> 26) {
  16156. case ALC880_HP_EVENT:
  16157. alc663_21jd_two_speaker_automute(codec);
  16158. break;
  16159. case ALC880_MIC_EVENT:
  16160. alc_mic_automute(codec);
  16161. break;
  16162. }
  16163. }
  16164. #define alc663_mode4_setup alc663_mode1_setup
  16165. static void alc663_mode4_inithook(struct hda_codec *codec)
  16166. {
  16167. alc663_21jd_two_speaker_automute(codec);
  16168. alc_mic_automute(codec);
  16169. }
  16170. /* ***************** Mode5 ******************************/
  16171. static void alc663_mode5_unsol_event(struct hda_codec *codec,
  16172. unsigned int res)
  16173. {
  16174. switch (res >> 26) {
  16175. case ALC880_HP_EVENT:
  16176. alc663_15jd_two_speaker_automute(codec);
  16177. break;
  16178. case ALC880_MIC_EVENT:
  16179. alc_mic_automute(codec);
  16180. break;
  16181. }
  16182. }
  16183. #define alc663_mode5_setup alc663_mode1_setup
  16184. static void alc663_mode5_inithook(struct hda_codec *codec)
  16185. {
  16186. alc663_15jd_two_speaker_automute(codec);
  16187. alc_mic_automute(codec);
  16188. }
  16189. /* ***************** Mode6 ******************************/
  16190. static void alc663_mode6_unsol_event(struct hda_codec *codec,
  16191. unsigned int res)
  16192. {
  16193. switch (res >> 26) {
  16194. case ALC880_HP_EVENT:
  16195. alc663_two_hp_m2_speaker_automute(codec);
  16196. break;
  16197. case ALC880_MIC_EVENT:
  16198. alc_mic_automute(codec);
  16199. break;
  16200. }
  16201. }
  16202. #define alc663_mode6_setup alc663_mode1_setup
  16203. static void alc663_mode6_inithook(struct hda_codec *codec)
  16204. {
  16205. alc663_two_hp_m2_speaker_automute(codec);
  16206. alc_mic_automute(codec);
  16207. }
  16208. /* ***************** Mode7 ******************************/
  16209. static void alc663_mode7_unsol_event(struct hda_codec *codec,
  16210. unsigned int res)
  16211. {
  16212. switch (res >> 26) {
  16213. case ALC880_HP_EVENT:
  16214. alc663_two_hp_m7_speaker_automute(codec);
  16215. break;
  16216. case ALC880_MIC_EVENT:
  16217. alc_mic_automute(codec);
  16218. break;
  16219. }
  16220. }
  16221. #define alc663_mode7_setup alc663_mode1_setup
  16222. static void alc663_mode7_inithook(struct hda_codec *codec)
  16223. {
  16224. alc663_two_hp_m7_speaker_automute(codec);
  16225. alc_mic_automute(codec);
  16226. }
  16227. /* ***************** Mode8 ******************************/
  16228. static void alc663_mode8_unsol_event(struct hda_codec *codec,
  16229. unsigned int res)
  16230. {
  16231. switch (res >> 26) {
  16232. case ALC880_HP_EVENT:
  16233. alc663_two_hp_m8_speaker_automute(codec);
  16234. break;
  16235. case ALC880_MIC_EVENT:
  16236. alc_mic_automute(codec);
  16237. break;
  16238. }
  16239. }
  16240. #define alc663_mode8_setup alc663_m51va_setup
  16241. static void alc663_mode8_inithook(struct hda_codec *codec)
  16242. {
  16243. alc663_two_hp_m8_speaker_automute(codec);
  16244. alc_mic_automute(codec);
  16245. }
  16246. static void alc663_g71v_hp_automute(struct hda_codec *codec)
  16247. {
  16248. unsigned int present;
  16249. unsigned char bits;
  16250. present = snd_hda_jack_detect(codec, 0x21);
  16251. bits = present ? HDA_AMP_MUTE : 0;
  16252. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  16253. HDA_AMP_MUTE, bits);
  16254. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  16255. HDA_AMP_MUTE, bits);
  16256. }
  16257. static void alc663_g71v_front_automute(struct hda_codec *codec)
  16258. {
  16259. unsigned int present;
  16260. unsigned char bits;
  16261. present = snd_hda_jack_detect(codec, 0x15);
  16262. bits = present ? HDA_AMP_MUTE : 0;
  16263. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  16264. HDA_AMP_MUTE, bits);
  16265. }
  16266. static void alc663_g71v_unsol_event(struct hda_codec *codec,
  16267. unsigned int res)
  16268. {
  16269. switch (res >> 26) {
  16270. case ALC880_HP_EVENT:
  16271. alc663_g71v_hp_automute(codec);
  16272. break;
  16273. case ALC880_FRONT_EVENT:
  16274. alc663_g71v_front_automute(codec);
  16275. break;
  16276. case ALC880_MIC_EVENT:
  16277. alc_mic_automute(codec);
  16278. break;
  16279. }
  16280. }
  16281. #define alc663_g71v_setup alc663_m51va_setup
  16282. static void alc663_g71v_inithook(struct hda_codec *codec)
  16283. {
  16284. alc663_g71v_front_automute(codec);
  16285. alc663_g71v_hp_automute(codec);
  16286. alc_mic_automute(codec);
  16287. }
  16288. static void alc663_g50v_unsol_event(struct hda_codec *codec,
  16289. unsigned int res)
  16290. {
  16291. switch (res >> 26) {
  16292. case ALC880_HP_EVENT:
  16293. alc663_m51va_speaker_automute(codec);
  16294. break;
  16295. case ALC880_MIC_EVENT:
  16296. alc_mic_automute(codec);
  16297. break;
  16298. }
  16299. }
  16300. #define alc663_g50v_setup alc663_m51va_setup
  16301. static void alc663_g50v_inithook(struct hda_codec *codec)
  16302. {
  16303. alc663_m51va_speaker_automute(codec);
  16304. alc_mic_automute(codec);
  16305. }
  16306. static struct snd_kcontrol_new alc662_ecs_mixer[] = {
  16307. HDA_CODEC_VOLUME("Master Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  16308. ALC262_HIPPO_MASTER_SWITCH,
  16309. HDA_CODEC_VOLUME("e-Mic/LineIn Boost", 0x18, 0, HDA_INPUT),
  16310. HDA_CODEC_VOLUME("e-Mic/LineIn Playback Volume", 0x0b, 0x0, HDA_INPUT),
  16311. HDA_CODEC_MUTE("e-Mic/LineIn Playback Switch", 0x0b, 0x0, HDA_INPUT),
  16312. HDA_CODEC_VOLUME("i-Mic Boost", 0x19, 0, HDA_INPUT),
  16313. HDA_CODEC_VOLUME("i-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  16314. HDA_CODEC_MUTE("i-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  16315. { } /* end */
  16316. };
  16317. static struct snd_kcontrol_new alc272_nc10_mixer[] = {
  16318. /* Master Playback automatically created from Speaker and Headphone */
  16319. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT),
  16320. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  16321. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT),
  16322. HDA_CODEC_MUTE("Headphone Playback Switch", 0x21, 0x0, HDA_OUTPUT),
  16323. HDA_CODEC_VOLUME("Ext Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  16324. HDA_CODEC_MUTE("Ext Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  16325. HDA_CODEC_VOLUME("Ext Mic Boost", 0x18, 0, HDA_INPUT),
  16326. HDA_CODEC_VOLUME("Int Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  16327. HDA_CODEC_MUTE("Int Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  16328. HDA_CODEC_VOLUME("Int Mic Boost", 0x19, 0, HDA_INPUT),
  16329. { } /* end */
  16330. };
  16331. #ifdef CONFIG_SND_HDA_POWER_SAVE
  16332. #define alc662_loopbacks alc880_loopbacks
  16333. #endif
  16334. /* pcm configuration: identical with ALC880 */
  16335. #define alc662_pcm_analog_playback alc880_pcm_analog_playback
  16336. #define alc662_pcm_analog_capture alc880_pcm_analog_capture
  16337. #define alc662_pcm_digital_playback alc880_pcm_digital_playback
  16338. #define alc662_pcm_digital_capture alc880_pcm_digital_capture
  16339. /*
  16340. * configuration and preset
  16341. */
  16342. static const char *alc662_models[ALC662_MODEL_LAST] = {
  16343. [ALC662_3ST_2ch_DIG] = "3stack-dig",
  16344. [ALC662_3ST_6ch_DIG] = "3stack-6ch-dig",
  16345. [ALC662_3ST_6ch] = "3stack-6ch",
  16346. [ALC662_5ST_DIG] = "6stack-dig",
  16347. [ALC662_LENOVO_101E] = "lenovo-101e",
  16348. [ALC662_ASUS_EEEPC_P701] = "eeepc-p701",
  16349. [ALC662_ASUS_EEEPC_EP20] = "eeepc-ep20",
  16350. [ALC662_ECS] = "ecs",
  16351. [ALC663_ASUS_M51VA] = "m51va",
  16352. [ALC663_ASUS_G71V] = "g71v",
  16353. [ALC663_ASUS_H13] = "h13",
  16354. [ALC663_ASUS_G50V] = "g50v",
  16355. [ALC663_ASUS_MODE1] = "asus-mode1",
  16356. [ALC662_ASUS_MODE2] = "asus-mode2",
  16357. [ALC663_ASUS_MODE3] = "asus-mode3",
  16358. [ALC663_ASUS_MODE4] = "asus-mode4",
  16359. [ALC663_ASUS_MODE5] = "asus-mode5",
  16360. [ALC663_ASUS_MODE6] = "asus-mode6",
  16361. [ALC663_ASUS_MODE7] = "asus-mode7",
  16362. [ALC663_ASUS_MODE8] = "asus-mode8",
  16363. [ALC272_DELL] = "dell",
  16364. [ALC272_DELL_ZM1] = "dell-zm1",
  16365. [ALC272_SAMSUNG_NC10] = "samsung-nc10",
  16366. [ALC662_AUTO] = "auto",
  16367. };
  16368. static struct snd_pci_quirk alc662_cfg_tbl[] = {
  16369. SND_PCI_QUIRK(0x1019, 0x9087, "ECS", ALC662_ECS),
  16370. SND_PCI_QUIRK(0x1028, 0x02d6, "DELL", ALC272_DELL),
  16371. SND_PCI_QUIRK(0x1028, 0x02f4, "DELL ZM1", ALC272_DELL_ZM1),
  16372. SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC663_ASUS_MODE1),
  16373. SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC663_ASUS_MODE3),
  16374. SND_PCI_QUIRK(0x1043, 0x1173, "ASUS K73Jn", ALC663_ASUS_MODE1),
  16375. SND_PCI_QUIRK(0x1043, 0x11c3, "ASUS M70V", ALC663_ASUS_MODE3),
  16376. SND_PCI_QUIRK(0x1043, 0x11d3, "ASUS NB", ALC663_ASUS_MODE1),
  16377. SND_PCI_QUIRK(0x1043, 0x11f3, "ASUS NB", ALC662_ASUS_MODE2),
  16378. SND_PCI_QUIRK(0x1043, 0x1203, "ASUS NB", ALC663_ASUS_MODE1),
  16379. SND_PCI_QUIRK(0x1043, 0x1303, "ASUS G60J", ALC663_ASUS_MODE1),
  16380. SND_PCI_QUIRK(0x1043, 0x1333, "ASUS G60Jx", ALC663_ASUS_MODE1),
  16381. SND_PCI_QUIRK(0x1043, 0x1339, "ASUS NB", ALC662_ASUS_MODE2),
  16382. SND_PCI_QUIRK(0x1043, 0x13e3, "ASUS N71JA", ALC663_ASUS_MODE7),
  16383. SND_PCI_QUIRK(0x1043, 0x1463, "ASUS N71", ALC663_ASUS_MODE7),
  16384. SND_PCI_QUIRK(0x1043, 0x14d3, "ASUS G72", ALC663_ASUS_MODE8),
  16385. SND_PCI_QUIRK(0x1043, 0x1563, "ASUS N90", ALC663_ASUS_MODE3),
  16386. SND_PCI_QUIRK(0x1043, 0x15d3, "ASUS N50SF F50SF", ALC663_ASUS_MODE1),
  16387. SND_PCI_QUIRK(0x1043, 0x16c3, "ASUS NB", ALC662_ASUS_MODE2),
  16388. SND_PCI_QUIRK(0x1043, 0x16f3, "ASUS K40C K50C", ALC662_ASUS_MODE2),
  16389. SND_PCI_QUIRK(0x1043, 0x1733, "ASUS N81De", ALC663_ASUS_MODE1),
  16390. SND_PCI_QUIRK(0x1043, 0x1753, "ASUS NB", ALC662_ASUS_MODE2),
  16391. SND_PCI_QUIRK(0x1043, 0x1763, "ASUS NB", ALC663_ASUS_MODE6),
  16392. SND_PCI_QUIRK(0x1043, 0x1765, "ASUS NB", ALC663_ASUS_MODE6),
  16393. SND_PCI_QUIRK(0x1043, 0x1783, "ASUS NB", ALC662_ASUS_MODE2),
  16394. SND_PCI_QUIRK(0x1043, 0x1793, "ASUS F50GX", ALC663_ASUS_MODE1),
  16395. SND_PCI_QUIRK(0x1043, 0x17b3, "ASUS F70SL", ALC663_ASUS_MODE3),
  16396. SND_PCI_QUIRK(0x1043, 0x17c3, "ASUS UX20", ALC663_ASUS_M51VA),
  16397. SND_PCI_QUIRK(0x1043, 0x17f3, "ASUS X58LE", ALC662_ASUS_MODE2),
  16398. SND_PCI_QUIRK(0x1043, 0x1813, "ASUS NB", ALC662_ASUS_MODE2),
  16399. SND_PCI_QUIRK(0x1043, 0x1823, "ASUS NB", ALC663_ASUS_MODE5),
  16400. SND_PCI_QUIRK(0x1043, 0x1833, "ASUS NB", ALC663_ASUS_MODE6),
  16401. SND_PCI_QUIRK(0x1043, 0x1843, "ASUS NB", ALC662_ASUS_MODE2),
  16402. SND_PCI_QUIRK(0x1043, 0x1853, "ASUS F50Z", ALC663_ASUS_MODE1),
  16403. SND_PCI_QUIRK(0x1043, 0x1864, "ASUS NB", ALC662_ASUS_MODE2),
  16404. SND_PCI_QUIRK(0x1043, 0x1876, "ASUS NB", ALC662_ASUS_MODE2),
  16405. SND_PCI_QUIRK(0x1043, 0x1878, "ASUS M51VA", ALC663_ASUS_M51VA),
  16406. /*SND_PCI_QUIRK(0x1043, 0x1878, "ASUS M50Vr", ALC663_ASUS_MODE1),*/
  16407. SND_PCI_QUIRK(0x1043, 0x1893, "ASUS M50Vm", ALC663_ASUS_MODE3),
  16408. SND_PCI_QUIRK(0x1043, 0x1894, "ASUS X55", ALC663_ASUS_MODE3),
  16409. SND_PCI_QUIRK(0x1043, 0x18b3, "ASUS N80Vc", ALC663_ASUS_MODE1),
  16410. SND_PCI_QUIRK(0x1043, 0x18c3, "ASUS VX5", ALC663_ASUS_MODE1),
  16411. SND_PCI_QUIRK(0x1043, 0x18d3, "ASUS N81Te", ALC663_ASUS_MODE1),
  16412. SND_PCI_QUIRK(0x1043, 0x18f3, "ASUS N505Tp", ALC663_ASUS_MODE1),
  16413. SND_PCI_QUIRK(0x1043, 0x1903, "ASUS F5GL", ALC663_ASUS_MODE1),
  16414. SND_PCI_QUIRK(0x1043, 0x1913, "ASUS NB", ALC662_ASUS_MODE2),
  16415. SND_PCI_QUIRK(0x1043, 0x1933, "ASUS F80Q", ALC662_ASUS_MODE2),
  16416. SND_PCI_QUIRK(0x1043, 0x1943, "ASUS Vx3V", ALC663_ASUS_MODE1),
  16417. SND_PCI_QUIRK(0x1043, 0x1953, "ASUS NB", ALC663_ASUS_MODE1),
  16418. SND_PCI_QUIRK(0x1043, 0x1963, "ASUS X71C", ALC663_ASUS_MODE3),
  16419. SND_PCI_QUIRK(0x1043, 0x1983, "ASUS N5051A", ALC663_ASUS_MODE1),
  16420. SND_PCI_QUIRK(0x1043, 0x1993, "ASUS N20", ALC663_ASUS_MODE1),
  16421. SND_PCI_QUIRK(0x1043, 0x19a3, "ASUS G50V", ALC663_ASUS_G50V),
  16422. /*SND_PCI_QUIRK(0x1043, 0x19a3, "ASUS NB", ALC663_ASUS_MODE1),*/
  16423. SND_PCI_QUIRK(0x1043, 0x19b3, "ASUS F7Z", ALC663_ASUS_MODE1),
  16424. SND_PCI_QUIRK(0x1043, 0x19c3, "ASUS F5Z/F6x", ALC662_ASUS_MODE2),
  16425. SND_PCI_QUIRK(0x1043, 0x19d3, "ASUS NB", ALC663_ASUS_M51VA),
  16426. SND_PCI_QUIRK(0x1043, 0x19e3, "ASUS NB", ALC663_ASUS_MODE1),
  16427. SND_PCI_QUIRK(0x1043, 0x19f3, "ASUS NB", ALC663_ASUS_MODE4),
  16428. SND_PCI_QUIRK(0x1043, 0x8290, "ASUS P5GC-MX", ALC662_3ST_6ch_DIG),
  16429. SND_PCI_QUIRK(0x1043, 0x82a1, "ASUS Eeepc", ALC662_ASUS_EEEPC_P701),
  16430. SND_PCI_QUIRK(0x1043, 0x82d1, "ASUS Eeepc EP20", ALC662_ASUS_EEEPC_EP20),
  16431. SND_PCI_QUIRK(0x105b, 0x0cd6, "Foxconn", ALC662_ECS),
  16432. SND_PCI_QUIRK(0x105b, 0x0d47, "Foxconn 45CMX/45GMX/45CMX-K",
  16433. ALC662_3ST_6ch_DIG),
  16434. SND_PCI_QUIRK(0x1179, 0xff6e, "Toshiba NB20x", ALC662_AUTO),
  16435. SND_PCI_QUIRK(0x144d, 0xca00, "Samsung NC10", ALC272_SAMSUNG_NC10),
  16436. SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte 945GCM-S2L",
  16437. ALC662_3ST_6ch_DIG),
  16438. SND_PCI_QUIRK(0x152d, 0x2304, "Quanta WH1", ALC663_ASUS_H13),
  16439. SND_PCI_QUIRK(0x1565, 0x820f, "Biostar TA780G M2+", ALC662_3ST_6ch_DIG),
  16440. SND_PCI_QUIRK(0x1631, 0xc10c, "PB RS65", ALC663_ASUS_M51VA),
  16441. SND_PCI_QUIRK(0x17aa, 0x101e, "Lenovo", ALC662_LENOVO_101E),
  16442. SND_PCI_QUIRK(0x1849, 0x3662, "ASROCK K10N78FullHD-hSLI R3.0",
  16443. ALC662_3ST_6ch_DIG),
  16444. SND_PCI_QUIRK_MASK(0x1854, 0xf000, 0x2000, "ASUS H13-200x",
  16445. ALC663_ASUS_H13),
  16446. {}
  16447. };
  16448. static struct alc_config_preset alc662_presets[] = {
  16449. [ALC662_3ST_2ch_DIG] = {
  16450. .mixers = { alc662_3ST_2ch_mixer },
  16451. .init_verbs = { alc662_init_verbs },
  16452. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16453. .dac_nids = alc662_dac_nids,
  16454. .dig_out_nid = ALC662_DIGOUT_NID,
  16455. .dig_in_nid = ALC662_DIGIN_NID,
  16456. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16457. .channel_mode = alc662_3ST_2ch_modes,
  16458. .input_mux = &alc662_capture_source,
  16459. },
  16460. [ALC662_3ST_6ch_DIG] = {
  16461. .mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer },
  16462. .init_verbs = { alc662_init_verbs },
  16463. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16464. .dac_nids = alc662_dac_nids,
  16465. .dig_out_nid = ALC662_DIGOUT_NID,
  16466. .dig_in_nid = ALC662_DIGIN_NID,
  16467. .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
  16468. .channel_mode = alc662_3ST_6ch_modes,
  16469. .need_dac_fix = 1,
  16470. .input_mux = &alc662_capture_source,
  16471. },
  16472. [ALC662_3ST_6ch] = {
  16473. .mixers = { alc662_3ST_6ch_mixer, alc662_chmode_mixer },
  16474. .init_verbs = { alc662_init_verbs },
  16475. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16476. .dac_nids = alc662_dac_nids,
  16477. .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
  16478. .channel_mode = alc662_3ST_6ch_modes,
  16479. .need_dac_fix = 1,
  16480. .input_mux = &alc662_capture_source,
  16481. },
  16482. [ALC662_5ST_DIG] = {
  16483. .mixers = { alc662_base_mixer, alc662_chmode_mixer },
  16484. .init_verbs = { alc662_init_verbs },
  16485. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16486. .dac_nids = alc662_dac_nids,
  16487. .dig_out_nid = ALC662_DIGOUT_NID,
  16488. .dig_in_nid = ALC662_DIGIN_NID,
  16489. .num_channel_mode = ARRAY_SIZE(alc662_5stack_modes),
  16490. .channel_mode = alc662_5stack_modes,
  16491. .input_mux = &alc662_capture_source,
  16492. },
  16493. [ALC662_LENOVO_101E] = {
  16494. .mixers = { alc662_lenovo_101e_mixer },
  16495. .init_verbs = { alc662_init_verbs, alc662_sue_init_verbs },
  16496. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16497. .dac_nids = alc662_dac_nids,
  16498. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16499. .channel_mode = alc662_3ST_2ch_modes,
  16500. .input_mux = &alc662_lenovo_101e_capture_source,
  16501. .unsol_event = alc662_lenovo_101e_unsol_event,
  16502. .init_hook = alc662_lenovo_101e_all_automute,
  16503. },
  16504. [ALC662_ASUS_EEEPC_P701] = {
  16505. .mixers = { alc662_eeepc_p701_mixer },
  16506. .init_verbs = { alc662_init_verbs,
  16507. alc662_eeepc_sue_init_verbs },
  16508. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16509. .dac_nids = alc662_dac_nids,
  16510. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16511. .channel_mode = alc662_3ST_2ch_modes,
  16512. .unsol_event = alc662_eeepc_unsol_event,
  16513. .setup = alc662_eeepc_setup,
  16514. .init_hook = alc662_eeepc_inithook,
  16515. },
  16516. [ALC662_ASUS_EEEPC_EP20] = {
  16517. .mixers = { alc662_eeepc_ep20_mixer,
  16518. alc662_chmode_mixer },
  16519. .init_verbs = { alc662_init_verbs,
  16520. alc662_eeepc_ep20_sue_init_verbs },
  16521. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16522. .dac_nids = alc662_dac_nids,
  16523. .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
  16524. .channel_mode = alc662_3ST_6ch_modes,
  16525. .input_mux = &alc662_lenovo_101e_capture_source,
  16526. .unsol_event = alc662_eeepc_unsol_event,
  16527. .setup = alc662_eeepc_ep20_setup,
  16528. .init_hook = alc662_eeepc_ep20_inithook,
  16529. },
  16530. [ALC662_ECS] = {
  16531. .mixers = { alc662_ecs_mixer },
  16532. .init_verbs = { alc662_init_verbs,
  16533. alc662_ecs_init_verbs },
  16534. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16535. .dac_nids = alc662_dac_nids,
  16536. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16537. .channel_mode = alc662_3ST_2ch_modes,
  16538. .unsol_event = alc662_eeepc_unsol_event,
  16539. .setup = alc662_eeepc_setup,
  16540. .init_hook = alc662_eeepc_inithook,
  16541. },
  16542. [ALC663_ASUS_M51VA] = {
  16543. .mixers = { alc663_m51va_mixer },
  16544. .init_verbs = { alc662_init_verbs, alc663_m51va_init_verbs },
  16545. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16546. .dac_nids = alc662_dac_nids,
  16547. .dig_out_nid = ALC662_DIGOUT_NID,
  16548. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16549. .channel_mode = alc662_3ST_2ch_modes,
  16550. .unsol_event = alc663_m51va_unsol_event,
  16551. .setup = alc663_m51va_setup,
  16552. .init_hook = alc663_m51va_inithook,
  16553. },
  16554. [ALC663_ASUS_G71V] = {
  16555. .mixers = { alc663_g71v_mixer },
  16556. .init_verbs = { alc662_init_verbs, alc663_g71v_init_verbs },
  16557. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16558. .dac_nids = alc662_dac_nids,
  16559. .dig_out_nid = ALC662_DIGOUT_NID,
  16560. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16561. .channel_mode = alc662_3ST_2ch_modes,
  16562. .unsol_event = alc663_g71v_unsol_event,
  16563. .setup = alc663_g71v_setup,
  16564. .init_hook = alc663_g71v_inithook,
  16565. },
  16566. [ALC663_ASUS_H13] = {
  16567. .mixers = { alc663_m51va_mixer },
  16568. .init_verbs = { alc662_init_verbs, alc663_m51va_init_verbs },
  16569. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16570. .dac_nids = alc662_dac_nids,
  16571. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16572. .channel_mode = alc662_3ST_2ch_modes,
  16573. .unsol_event = alc663_m51va_unsol_event,
  16574. .init_hook = alc663_m51va_inithook,
  16575. },
  16576. [ALC663_ASUS_G50V] = {
  16577. .mixers = { alc663_g50v_mixer },
  16578. .init_verbs = { alc662_init_verbs, alc663_g50v_init_verbs },
  16579. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16580. .dac_nids = alc662_dac_nids,
  16581. .dig_out_nid = ALC662_DIGOUT_NID,
  16582. .num_channel_mode = ARRAY_SIZE(alc662_3ST_6ch_modes),
  16583. .channel_mode = alc662_3ST_6ch_modes,
  16584. .input_mux = &alc663_capture_source,
  16585. .unsol_event = alc663_g50v_unsol_event,
  16586. .setup = alc663_g50v_setup,
  16587. .init_hook = alc663_g50v_inithook,
  16588. },
  16589. [ALC663_ASUS_MODE1] = {
  16590. .mixers = { alc663_m51va_mixer },
  16591. .cap_mixer = alc662_auto_capture_mixer,
  16592. .init_verbs = { alc662_init_verbs,
  16593. alc663_21jd_amic_init_verbs },
  16594. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16595. .hp_nid = 0x03,
  16596. .dac_nids = alc662_dac_nids,
  16597. .dig_out_nid = ALC662_DIGOUT_NID,
  16598. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16599. .channel_mode = alc662_3ST_2ch_modes,
  16600. .unsol_event = alc663_mode1_unsol_event,
  16601. .setup = alc663_mode1_setup,
  16602. .init_hook = alc663_mode1_inithook,
  16603. },
  16604. [ALC662_ASUS_MODE2] = {
  16605. .mixers = { alc662_1bjd_mixer },
  16606. .cap_mixer = alc662_auto_capture_mixer,
  16607. .init_verbs = { alc662_init_verbs,
  16608. alc662_1bjd_amic_init_verbs },
  16609. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16610. .dac_nids = alc662_dac_nids,
  16611. .dig_out_nid = ALC662_DIGOUT_NID,
  16612. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16613. .channel_mode = alc662_3ST_2ch_modes,
  16614. .unsol_event = alc662_mode2_unsol_event,
  16615. .setup = alc662_mode2_setup,
  16616. .init_hook = alc662_mode2_inithook,
  16617. },
  16618. [ALC663_ASUS_MODE3] = {
  16619. .mixers = { alc663_two_hp_m1_mixer },
  16620. .cap_mixer = alc662_auto_capture_mixer,
  16621. .init_verbs = { alc662_init_verbs,
  16622. alc663_two_hp_amic_m1_init_verbs },
  16623. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16624. .hp_nid = 0x03,
  16625. .dac_nids = alc662_dac_nids,
  16626. .dig_out_nid = ALC662_DIGOUT_NID,
  16627. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16628. .channel_mode = alc662_3ST_2ch_modes,
  16629. .unsol_event = alc663_mode3_unsol_event,
  16630. .setup = alc663_mode3_setup,
  16631. .init_hook = alc663_mode3_inithook,
  16632. },
  16633. [ALC663_ASUS_MODE4] = {
  16634. .mixers = { alc663_asus_21jd_clfe_mixer },
  16635. .cap_mixer = alc662_auto_capture_mixer,
  16636. .init_verbs = { alc662_init_verbs,
  16637. alc663_21jd_amic_init_verbs},
  16638. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16639. .hp_nid = 0x03,
  16640. .dac_nids = alc662_dac_nids,
  16641. .dig_out_nid = ALC662_DIGOUT_NID,
  16642. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16643. .channel_mode = alc662_3ST_2ch_modes,
  16644. .unsol_event = alc663_mode4_unsol_event,
  16645. .setup = alc663_mode4_setup,
  16646. .init_hook = alc663_mode4_inithook,
  16647. },
  16648. [ALC663_ASUS_MODE5] = {
  16649. .mixers = { alc663_asus_15jd_clfe_mixer },
  16650. .cap_mixer = alc662_auto_capture_mixer,
  16651. .init_verbs = { alc662_init_verbs,
  16652. alc663_15jd_amic_init_verbs },
  16653. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16654. .hp_nid = 0x03,
  16655. .dac_nids = alc662_dac_nids,
  16656. .dig_out_nid = ALC662_DIGOUT_NID,
  16657. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16658. .channel_mode = alc662_3ST_2ch_modes,
  16659. .unsol_event = alc663_mode5_unsol_event,
  16660. .setup = alc663_mode5_setup,
  16661. .init_hook = alc663_mode5_inithook,
  16662. },
  16663. [ALC663_ASUS_MODE6] = {
  16664. .mixers = { alc663_two_hp_m2_mixer },
  16665. .cap_mixer = alc662_auto_capture_mixer,
  16666. .init_verbs = { alc662_init_verbs,
  16667. alc663_two_hp_amic_m2_init_verbs },
  16668. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16669. .hp_nid = 0x03,
  16670. .dac_nids = alc662_dac_nids,
  16671. .dig_out_nid = ALC662_DIGOUT_NID,
  16672. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16673. .channel_mode = alc662_3ST_2ch_modes,
  16674. .unsol_event = alc663_mode6_unsol_event,
  16675. .setup = alc663_mode6_setup,
  16676. .init_hook = alc663_mode6_inithook,
  16677. },
  16678. [ALC663_ASUS_MODE7] = {
  16679. .mixers = { alc663_mode7_mixer },
  16680. .cap_mixer = alc662_auto_capture_mixer,
  16681. .init_verbs = { alc662_init_verbs,
  16682. alc663_mode7_init_verbs },
  16683. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16684. .hp_nid = 0x03,
  16685. .dac_nids = alc662_dac_nids,
  16686. .dig_out_nid = ALC662_DIGOUT_NID,
  16687. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16688. .channel_mode = alc662_3ST_2ch_modes,
  16689. .unsol_event = alc663_mode7_unsol_event,
  16690. .setup = alc663_mode7_setup,
  16691. .init_hook = alc663_mode7_inithook,
  16692. },
  16693. [ALC663_ASUS_MODE8] = {
  16694. .mixers = { alc663_mode8_mixer },
  16695. .cap_mixer = alc662_auto_capture_mixer,
  16696. .init_verbs = { alc662_init_verbs,
  16697. alc663_mode8_init_verbs },
  16698. .num_dacs = ARRAY_SIZE(alc662_dac_nids),
  16699. .hp_nid = 0x03,
  16700. .dac_nids = alc662_dac_nids,
  16701. .dig_out_nid = ALC662_DIGOUT_NID,
  16702. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16703. .channel_mode = alc662_3ST_2ch_modes,
  16704. .unsol_event = alc663_mode8_unsol_event,
  16705. .setup = alc663_mode8_setup,
  16706. .init_hook = alc663_mode8_inithook,
  16707. },
  16708. [ALC272_DELL] = {
  16709. .mixers = { alc663_m51va_mixer },
  16710. .cap_mixer = alc272_auto_capture_mixer,
  16711. .init_verbs = { alc662_init_verbs, alc272_dell_init_verbs },
  16712. .num_dacs = ARRAY_SIZE(alc272_dac_nids),
  16713. .dac_nids = alc662_dac_nids,
  16714. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16715. .adc_nids = alc272_adc_nids,
  16716. .num_adc_nids = ARRAY_SIZE(alc272_adc_nids),
  16717. .capsrc_nids = alc272_capsrc_nids,
  16718. .channel_mode = alc662_3ST_2ch_modes,
  16719. .unsol_event = alc663_m51va_unsol_event,
  16720. .setup = alc663_m51va_setup,
  16721. .init_hook = alc663_m51va_inithook,
  16722. },
  16723. [ALC272_DELL_ZM1] = {
  16724. .mixers = { alc663_m51va_mixer },
  16725. .cap_mixer = alc662_auto_capture_mixer,
  16726. .init_verbs = { alc662_init_verbs, alc272_dell_zm1_init_verbs },
  16727. .num_dacs = ARRAY_SIZE(alc272_dac_nids),
  16728. .dac_nids = alc662_dac_nids,
  16729. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16730. .adc_nids = alc662_adc_nids,
  16731. .num_adc_nids = 1,
  16732. .capsrc_nids = alc662_capsrc_nids,
  16733. .channel_mode = alc662_3ST_2ch_modes,
  16734. .unsol_event = alc663_m51va_unsol_event,
  16735. .setup = alc663_m51va_setup,
  16736. .init_hook = alc663_m51va_inithook,
  16737. },
  16738. [ALC272_SAMSUNG_NC10] = {
  16739. .mixers = { alc272_nc10_mixer },
  16740. .init_verbs = { alc662_init_verbs,
  16741. alc663_21jd_amic_init_verbs },
  16742. .num_dacs = ARRAY_SIZE(alc272_dac_nids),
  16743. .dac_nids = alc272_dac_nids,
  16744. .num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
  16745. .channel_mode = alc662_3ST_2ch_modes,
  16746. /*.input_mux = &alc272_nc10_capture_source,*/
  16747. .unsol_event = alc663_mode4_unsol_event,
  16748. .setup = alc663_mode4_setup,
  16749. .init_hook = alc663_mode4_inithook,
  16750. },
  16751. };
  16752. /*
  16753. * BIOS auto configuration
  16754. */
  16755. /* convert from MIX nid to DAC */
  16756. static inline hda_nid_t alc662_mix_to_dac(hda_nid_t nid)
  16757. {
  16758. if (nid == 0x0f)
  16759. return 0x02;
  16760. else if (nid >= 0x0c && nid <= 0x0e)
  16761. return nid - 0x0c + 0x02;
  16762. else
  16763. return 0;
  16764. }
  16765. /* get MIX nid connected to the given pin targeted to DAC */
  16766. static hda_nid_t alc662_dac_to_mix(struct hda_codec *codec, hda_nid_t pin,
  16767. hda_nid_t dac)
  16768. {
  16769. hda_nid_t mix[4];
  16770. int i, num;
  16771. num = snd_hda_get_connections(codec, pin, mix, ARRAY_SIZE(mix));
  16772. for (i = 0; i < num; i++) {
  16773. if (alc662_mix_to_dac(mix[i]) == dac)
  16774. return mix[i];
  16775. }
  16776. return 0;
  16777. }
  16778. /* look for an empty DAC slot */
  16779. static hda_nid_t alc662_look_for_dac(struct hda_codec *codec, hda_nid_t pin)
  16780. {
  16781. struct alc_spec *spec = codec->spec;
  16782. hda_nid_t srcs[5];
  16783. int i, j, num;
  16784. num = snd_hda_get_connections(codec, pin, srcs, ARRAY_SIZE(srcs));
  16785. if (num < 0)
  16786. return 0;
  16787. for (i = 0; i < num; i++) {
  16788. hda_nid_t nid = alc662_mix_to_dac(srcs[i]);
  16789. if (!nid)
  16790. continue;
  16791. for (j = 0; j < spec->multiout.num_dacs; j++)
  16792. if (spec->multiout.dac_nids[j] == nid)
  16793. break;
  16794. if (j >= spec->multiout.num_dacs)
  16795. return nid;
  16796. }
  16797. return 0;
  16798. }
  16799. /* fill in the dac_nids table from the parsed pin configuration */
  16800. static int alc662_auto_fill_dac_nids(struct hda_codec *codec,
  16801. const struct auto_pin_cfg *cfg)
  16802. {
  16803. struct alc_spec *spec = codec->spec;
  16804. int i;
  16805. hda_nid_t dac;
  16806. spec->multiout.dac_nids = spec->private_dac_nids;
  16807. for (i = 0; i < cfg->line_outs; i++) {
  16808. dac = alc662_look_for_dac(codec, cfg->line_out_pins[i]);
  16809. if (!dac)
  16810. continue;
  16811. spec->multiout.dac_nids[spec->multiout.num_dacs++] = dac;
  16812. }
  16813. return 0;
  16814. }
  16815. static inline int alc662_add_vol_ctl(struct alc_spec *spec, const char *pfx,
  16816. hda_nid_t nid, unsigned int chs)
  16817. {
  16818. return add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, pfx,
  16819. HDA_COMPOSE_AMP_VAL(nid, chs, 0, HDA_OUTPUT));
  16820. }
  16821. static inline int alc662_add_sw_ctl(struct alc_spec *spec, const char *pfx,
  16822. hda_nid_t nid, unsigned int chs)
  16823. {
  16824. return add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, pfx,
  16825. HDA_COMPOSE_AMP_VAL(nid, chs, 0, HDA_INPUT));
  16826. }
  16827. #define alc662_add_stereo_vol(spec, pfx, nid) \
  16828. alc662_add_vol_ctl(spec, pfx, nid, 3)
  16829. #define alc662_add_stereo_sw(spec, pfx, nid) \
  16830. alc662_add_sw_ctl(spec, pfx, nid, 3)
  16831. /* add playback controls from the parsed DAC table */
  16832. static int alc662_auto_create_multi_out_ctls(struct hda_codec *codec,
  16833. const struct auto_pin_cfg *cfg)
  16834. {
  16835. struct alc_spec *spec = codec->spec;
  16836. static const char *chname[4] = {
  16837. "Front", "Surround", NULL /*CLFE*/, "Side"
  16838. };
  16839. hda_nid_t nid, mix;
  16840. int i, err;
  16841. for (i = 0; i < cfg->line_outs; i++) {
  16842. nid = spec->multiout.dac_nids[i];
  16843. if (!nid)
  16844. continue;
  16845. mix = alc662_dac_to_mix(codec, cfg->line_out_pins[i], nid);
  16846. if (!mix)
  16847. continue;
  16848. if (i == 2) {
  16849. /* Center/LFE */
  16850. err = alc662_add_vol_ctl(spec, "Center", nid, 1);
  16851. if (err < 0)
  16852. return err;
  16853. err = alc662_add_vol_ctl(spec, "LFE", nid, 2);
  16854. if (err < 0)
  16855. return err;
  16856. err = alc662_add_sw_ctl(spec, "Center", mix, 1);
  16857. if (err < 0)
  16858. return err;
  16859. err = alc662_add_sw_ctl(spec, "LFE", mix, 2);
  16860. if (err < 0)
  16861. return err;
  16862. } else {
  16863. const char *pfx;
  16864. if (cfg->line_outs == 1 &&
  16865. cfg->line_out_type == AUTO_PIN_SPEAKER_OUT) {
  16866. if (cfg->hp_outs)
  16867. pfx = "Speaker";
  16868. else
  16869. pfx = "PCM";
  16870. } else
  16871. pfx = chname[i];
  16872. err = alc662_add_vol_ctl(spec, pfx, nid, 3);
  16873. if (err < 0)
  16874. return err;
  16875. if (cfg->line_outs == 1 &&
  16876. cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  16877. pfx = "Speaker";
  16878. err = alc662_add_sw_ctl(spec, pfx, mix, 3);
  16879. if (err < 0)
  16880. return err;
  16881. }
  16882. }
  16883. return 0;
  16884. }
  16885. /* add playback controls for speaker and HP outputs */
  16886. /* return DAC nid if any new DAC is assigned */
  16887. static int alc662_auto_create_extra_out(struct hda_codec *codec, hda_nid_t pin,
  16888. const char *pfx)
  16889. {
  16890. struct alc_spec *spec = codec->spec;
  16891. hda_nid_t nid, mix;
  16892. int err;
  16893. if (!pin)
  16894. return 0;
  16895. nid = alc662_look_for_dac(codec, pin);
  16896. if (!nid) {
  16897. /* the corresponding DAC is already occupied */
  16898. if (!(get_wcaps(codec, pin) & AC_WCAP_OUT_AMP))
  16899. return 0; /* no way */
  16900. /* create a switch only */
  16901. return add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, pfx,
  16902. HDA_COMPOSE_AMP_VAL(pin, 3, 0, HDA_OUTPUT));
  16903. }
  16904. mix = alc662_dac_to_mix(codec, pin, nid);
  16905. if (!mix)
  16906. return 0;
  16907. err = alc662_add_vol_ctl(spec, pfx, nid, 3);
  16908. if (err < 0)
  16909. return err;
  16910. err = alc662_add_sw_ctl(spec, pfx, mix, 3);
  16911. if (err < 0)
  16912. return err;
  16913. return nid;
  16914. }
  16915. /* create playback/capture controls for input pins */
  16916. #define alc662_auto_create_input_ctls \
  16917. alc882_auto_create_input_ctls
  16918. static void alc662_auto_set_output_and_unmute(struct hda_codec *codec,
  16919. hda_nid_t nid, int pin_type,
  16920. hda_nid_t dac)
  16921. {
  16922. int i, num;
  16923. hda_nid_t srcs[HDA_MAX_CONNECTIONS];
  16924. alc_set_pin_output(codec, nid, pin_type);
  16925. /* need the manual connection? */
  16926. num = snd_hda_get_connections(codec, nid, srcs, ARRAY_SIZE(srcs));
  16927. if (num <= 1)
  16928. return;
  16929. for (i = 0; i < num; i++) {
  16930. if (alc662_mix_to_dac(srcs[i]) != dac)
  16931. continue;
  16932. snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_CONNECT_SEL, i);
  16933. return;
  16934. }
  16935. }
  16936. static void alc662_auto_init_multi_out(struct hda_codec *codec)
  16937. {
  16938. struct alc_spec *spec = codec->spec;
  16939. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  16940. int i;
  16941. for (i = 0; i <= HDA_SIDE; i++) {
  16942. hda_nid_t nid = spec->autocfg.line_out_pins[i];
  16943. if (nid)
  16944. alc662_auto_set_output_and_unmute(codec, nid, pin_type,
  16945. spec->multiout.dac_nids[i]);
  16946. }
  16947. }
  16948. static void alc662_auto_init_hp_out(struct hda_codec *codec)
  16949. {
  16950. struct alc_spec *spec = codec->spec;
  16951. hda_nid_t pin;
  16952. pin = spec->autocfg.hp_pins[0];
  16953. if (pin)
  16954. alc662_auto_set_output_and_unmute(codec, pin, PIN_HP,
  16955. spec->multiout.hp_nid);
  16956. pin = spec->autocfg.speaker_pins[0];
  16957. if (pin)
  16958. alc662_auto_set_output_and_unmute(codec, pin, PIN_OUT,
  16959. spec->multiout.extra_out_nid[0]);
  16960. }
  16961. #define ALC662_PIN_CD_NID ALC880_PIN_CD_NID
  16962. static void alc662_auto_init_analog_input(struct hda_codec *codec)
  16963. {
  16964. struct alc_spec *spec = codec->spec;
  16965. int i;
  16966. for (i = 0; i < AUTO_PIN_LAST; i++) {
  16967. hda_nid_t nid = spec->autocfg.input_pins[i];
  16968. if (alc_is_input_pin(codec, nid)) {
  16969. alc_set_input_pin(codec, nid, i);
  16970. if (nid != ALC662_PIN_CD_NID &&
  16971. (get_wcaps(codec, nid) & AC_WCAP_OUT_AMP))
  16972. snd_hda_codec_write(codec, nid, 0,
  16973. AC_VERB_SET_AMP_GAIN_MUTE,
  16974. AMP_OUT_MUTE);
  16975. }
  16976. }
  16977. }
  16978. #define alc662_auto_init_input_src alc882_auto_init_input_src
  16979. static int alc662_parse_auto_config(struct hda_codec *codec)
  16980. {
  16981. struct alc_spec *spec = codec->spec;
  16982. int err;
  16983. static hda_nid_t alc662_ignore[] = { 0x1d, 0 };
  16984. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  16985. alc662_ignore);
  16986. if (err < 0)
  16987. return err;
  16988. if (!spec->autocfg.line_outs)
  16989. return 0; /* can't find valid BIOS pin config */
  16990. err = alc662_auto_fill_dac_nids(codec, &spec->autocfg);
  16991. if (err < 0)
  16992. return err;
  16993. err = alc662_auto_create_multi_out_ctls(codec, &spec->autocfg);
  16994. if (err < 0)
  16995. return err;
  16996. err = alc662_auto_create_extra_out(codec,
  16997. spec->autocfg.speaker_pins[0],
  16998. "Speaker");
  16999. if (err < 0)
  17000. return err;
  17001. if (err)
  17002. spec->multiout.extra_out_nid[0] = err;
  17003. err = alc662_auto_create_extra_out(codec, spec->autocfg.hp_pins[0],
  17004. "Headphone");
  17005. if (err < 0)
  17006. return err;
  17007. if (err)
  17008. spec->multiout.hp_nid = err;
  17009. err = alc662_auto_create_input_ctls(codec, &spec->autocfg);
  17010. if (err < 0)
  17011. return err;
  17012. spec->multiout.max_channels = spec->multiout.num_dacs * 2;
  17013. alc_auto_parse_digital(codec);
  17014. if (spec->kctls.list)
  17015. add_mixer(spec, spec->kctls.list);
  17016. spec->num_mux_defs = 1;
  17017. spec->input_mux = &spec->private_imux[0];
  17018. add_verb(spec, alc662_init_verbs);
  17019. if (codec->vendor_id == 0x10ec0272 || codec->vendor_id == 0x10ec0663 ||
  17020. codec->vendor_id == 0x10ec0665 || codec->vendor_id == 0x10ec0670)
  17021. add_verb(spec, alc663_init_verbs);
  17022. if (codec->vendor_id == 0x10ec0272)
  17023. add_verb(spec, alc272_init_verbs);
  17024. err = alc_auto_add_mic_boost(codec);
  17025. if (err < 0)
  17026. return err;
  17027. if (codec->vendor_id == 0x10ec0272 || codec->vendor_id == 0x10ec0663 ||
  17028. codec->vendor_id == 0x10ec0665 || codec->vendor_id == 0x10ec0670)
  17029. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0x21);
  17030. else
  17031. alc_ssid_check(codec, 0x15, 0x1b, 0x14, 0);
  17032. return 1;
  17033. }
  17034. /* additional initialization for auto-configuration model */
  17035. static void alc662_auto_init(struct hda_codec *codec)
  17036. {
  17037. struct alc_spec *spec = codec->spec;
  17038. alc662_auto_init_multi_out(codec);
  17039. alc662_auto_init_hp_out(codec);
  17040. alc662_auto_init_analog_input(codec);
  17041. alc662_auto_init_input_src(codec);
  17042. alc_auto_init_digital(codec);
  17043. if (spec->unsol_event)
  17044. alc_inithook(codec);
  17045. }
  17046. static int patch_alc662(struct hda_codec *codec)
  17047. {
  17048. struct alc_spec *spec;
  17049. int err, board_config;
  17050. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  17051. if (!spec)
  17052. return -ENOMEM;
  17053. codec->spec = spec;
  17054. alc_auto_parse_customize_define(codec);
  17055. alc_fix_pll_init(codec, 0x20, 0x04, 15);
  17056. if (alc_read_coef_idx(codec, 0) == 0x8020)
  17057. alc_codec_rename(codec, "ALC661");
  17058. else if ((alc_read_coef_idx(codec, 0) & (1 << 14)) &&
  17059. codec->bus->pci->subsystem_vendor == 0x1025 &&
  17060. spec->cdefine.platform_type == 1)
  17061. alc_codec_rename(codec, "ALC272X");
  17062. board_config = snd_hda_check_board_config(codec, ALC662_MODEL_LAST,
  17063. alc662_models,
  17064. alc662_cfg_tbl);
  17065. if (board_config < 0) {
  17066. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  17067. codec->chip_name);
  17068. board_config = ALC662_AUTO;
  17069. }
  17070. if (board_config == ALC662_AUTO) {
  17071. /* automatic parse from the BIOS config */
  17072. err = alc662_parse_auto_config(codec);
  17073. if (err < 0) {
  17074. alc_free(codec);
  17075. return err;
  17076. } else if (!err) {
  17077. printk(KERN_INFO
  17078. "hda_codec: Cannot set up configuration "
  17079. "from BIOS. Using base mode...\n");
  17080. board_config = ALC662_3ST_2ch_DIG;
  17081. }
  17082. }
  17083. if (has_cdefine_beep(codec)) {
  17084. err = snd_hda_attach_beep_device(codec, 0x1);
  17085. if (err < 0) {
  17086. alc_free(codec);
  17087. return err;
  17088. }
  17089. }
  17090. if (board_config != ALC662_AUTO)
  17091. setup_preset(codec, &alc662_presets[board_config]);
  17092. spec->stream_analog_playback = &alc662_pcm_analog_playback;
  17093. spec->stream_analog_capture = &alc662_pcm_analog_capture;
  17094. spec->stream_digital_playback = &alc662_pcm_digital_playback;
  17095. spec->stream_digital_capture = &alc662_pcm_digital_capture;
  17096. if (!spec->adc_nids) {
  17097. spec->adc_nids = alc662_adc_nids;
  17098. spec->num_adc_nids = ARRAY_SIZE(alc662_adc_nids);
  17099. }
  17100. if (!spec->capsrc_nids)
  17101. spec->capsrc_nids = alc662_capsrc_nids;
  17102. if (!spec->cap_mixer)
  17103. set_capture_mixer(codec);
  17104. if (has_cdefine_beep(codec)) {
  17105. switch (codec->vendor_id) {
  17106. case 0x10ec0662:
  17107. set_beep_amp(spec, 0x0b, 0x05, HDA_INPUT);
  17108. break;
  17109. case 0x10ec0272:
  17110. case 0x10ec0663:
  17111. case 0x10ec0665:
  17112. set_beep_amp(spec, 0x0b, 0x04, HDA_INPUT);
  17113. break;
  17114. case 0x10ec0273:
  17115. set_beep_amp(spec, 0x0b, 0x03, HDA_INPUT);
  17116. break;
  17117. }
  17118. }
  17119. spec->vmaster_nid = 0x02;
  17120. codec->patch_ops = alc_patch_ops;
  17121. if (board_config == ALC662_AUTO)
  17122. spec->init_hook = alc662_auto_init;
  17123. #ifdef CONFIG_SND_HDA_POWER_SAVE
  17124. if (!spec->loopback.amplist)
  17125. spec->loopback.amplist = alc662_loopbacks;
  17126. #endif
  17127. return 0;
  17128. }
  17129. static int patch_alc888(struct hda_codec *codec)
  17130. {
  17131. if ((alc_read_coef_idx(codec, 0) & 0x00f0)==0x0030){
  17132. kfree(codec->chip_name);
  17133. codec->chip_name = kstrdup("ALC888-VD", GFP_KERNEL);
  17134. if (!codec->chip_name) {
  17135. alc_free(codec);
  17136. return -ENOMEM;
  17137. }
  17138. return patch_alc662(codec);
  17139. }
  17140. return patch_alc882(codec);
  17141. }
  17142. /*
  17143. * ALC680 support
  17144. */
  17145. #define ALC680_DIGIN_NID ALC880_DIGIN_NID
  17146. #define ALC680_DIGOUT_NID ALC880_DIGOUT_NID
  17147. #define alc680_modes alc260_modes
  17148. static hda_nid_t alc680_dac_nids[3] = {
  17149. /* Lout1, Lout2, hp */
  17150. 0x02, 0x03, 0x04
  17151. };
  17152. static hda_nid_t alc680_adc_nids[3] = {
  17153. /* ADC0-2 */
  17154. /* DMIC, MIC, Line-in*/
  17155. 0x07, 0x08, 0x09
  17156. };
  17157. /*
  17158. * Analog capture ADC cgange
  17159. */
  17160. static int alc680_capture_pcm_prepare(struct hda_pcm_stream *hinfo,
  17161. struct hda_codec *codec,
  17162. unsigned int stream_tag,
  17163. unsigned int format,
  17164. struct snd_pcm_substream *substream)
  17165. {
  17166. struct alc_spec *spec = codec->spec;
  17167. struct auto_pin_cfg *cfg = &spec->autocfg;
  17168. unsigned int pre_mic, pre_line;
  17169. pre_mic = snd_hda_jack_detect(codec, cfg->input_pins[AUTO_PIN_MIC]);
  17170. pre_line = snd_hda_jack_detect(codec, cfg->input_pins[AUTO_PIN_LINE]);
  17171. spec->cur_adc_stream_tag = stream_tag;
  17172. spec->cur_adc_format = format;
  17173. if (pre_mic || pre_line) {
  17174. if (pre_mic)
  17175. snd_hda_codec_setup_stream(codec, 0x08, stream_tag, 0,
  17176. format);
  17177. else
  17178. snd_hda_codec_setup_stream(codec, 0x09, stream_tag, 0,
  17179. format);
  17180. } else
  17181. snd_hda_codec_setup_stream(codec, 0x07, stream_tag, 0, format);
  17182. return 0;
  17183. }
  17184. static int alc680_capture_pcm_cleanup(struct hda_pcm_stream *hinfo,
  17185. struct hda_codec *codec,
  17186. struct snd_pcm_substream *substream)
  17187. {
  17188. snd_hda_codec_cleanup_stream(codec, 0x07);
  17189. snd_hda_codec_cleanup_stream(codec, 0x08);
  17190. snd_hda_codec_cleanup_stream(codec, 0x09);
  17191. return 0;
  17192. }
  17193. static struct hda_pcm_stream alc680_pcm_analog_auto_capture = {
  17194. .substreams = 1, /* can be overridden */
  17195. .channels_min = 2,
  17196. .channels_max = 2,
  17197. /* NID is set in alc_build_pcms */
  17198. .ops = {
  17199. .prepare = alc680_capture_pcm_prepare,
  17200. .cleanup = alc680_capture_pcm_cleanup
  17201. },
  17202. };
  17203. static struct snd_kcontrol_new alc680_base_mixer[] = {
  17204. /* output mixer control */
  17205. HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT),
  17206. HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  17207. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x4, 0x0, HDA_OUTPUT),
  17208. HDA_CODEC_MUTE("Headphone Playback Switch", 0x16, 0x0, HDA_OUTPUT),
  17209. HDA_CODEC_VOLUME("Int Mic Boost", 0x12, 0, HDA_INPUT),
  17210. HDA_CODEC_VOLUME("Mic Boost", 0x18, 0, HDA_INPUT),
  17211. HDA_CODEC_VOLUME("Line In Boost", 0x19, 0, HDA_INPUT),
  17212. { }
  17213. };
  17214. static struct hda_bind_ctls alc680_bind_cap_vol = {
  17215. .ops = &snd_hda_bind_vol,
  17216. .values = {
  17217. HDA_COMPOSE_AMP_VAL(0x07, 3, 0, HDA_INPUT),
  17218. HDA_COMPOSE_AMP_VAL(0x08, 3, 0, HDA_INPUT),
  17219. HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_INPUT),
  17220. 0
  17221. },
  17222. };
  17223. static struct hda_bind_ctls alc680_bind_cap_switch = {
  17224. .ops = &snd_hda_bind_sw,
  17225. .values = {
  17226. HDA_COMPOSE_AMP_VAL(0x07, 3, 0, HDA_INPUT),
  17227. HDA_COMPOSE_AMP_VAL(0x08, 3, 0, HDA_INPUT),
  17228. HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_INPUT),
  17229. 0
  17230. },
  17231. };
  17232. static struct snd_kcontrol_new alc680_master_capture_mixer[] = {
  17233. HDA_BIND_VOL("Capture Volume", &alc680_bind_cap_vol),
  17234. HDA_BIND_SW("Capture Switch", &alc680_bind_cap_switch),
  17235. { } /* end */
  17236. };
  17237. /*
  17238. * generic initialization of ADC, input mixers and output mixers
  17239. */
  17240. static struct hda_verb alc680_init_verbs[] = {
  17241. {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  17242. {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  17243. {0x04, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  17244. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  17245. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  17246. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  17247. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  17248. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  17249. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  17250. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  17251. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  17252. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  17253. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  17254. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  17255. {0x16, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN},
  17256. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_MIC_EVENT | AC_USRSP_EN},
  17257. { }
  17258. };
  17259. /* toggle speaker-output according to the hp-jack state */
  17260. static void alc680_base_setup(struct hda_codec *codec)
  17261. {
  17262. struct alc_spec *spec = codec->spec;
  17263. spec->autocfg.hp_pins[0] = 0x16;
  17264. spec->autocfg.speaker_pins[0] = 0x14;
  17265. spec->autocfg.speaker_pins[1] = 0x15;
  17266. spec->autocfg.input_pins[AUTO_PIN_MIC] = 0x18;
  17267. spec->autocfg.input_pins[AUTO_PIN_LINE] = 0x19;
  17268. }
  17269. static void alc680_rec_autoswitch(struct hda_codec *codec)
  17270. {
  17271. struct alc_spec *spec = codec->spec;
  17272. struct auto_pin_cfg *cfg = &spec->autocfg;
  17273. unsigned int present;
  17274. hda_nid_t new_adc;
  17275. present = snd_hda_jack_detect(codec, cfg->input_pins[AUTO_PIN_MIC]);
  17276. new_adc = present ? 0x8 : 0x7;
  17277. __snd_hda_codec_cleanup_stream(codec, !present ? 0x8 : 0x7, 1);
  17278. snd_hda_codec_setup_stream(codec, new_adc,
  17279. spec->cur_adc_stream_tag, 0,
  17280. spec->cur_adc_format);
  17281. }
  17282. static void alc680_unsol_event(struct hda_codec *codec,
  17283. unsigned int res)
  17284. {
  17285. if ((res >> 26) == ALC880_HP_EVENT)
  17286. alc_automute_amp(codec);
  17287. if ((res >> 26) == ALC880_MIC_EVENT)
  17288. alc680_rec_autoswitch(codec);
  17289. }
  17290. static void alc680_inithook(struct hda_codec *codec)
  17291. {
  17292. alc_automute_amp(codec);
  17293. alc680_rec_autoswitch(codec);
  17294. }
  17295. /* create input playback/capture controls for the given pin */
  17296. static int alc680_new_analog_output(struct alc_spec *spec, hda_nid_t nid,
  17297. const char *ctlname, int idx)
  17298. {
  17299. hda_nid_t dac;
  17300. int err;
  17301. switch (nid) {
  17302. case 0x14:
  17303. dac = 0x02;
  17304. break;
  17305. case 0x15:
  17306. dac = 0x03;
  17307. break;
  17308. case 0x16:
  17309. dac = 0x04;
  17310. break;
  17311. default:
  17312. return 0;
  17313. }
  17314. if (spec->multiout.dac_nids[0] != dac &&
  17315. spec->multiout.dac_nids[1] != dac) {
  17316. err = add_pb_vol_ctrl(spec, ALC_CTL_WIDGET_VOL, ctlname,
  17317. HDA_COMPOSE_AMP_VAL(dac, 3, idx,
  17318. HDA_OUTPUT));
  17319. if (err < 0)
  17320. return err;
  17321. err = add_pb_sw_ctrl(spec, ALC_CTL_WIDGET_MUTE, ctlname,
  17322. HDA_COMPOSE_AMP_VAL(nid, 3, idx, HDA_OUTPUT));
  17323. if (err < 0)
  17324. return err;
  17325. spec->multiout.dac_nids[spec->multiout.num_dacs++] = dac;
  17326. }
  17327. return 0;
  17328. }
  17329. /* add playback controls from the parsed DAC table */
  17330. static int alc680_auto_create_multi_out_ctls(struct alc_spec *spec,
  17331. const struct auto_pin_cfg *cfg)
  17332. {
  17333. hda_nid_t nid;
  17334. int err;
  17335. spec->multiout.dac_nids = spec->private_dac_nids;
  17336. nid = cfg->line_out_pins[0];
  17337. if (nid) {
  17338. const char *name;
  17339. if (cfg->line_out_type == AUTO_PIN_SPEAKER_OUT)
  17340. name = "Speaker";
  17341. else
  17342. name = "Front";
  17343. err = alc680_new_analog_output(spec, nid, name, 0);
  17344. if (err < 0)
  17345. return err;
  17346. }
  17347. nid = cfg->speaker_pins[0];
  17348. if (nid) {
  17349. err = alc680_new_analog_output(spec, nid, "Speaker", 0);
  17350. if (err < 0)
  17351. return err;
  17352. }
  17353. nid = cfg->hp_pins[0];
  17354. if (nid) {
  17355. err = alc680_new_analog_output(spec, nid, "Headphone", 0);
  17356. if (err < 0)
  17357. return err;
  17358. }
  17359. return 0;
  17360. }
  17361. static void alc680_auto_set_output_and_unmute(struct hda_codec *codec,
  17362. hda_nid_t nid, int pin_type)
  17363. {
  17364. alc_set_pin_output(codec, nid, pin_type);
  17365. }
  17366. static void alc680_auto_init_multi_out(struct hda_codec *codec)
  17367. {
  17368. struct alc_spec *spec = codec->spec;
  17369. hda_nid_t nid = spec->autocfg.line_out_pins[0];
  17370. if (nid) {
  17371. int pin_type = get_pin_type(spec->autocfg.line_out_type);
  17372. alc680_auto_set_output_and_unmute(codec, nid, pin_type);
  17373. }
  17374. }
  17375. static void alc680_auto_init_hp_out(struct hda_codec *codec)
  17376. {
  17377. struct alc_spec *spec = codec->spec;
  17378. hda_nid_t pin;
  17379. pin = spec->autocfg.hp_pins[0];
  17380. if (pin)
  17381. alc680_auto_set_output_and_unmute(codec, pin, PIN_HP);
  17382. pin = spec->autocfg.speaker_pins[0];
  17383. if (pin)
  17384. alc680_auto_set_output_and_unmute(codec, pin, PIN_OUT);
  17385. }
  17386. /* pcm configuration: identical with ALC880 */
  17387. #define alc680_pcm_analog_playback alc880_pcm_analog_playback
  17388. #define alc680_pcm_analog_capture alc880_pcm_analog_capture
  17389. #define alc680_pcm_analog_alt_capture alc880_pcm_analog_alt_capture
  17390. #define alc680_pcm_digital_playback alc880_pcm_digital_playback
  17391. #define alc680_pcm_digital_capture alc880_pcm_digital_capture
  17392. /*
  17393. * BIOS auto configuration
  17394. */
  17395. static int alc680_parse_auto_config(struct hda_codec *codec)
  17396. {
  17397. struct alc_spec *spec = codec->spec;
  17398. int err;
  17399. static hda_nid_t alc680_ignore[] = { 0 };
  17400. err = snd_hda_parse_pin_def_config(codec, &spec->autocfg,
  17401. alc680_ignore);
  17402. if (err < 0)
  17403. return err;
  17404. if (!spec->autocfg.line_outs) {
  17405. if (spec->autocfg.dig_outs || spec->autocfg.dig_in_pin) {
  17406. spec->multiout.max_channels = 2;
  17407. spec->no_analog = 1;
  17408. goto dig_only;
  17409. }
  17410. return 0; /* can't find valid BIOS pin config */
  17411. }
  17412. err = alc680_auto_create_multi_out_ctls(spec, &spec->autocfg);
  17413. if (err < 0)
  17414. return err;
  17415. spec->multiout.max_channels = 2;
  17416. dig_only:
  17417. /* digital only support output */
  17418. alc_auto_parse_digital(codec);
  17419. if (spec->kctls.list)
  17420. add_mixer(spec, spec->kctls.list);
  17421. add_verb(spec, alc680_init_verbs);
  17422. err = alc_auto_add_mic_boost(codec);
  17423. if (err < 0)
  17424. return err;
  17425. return 1;
  17426. }
  17427. #define alc680_auto_init_analog_input alc882_auto_init_analog_input
  17428. /* init callback for auto-configuration model -- overriding the default init */
  17429. static void alc680_auto_init(struct hda_codec *codec)
  17430. {
  17431. struct alc_spec *spec = codec->spec;
  17432. alc680_auto_init_multi_out(codec);
  17433. alc680_auto_init_hp_out(codec);
  17434. alc680_auto_init_analog_input(codec);
  17435. alc_auto_init_digital(codec);
  17436. if (spec->unsol_event)
  17437. alc_inithook(codec);
  17438. }
  17439. /*
  17440. * configuration and preset
  17441. */
  17442. static const char *alc680_models[ALC680_MODEL_LAST] = {
  17443. [ALC680_BASE] = "base",
  17444. [ALC680_AUTO] = "auto",
  17445. };
  17446. static struct snd_pci_quirk alc680_cfg_tbl[] = {
  17447. SND_PCI_QUIRK(0x1043, 0x12f3, "ASUS NX90", ALC680_BASE),
  17448. {}
  17449. };
  17450. static struct alc_config_preset alc680_presets[] = {
  17451. [ALC680_BASE] = {
  17452. .mixers = { alc680_base_mixer },
  17453. .cap_mixer = alc680_master_capture_mixer,
  17454. .init_verbs = { alc680_init_verbs },
  17455. .num_dacs = ARRAY_SIZE(alc680_dac_nids),
  17456. .dac_nids = alc680_dac_nids,
  17457. .dig_out_nid = ALC680_DIGOUT_NID,
  17458. .num_channel_mode = ARRAY_SIZE(alc680_modes),
  17459. .channel_mode = alc680_modes,
  17460. .unsol_event = alc680_unsol_event,
  17461. .setup = alc680_base_setup,
  17462. .init_hook = alc680_inithook,
  17463. },
  17464. };
  17465. static int patch_alc680(struct hda_codec *codec)
  17466. {
  17467. struct alc_spec *spec;
  17468. int board_config;
  17469. int err;
  17470. spec = kzalloc(sizeof(*spec), GFP_KERNEL);
  17471. if (spec == NULL)
  17472. return -ENOMEM;
  17473. codec->spec = spec;
  17474. board_config = snd_hda_check_board_config(codec, ALC680_MODEL_LAST,
  17475. alc680_models,
  17476. alc680_cfg_tbl);
  17477. if (board_config < 0 || board_config >= ALC680_MODEL_LAST) {
  17478. printk(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
  17479. codec->chip_name);
  17480. board_config = ALC680_AUTO;
  17481. }
  17482. if (board_config == ALC680_AUTO) {
  17483. /* automatic parse from the BIOS config */
  17484. err = alc680_parse_auto_config(codec);
  17485. if (err < 0) {
  17486. alc_free(codec);
  17487. return err;
  17488. } else if (!err) {
  17489. printk(KERN_INFO
  17490. "hda_codec: Cannot set up configuration "
  17491. "from BIOS. Using base mode...\n");
  17492. board_config = ALC680_BASE;
  17493. }
  17494. }
  17495. if (board_config != ALC680_AUTO)
  17496. setup_preset(codec, &alc680_presets[board_config]);
  17497. spec->stream_analog_playback = &alc680_pcm_analog_playback;
  17498. spec->stream_analog_capture = &alc680_pcm_analog_auto_capture;
  17499. spec->stream_digital_playback = &alc680_pcm_digital_playback;
  17500. spec->stream_digital_capture = &alc680_pcm_digital_capture;
  17501. if (!spec->adc_nids) {
  17502. spec->adc_nids = alc680_adc_nids;
  17503. spec->num_adc_nids = ARRAY_SIZE(alc680_adc_nids);
  17504. }
  17505. if (!spec->cap_mixer)
  17506. set_capture_mixer(codec);
  17507. spec->vmaster_nid = 0x02;
  17508. codec->patch_ops = alc_patch_ops;
  17509. if (board_config == ALC680_AUTO)
  17510. spec->init_hook = alc680_auto_init;
  17511. return 0;
  17512. }
  17513. /*
  17514. * patch entries
  17515. */
  17516. static struct hda_codec_preset snd_hda_preset_realtek[] = {
  17517. { .id = 0x10ec0260, .name = "ALC260", .patch = patch_alc260 },
  17518. { .id = 0x10ec0262, .name = "ALC262", .patch = patch_alc262 },
  17519. { .id = 0x10ec0267, .name = "ALC267", .patch = patch_alc268 },
  17520. { .id = 0x10ec0268, .name = "ALC268", .patch = patch_alc268 },
  17521. { .id = 0x10ec0269, .name = "ALC269", .patch = patch_alc269 },
  17522. { .id = 0x10ec0270, .name = "ALC270", .patch = patch_alc269 },
  17523. { .id = 0x10ec0272, .name = "ALC272", .patch = patch_alc662 },
  17524. { .id = 0x10ec0275, .name = "ALC275", .patch = patch_alc269 },
  17525. { .id = 0x10ec0861, .rev = 0x100340, .name = "ALC660",
  17526. .patch = patch_alc861 },
  17527. { .id = 0x10ec0660, .name = "ALC660-VD", .patch = patch_alc861vd },
  17528. { .id = 0x10ec0861, .name = "ALC861", .patch = patch_alc861 },
  17529. { .id = 0x10ec0862, .name = "ALC861-VD", .patch = patch_alc861vd },
  17530. { .id = 0x10ec0662, .rev = 0x100002, .name = "ALC662 rev2",
  17531. .patch = patch_alc882 },
  17532. { .id = 0x10ec0662, .rev = 0x100101, .name = "ALC662 rev1",
  17533. .patch = patch_alc662 },
  17534. { .id = 0x10ec0663, .name = "ALC663", .patch = patch_alc662 },
  17535. { .id = 0x10ec0665, .name = "ALC665", .patch = patch_alc662 },
  17536. { .id = 0x10ec0670, .name = "ALC670", .patch = patch_alc662 },
  17537. { .id = 0x10ec0680, .name = "ALC680", .patch = patch_alc680 },
  17538. { .id = 0x10ec0880, .name = "ALC880", .patch = patch_alc880 },
  17539. { .id = 0x10ec0882, .name = "ALC882", .patch = patch_alc882 },
  17540. { .id = 0x10ec0883, .name = "ALC883", .patch = patch_alc882 },
  17541. { .id = 0x10ec0885, .rev = 0x100101, .name = "ALC889A",
  17542. .patch = patch_alc882 },
  17543. { .id = 0x10ec0885, .rev = 0x100103, .name = "ALC889A",
  17544. .patch = patch_alc882 },
  17545. { .id = 0x10ec0885, .name = "ALC885", .patch = patch_alc882 },
  17546. { .id = 0x10ec0887, .name = "ALC887", .patch = patch_alc882 },
  17547. { .id = 0x10ec0888, .rev = 0x100101, .name = "ALC1200",
  17548. .patch = patch_alc882 },
  17549. { .id = 0x10ec0888, .name = "ALC888", .patch = patch_alc888 },
  17550. { .id = 0x10ec0889, .name = "ALC889", .patch = patch_alc882 },
  17551. { .id = 0x10ec0892, .name = "ALC892", .patch = patch_alc662 },
  17552. {} /* terminator */
  17553. };
  17554. MODULE_ALIAS("snd-hda-codec-id:10ec*");
  17555. MODULE_LICENSE("GPL");
  17556. MODULE_DESCRIPTION("Realtek HD-audio codec");
  17557. static struct hda_codec_preset_list realtek_list = {
  17558. .preset = snd_hda_preset_realtek,
  17559. .owner = THIS_MODULE,
  17560. };
  17561. static int __init patch_realtek_init(void)
  17562. {
  17563. return snd_hda_add_codec_preset(&realtek_list);
  17564. }
  17565. static void __exit patch_realtek_exit(void)
  17566. {
  17567. snd_hda_delete_codec_preset(&realtek_list);
  17568. }
  17569. module_init(patch_realtek_init)
  17570. module_exit(patch_realtek_exit)