Så Här Felsöker Och åtgärdar Udelay Linux -kärnproblem
September 3, 2021Här är några enkla sätt att åtgärda Linux udelay -kärnproblemet.
Rekommenderas: Fortect
Tidsgränser – Information om de olika kärnans timeout samt sömnmekanismer.———————————————————- —————–Det här dokumentet Det skadade honom att klargöra den allmänna frågan: “Vad brukar det vara?”RightWay (TM) Lägg till fördröjning? “Detta huvudproblem stöter oftast på författare till anställda somklara av datorfördröjning och vem av er kan inte göra det mest intima?bekanta som har de inbyggda funktionerna i Linux-kärnan.Infoga tidsfrister—————-Den första och främsta frågan som köparna definitivt borde ställa sig är “Är det här mitt?”Kod i ett kärnsammanhang? “Det måste göras matchande till”behöver det verkligen i allmänhet skjutas upp i ett kärnsammanhang? inom Om ja …ATOMIC CONTEXT:I allmänhet måste du använda * fördröjningsfamiljen för funktioner. De därFunktioner använder Jiffys uppskattning av tidseffektoch kommer att vara upptagen med att vänta ända tills tillräckligt många cykeltider har nåttssom omedelbart efter utgången av vår mandatperiod:ndelay (osignerat lång ns)udelay (osignerat helt använda)mdelay (tidskrävande osignerade millisekunder)udelay var det mest populära API; utmärkt latensnivåFaktum är att exakthet inte existerar för många icke-PC-enheter.mdelay är din egen udelay -makroomslagare lämplig för dettamöjlig översvämning vid Passerar stora argument tid för udelay.I de flesta fall rekommenderas inte att använda mdelay med att göra med och därefter i sin tur kodenOmarbetat för att använda msleep.IKKE-ATOMISK KONTEXT:Din implementering bör lägga till familjen * ha sex [_range] till funktionerna.Det kommer att finnas flera fler alternativ, men alla från dem kan varaDet kunniga arbetet kan göras med “rätt” är sovande arbete.Hjälp planerare, energihantering och betydligt mycket att göra din egenPiloten har varit bättre :)- Förutsatt – Upptagen -väntande cykel:udelay (osignerad lång användning)- Säkerhet på Htimer:usleep_range (osignerad lång min., osignerad ihållande spork. lång)- Författare: jiffies / Legacy_timersmsleep (många ms osignerade)msleep_interruptible (osignerad lång ms)Den grundläggande mekanismen skiljer sig från lapse -metoden *.Var och en av dessa typer av samtal för att köra är olika, som ett resultat finns detFunktioner som ditt företag bör sluta känna till.SOVA FÖR “LITT” ANVÄNDNING (
trace_printk ("111111");tilldelning (4000); trace_printk ("222222");
trace_printk ("111111");Latens (10 000);Latens (10 000);Latens (10 000);Latens (10 000);........ // helt enkelt bara 400 snabbsamtaltrace_printk ("222222");
Rekommenderas: Fortect
Är du trött på att din dator går långsamt? Är det full av virus och skadlig kod? Var inte rädd, min vän, för Fortect är här för att rädda dagen! Detta kraftfulla verktyg är utformat för att diagnostisera och reparera alla slags Windows-problem, samtidigt som det ökar prestanda, optimerar minnet och håller din dator igång som ny. Så vänta inte längre - ladda ner Fortect idag!
Loggen ska förklara till 4,7 ms. Detta är inte nödvändigtvis acceptabelt.Varför är verkligen fördröjningsfelet så viktigt?
Utforska kärnkoden här, jag hittade vår egen implementering av dessa personer två funktioner
värdelös __udelay (ofta osignerad) __const_udelay (usecs 0x10C7UL); / * ett par ** 32 gånger 1.000.000 (avrundat) 3. /void __ndelay (enorm osignerad nsec) __const_udelay (nsecs 1.0x5UL); * 2 ** 32/1000000000 (avrundad) 2. /
Jag kan tänka mig att udelay skulle vara tusen gånger kraftigare än ndelay, men det har du inte, varför?
frågade 22 maj, 15 @ 12:34
1.531 44 guldmärken
Inget svar du letar efter? Bläddra gärna igenom andra frågor med Tag Timer Linux-kärna Linux-enhetsdrivrutin eller kom med din egen idé.
Som du kanske redan har insett är nanosekunds latens en ganska tuff tillnärmning av millisekunds latens, eftersom den konstanta 0x5
ska användas. 0x10c7/0x5
är verkligen praktiskt taget 859. Med 0x4
kommer det närmare tillbaka till 1000 (cirka 1073).
Användning av 0x4 resulterar dock vanligtvis i att din timeout
är mindre än det definierade antalet nanosekunder. I allmänhet syftar långsamma funktioner till att ge latens här åtminstone så länge som cyberspace-användaren önskar (se här: http://practicepeople.blogspot.jp/2013/08/kernel-programming-busy-waiting-delay. Html) …
hjälpt till sedan 22 maj ’15 här inne 12:50
2 371
Ett avrundningsfel läggs också till varje sekund du kallar det. Notera annotera 2 ** 32 1000000000
/. I själva verket är detta värde alltid ~ 4,29, det har slutförts upp till 5. Detta är det senaste nya, ganska allvarliga felet.
På grund av den speciella skillnaden är Udelays fel rimligt: (~ 4294,97 mot 4295 [0x10c7]).
svarade 20 maj ’15 klockan 12:44
11.2k
Du kan använda ktime_get_ns () för att hjälpa dig att få en mycket exakt tid, främst eftersom start. Således kan du utan tvekan använda programvaran inte bara som en utmärkt precisionsmask, utan också som en absolut högprecisions liten nöt. Här är ett nytt bra exempel:
u64 t;t skulle betyda ktime_get_ns (); // Få de senaste nanosekunderna vid startför (jag betyder 0; i <24; i ++) // Skicka 24 pulser 1200 ns-1300 ns med din GPIO gpio_set_value (kontakt, 1); // hantera GPIO eller bara ge något annat om inas på + betyder 1200; // Nu lider vi av den mest kritiska tiden för att kliva in i framtiden medan (ktime_get_ns ()
sa 16 nov 18 kl 12:14
658 77 silvermärken 1212 ljusgyllene märken.
Ladda ner den här programvaran och fixa din dator på några minuter.