Portál AbcLinuxu, 4. května 2025 18:55

XFS a problémy s rozlišovaním adresárov od súborov

27.10.2013 09:47 | Přečteno: 2438× | Linux

Dnešný blog bude relatívne krátky, v podstate pôjde len o jednoduchý programík, ktorý demonštruje to, že xfs v záznamoch dirent nerozlišuje medzi adresármi a súbormi čo môže nepripravenému softvéru urobiť poriadne problémy. Na záver blogu jeden malý bonus - foto mojej mačky ;-)

Včera som zopár hodín strávil ladením malého programu na správu siete - connman. Táto malá utilitka sa používa prevažne v mobilných zariadeniach (tizen, nemo ...). Pre jedno embedded zariadenie som potreboval vyrobiť okrem network manažéra aj nastavenie časovej zóny. Keďže už connman používam na pripojenie k sieti nebolo nad čím váhať a využil som rovno aj jeho modul na nastavenie času / časovej zóny a ntp. To som ale nečakal na aký problém narazím pri použití xfs.

Niekoľko hodín som strávil pátraním prečo nemám vôbec hodiny dostupné cez dbus rozhranie. Došiel som až k súboru timezone.c a konkrétne k funkcii find_origin. Nenápadný kód typu:

while ((d = readdir(dir))) {
    switch (d->d_type) {
        ...
    }
}

vyzerá na prvý pohľad v poriadku. Niektoré súborové systémy však pri čítaní adresára nevracajú vôbec d_type. Na prvý pohľad to síce vyzerá nezmyselne, ale ak je atribút typu súboru uložený samostatne vo vlastnom inode (tj. pre každý súbor sa pre zistenie jeho typu musí načítať samostatný uzol na disku) môže byť directory listing poriadne pomalý. Preto v takých prípadoch môže filesystém vracať neznámy typ a konkrétny typ záznamu sa musí zistiť cez volanie stat.

Na záver ešte sľúbený príklad (nič neošetrujem, netrhajte si prosím vlasy ;-)

#include <sys/stat.h>
#include <dirent.h>
#include <stdlib.h>
#include <stdio.h>

int main(int argc, char *argv[])
{
    DIR *dir = opendir(argv[1]);
    struct dirent *d;
    struct stat buf;
    char path[255];

    while ((d = readdir(dir))) {
        // Identifikacia caz fstat
        switch (d->d_type) {
            case DT_UNKNOWN : printf("UNKNOWN"); break;
            case DT_FIFO    : printf("FIFO   "); break;
            case DT_CHR     : printf("CHR    "); break;
            case DT_DIR     : printf("DIR    "); break;
            case DT_BLK     : printf("BLK    "); break;
            case DT_REG     : printf("REG    "); break;
            case DT_LNK     : printf("LNK    "); break;
            case DT_SOCK    : printf("SOCK   "); break;
            case DT_WHT     : printf("WHT    "); break;
        }
        printf(" (");

        // Identifikacia cez d_type
        snprintf(path, 255, "%s/%s", argv[1], d->d_name);
        if (stat(path, &buf) == 0) {
            if (S_ISREG  (buf.st_mode))  printf("REG ");
            if (S_ISDIR  (buf.st_mode))  printf("DIR ");
            if (S_ISCHR  (buf.st_mode))  printf("CHR ");
            if (S_ISBLK  (buf.st_mode))  printf("BLK ");
            if (S_ISFIFO (buf.st_mode))  printf("FIFO");
            if (S_ISLNK  (buf.st_mode))  printf("LNK ");
            if (S_ISSOCK (buf.st_mode))  printf("SOCK");
        }

        printf(") %s ", d->d_name);
        printf("\n");
    }
    return 0;
}

Po zavolaní ./a.out /cesta/k/adresaru na nasledujúci adresár:

% ls -lh
celkom 0
drwxr-xr-x 2 mirec mirec 6 okt 26 11:48 adresar
prw-r--r-- 1 mirec mirec 0 okt 26 11:48 fifo
-rw-r--r-- 1 mirec mirec 0 okt 26 11:48 subor

vypíše testovací program nasledujúce záznamy:

./a.out test
DIR     (DIR ) . 
DIR     (DIR ) .. 
UNKNOWN (DIR ) adresar 
UNKNOWN (REG ) subor 
UNKNOWN (FIFO) fifo 

Prvý záznam je vrátený z dirent, druhý už korektný získaný volaním stat.

Kocúr na záver

Minulý blog bol taký trochu smutnejší a na záver som poslal fotku jednej mačky, ktorá behala po okolí. Tentoraz posielam foto v podstate už môjho kocúra. Asi pred 3 týždňami som ho našiel pred dverami a od vtedy je doma každý deň. Majiteľka je niečo ako crazy cat women zo simpsonovcov, takže domov sa už radšej nevracia ;-)

       

Hodnocení: 100 %

        špatnédobré        

Obrázky

XFS a problémy s rozlišovaním adresárov od súborov, obrázek 1 XFS a problémy s rozlišovaním adresárov od súborov, obrázek 2

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

Komentáře

Nástroje: Začni sledovat (1) ?Zašle upozornění na váš email při vložení nového komentáře. , Tisk

Vložit další komentář

27.10.2013 11:19 kralyk z abclinuxu | skóre: 29 | blog:
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
Odpovědět | Sbalit | Link | Blokovat | Admin
A přitom v manuálu to je napsaný...
unsigned char  d_type;      /* type of file; not supported
                               by all file system types */
SPD vůbec není proruská
mirec avatar 27.10.2013 11:23 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
Odpovědět | Sbalit | Link | Blokovat | Admin

Jop, v manuále je to napísané správne, ale v bugreporte ku connman-u to inteláci zahodili, lebo podľa nich všetky normálne filesystémy to podporujú.

LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
27.10.2013 17:33 kralyk z abclinuxu | skóre: 29 | blog:
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
To jako XFS není normální fs nebo co? :-D

Patch by nebrali?
27.10.2013 13:15 jas | skóre: 13 | blog: blag
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
Odpovědět | Sbalit | Link | Blokovat | Admin

btw: Namiesto stat by bolo v tomto pripade lepsie pouzit lstat nech sa nesleduju linky.

Agent avatar 27.10.2013 13:37 Agent | blog: Life_in_Pieces | HC city
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
Odpovědět | Sbalit | Link | Blokovat | Admin
Když už sme u těch maček, dnes už náš kocour se k nám přistěhoval od nedalekých sousedů. Asi se o něj moc dobře nestarali. Tady je jak číhá v krmítku na ptáky: Mates
Nevěděl zpočátku, co si počít, jak žít, co dělat, ale brzy se vpravil do role samotáře.
mirec avatar 27.10.2013 13:44 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
Pekne, tento náš má domov asi o 4 domy ďalej. Keď som ho bol vrátiť majiteľka ho hneď udrela. Asi o hodinu ušiel a bol späť u nás ;-)
LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
mirec avatar 27.10.2013 15:31 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
Příloha:
Inak náš Muro bežne odpočíva na vonkajšom schodišti do hospodárskej budovy pod strechou. Prikladám foto ;)
LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon
Agent avatar 27.10.2013 17:38 Agent | blog: Life_in_Pieces | HC city
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
My sme to krmítko nakonec museli dát na dlouhou železnou trubku aby se tam nevyšplhal. Když je teplo tak odpočívá venku, při chladnějším počasí ho necháme doma nebo v dílně.

Ještě mám tuto kočičí dámu: Mína ve sněhu Ale spolu s tim kocourem se rádi nemaj. Teda on by si chtěl hrát, ale ona na něj jen vrčí a syčí... Někdy to musím natočit :-)
Nevěděl zpočátku, co si počít, jak žít, co dělat, ale brzy se vpravil do role samotáře.
mirec avatar 27.10.2013 18:00 mirec | skóre: 32 | blog: mirecove_dristy | Poprad
Rozbalit Rozbalit vše Re: XFS a problémy s rozlišovaním adresárov od súborov
Ja som kŕmitko zdemoloval pred 2 týždňami. Vlastne to bolo v rámci plánovanej demolácie stromu (suché konáre a tak). Okrem toho bolo to kŕmitko zbúchané za 5 minút, škaredé, krivé ... Musím vymyslieť nové, krajšie, luxusnejšie ... ;-)
LinuxOS.sk | USE="-fotak -zbytocnosti -farebne_lcd +vydrz +odolnost +java" emerge telefon

Založit nové vláknoNahoru

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.