From 889a015512d1a1e864e02b14d281f213cf896914 Mon Sep 17 00:00:00 2001 From: Simone Piccardi Date: Wed, 17 Aug 2011 15:42:26 +0000 Subject: [PATCH] Altro materiale sulle quote. --- filedir.tex | 210 ++++++++++++++++++++++++++++++++--------------- listati/dqblk.h | 12 +++ listati/dqinfo.h | 7 ++ 3 files changed, 163 insertions(+), 66 deletions(-) create mode 100644 listati/dqblk.h create mode 100644 listati/dqinfo.h diff --git a/filedir.tex b/filedir.tex index 18bbdc0..d1ba1b0 100644 --- a/filedir.tex +++ b/filedir.tex @@ -1,4 +1,4 @@ -4%% filedir.tex +%% filedir.tex %% %% Copyright (C) 2000-2011 Simone Piccardi. Permission is granted to %% copy, distribute and/or modify this document under the terms of the GNU Free @@ -1484,7 +1484,7 @@ il suo prototipo è: \end{errlist}} \end{prototype} -La funzionne genera un nome univoco sostituendo le \code{XXXXXX} finali di +La funzionane genera un nome univoco sostituendo le \code{XXXXXX} finali di \param{template}; dato che \param{template} deve poter essere modificata dalla funzione non si può usare una stringa costante. Tutte le avvertenze riguardo alle possibili \itindex{race~condition} \textit{race condition} date per @@ -1597,7 +1597,7 @@ funzioni \funcd{stat}, \funcd{fstat} e \funcd{lstat}, i cui prototipi sono: \errval{EACCES}, \errval{ENOMEM}, \errval{ENAMETOOLONG}.} \end{functions} -La funzione \func{stat} legge le informazion del file il cui pathname è +La funzione \func{stat} legge le informazioni del file il cui pathname è specificato dalla stringa puntata da \param{file\_name} e le inserisce nel buffer puntato dall'argomento \param{buf}; la funzione \func{lstat} è identica a \func{stat} eccetto che se \param{file\_name} è un link simbolico vengono @@ -1793,9 +1793,9 @@ dimensione si possono usare le due funzioni \funcd{truncate} e \errval{EROFS}, \errval{EIO}, \errval{EFAULT}, \errval{ELOOP}.} \end{functions} -Emtrambe le funzioni fan sì che la dimensione del file sia troncata ad un +Entrambe le funzioni fan sì che la dimensione del file sia troncata ad un valore massimo specificato da \param{length}, e si distinguono solo per il -fatto che il file viene indicato con il pathame \param{file\_name} per +fatto che il file viene indicato con il pathname \param{file\_name} per \func{truncate} e con il file descriptor \param{fd} per \funcd{ftruncate}; se il file è più lungo della lunghezza specificata i dati in eccesso saranno perduti. @@ -1806,7 +1806,7 @@ lunghezza scelta; nel caso di Linux viene esteso con la creazione di un \index{file!\textit{hole}} \textsl{buco} nel \itindex{sparse~file} file e ad una lettura si otterranno degli zeri; si tenga presente però che questo comportamento è supportato solo per filesystem nativi, ad esempio su un -filesystem non nativo come il VFAT di windows questo non è possibile. +filesystem non nativo come il VFAT di Windows questo non è possibile. \subsection{I tempi dei file} \label{sec:file_file_times} @@ -1996,7 +1996,7 @@ I tempi di ultimo accesso e modifica possono essere modificati esplicitamente usando la funzione \funcd{utime}, il cui prototipo è: \begin{prototype}{utime.h} {int utime(const char *filename, struct utimbuf *times)} - Modidica i tempi di ultimo accesso e modifica di un file. + Modifica i tempi di ultimo accesso e modifica di un file. \bodydesc{La funzione restituisce 0 in caso di successo e -1 in caso di errore, nel qual caso \var{errno} assumerà uno dei valori: @@ -2058,7 +2058,7 @@ precisione; il suo prototipo è: \begin{prototype} {sys/time.h} {int utimes(const char *filename, struct timeval times[2])} - Modidica i tempi di ultimo accesso e modifica di un file. + Modifica i tempi di ultimo accesso e modifica di un file. \bodydesc{La funzione restituisce 0 in caso di successo e -1 in caso di errore, nel qual caso \var{errno} assumerà uno dei valori: @@ -2709,7 +2709,7 @@ in particolare accade che: \end{enumerate} Per alcuni filesystem\footnote{i filesystem più comuni (\textsl{ext2}, - \textsl{ext3}, \textsl{ext4}, \textsl{reiserfs}) supportano questa + \textsl{ext3}, \textsl{ext4}, \textsl{ReiserFS}) supportano questa caratteristica, che è mutuata da BSD.} è inoltre prevista un'ulteriore misura di sicurezza, volta a scongiurare l'abuso dei \itindex{suid~bit} bit \acr{suid} e \acr{sgid}; essa consiste nel cancellare automaticamente questi @@ -4151,30 +4151,32 @@ ad un altra con \funcd{acl\_copy\_entry} o eliminare una voce da una ACL con \label{sec:disk_quota} Quella delle quote disco è una funzionalità introdotta inizialmente da BSD, e -presente in Linux fino dalla serie 2.0, che consente di porre dei tetti -massimi al consumo delle risorse di un filesystem (spazio disco e -\textit{inode}) da parte degli utenti e dei gruppi. Dato che la funzionalità -ha senso solo per i filesystem su cui si mantengono i dati degli -utenti\footnote{in genere la si attiva sul filesystem che contiene le - \textit{home} degli utenti, dato che non avrebbe senso per i file di sistema - che in genere appartengono all'amministratore.} essa deve essere abilitata -esplicitamente, questo si fa tramite due distinte opzioni di montaggio, -\texttt{usrquota} e \texttt{grpquota} che la attivano rispettivamente per gli -utenti e per i gruppi, cosa che consente di abilitare solo quelle che -interessano veramente. - -Il meccanismo delle quote prevede che per ciascun filesystem che le supporta +presente in Linux fino dai kernel dalla serie 2.0, che consente di porre dei +tetti massimi al consumo delle risorse di un filesystem (spazio disco e +\textit{inode}) da parte di utenti e gruppi. Dato che la funzionalità ha senso +solo per i filesystem su cui si mantengono i dati degli utenti\footnote{in + genere la si attiva sul filesystem che contiene le \textit{home} degli + utenti, dato che non avrebbe senso per i file di sistema che in genere + appartengono all'amministratore.} essa deve essere esplicitamente richiesta; +questo si fa tramite due distinte opzioni di montaggio, \texttt{usrquota} e +\texttt{grpquota} che abilitano le quote rispettivamente per gli utenti e per +i gruppi. Grazie a questo è possibile usare le limitazioni sulle quote solo +sugli utenti o solo sui gruppi. + +Il meccanismo prevede che per ciascun filesystem che supporta le quote disco (i vari \textit{extN}, \textit{btrfs}, \textit{XFS}, \textit{JFS}, \textit{ReiserFS}) il kernel provveda sia a mantenere aggiornati i dati relativi al consumo delle risorse da parte di utenti e/o gruppi che a far -rispettare i limiti imposti dal sistema con la generazione di un errore di +rispettare i limiti imposti dal sistema, con la generazione di un errore di \errval{EDQUOT} per tutte le operazioni sui file che porterebbero ad un -superamento degli stessi. +superamento degli stessi. Si tenga presente che questi due compiti sono +separati, il primo si attiva al montaggio del filesystem con le quote +attivate, il secondo deve essere abilitato esplicitamente. Per il mantenimento dei dati di consumo delle risorse vengono usati due file riservati (uno per le quote utente e l'altro per le quote gruppo) nella -directory radice del filesytem su cui si sono attivate le quote;\footnote{la - cosa vale per tutti i fileystem tranne \textit{XFS} che mantiene i dati +directory radice del filesystem su cui si sono attivate le quote;\footnote{la + cosa vale per tutti i filesystem tranne \textit{XFS} che mantiene i dati internamente.} con la versione 2 del supporto delle quote, l'unica rimasta in uso, questi file sono \texttt{aquota.user} e \texttt{aquota.group}, in precedenza erano \texttt{quota.user} e \texttt{quota.group}. Dato che i file @@ -4182,9 +4184,9 @@ vengono aggiornati soltanto se il filesystem è stato montato con il supporto delle quote, se si abilita questo in un secondo tempo (o se si eseguono operazioni sul filesystem senza averlo abilitato) i dati contenuti possono non corrispondere esattamente allo stato corrente del consumo delle risorse; per -questo in genere prima di montare un filesystem su cui sono abilitate le quote -viene utilizzato il comando \cmd{quotacheck} per verificare e aggiornare i -dati. +questo in genere prima di montare in scrittura un filesystem su cui sono +abilitate le quote in genere viene utilizzato il comando \cmd{quotacheck} per +verificare e aggiornare i dati. Le restrizioni sul consumo delle risorse prevedono due limiti, il primo viene detto \textit{soft limit} e può essere superato per brevi periodi di tempo, il @@ -4202,28 +4204,28 @@ delle quote è \funcd{quotactl}, ed il suo prototipo è: \headdecl{sys/types.h} \headdecl{sys/quota.h} - \funcdecl{quotactl(int cmd, const char *special, int id, caddr\_t addr)} + \funcdecl{quotactl(int cmd, const char *dev, int id, caddr\_t addr)} Esegue una operazione di controllo sulle quote disco. \bodydesc{La funzione restituisce $0$ in caso di successo e $-1$ in caso di errore, nel qual caso \var{errno} assumerà uno dei valori: \begin{errlist} - \item[\errcode{EACCES}] il file delle quote non è un file normale. + \item[\errcode{EACCES}] il file delle quote non è un file ordinario. \item[\errcode{EBUSY}] si è richiesto \const{Q\_QUOTAON} ma le quote sono già attive. \item[\errcode{EFAULT}] l'indirizzo \param{addr} non è valido. \item[\errcode{EIO}] errore di lettura/scrittura sul file delle quote. - \item[\errcode{EMFILE}] non si può aprire il file delle quote avando + \item[\errcode{EMFILE}] non si può aprire il file delle quote avendo superato il limite sul numero di file aperti nel sistema. \item[\errcode{EINVAL}] o \param{cmd} non è un comando valido, - o il dispositivo \param{special} non esiste. - \item[\errcode{ENODEV}] \param{special} non corrisponde ad un \textit{mount + o il dispositivo \param{dev} non esiste. + \item[\errcode{ENODEV}] \param{dev} non corrisponde ad un \textit{mount point} attivo. \item[\errcode{ENOPKG}] il kernel è stato compilato senza supporto per le quote. - \item[\errcode{ENOTBLK}] \param{special} non è un dispositivo a blocchi. - \item[\errcode{EPERM}] il . + \item[\errcode{ENOTBLK}] \param{dev} non è un dispositivo a blocchi. + \item[\errcode{EPERM}] non si hanno i permessi per l'operazione richiesta. \item[\errcode{ESRCH}] è stato richiesto uno fra \const{Q\_GETQUOTA}, \const{Q\_SETQUOTA}, \const{Q\_SETUSE}, \const{Q\_SETQLIM} per un filesystem senza quote attivate. @@ -4231,27 +4233,98 @@ delle quote è \funcd{quotactl}, ed il suo prototipo è: } \end{functions} -La funzione richiede che si indichi il filesystem sul quale si vuole operare -tramite il secondo argomento \param{special} che deve indicare il nome del -file di dispositivo ad esso associato, la funzione richiede che il filesystem -sia montato con il supporto per le quote. Il terzo argomento \param{id} -indica, per le operazioni che lo richiedono l'utente o il gruppo (specificati -rispettivamente per \acr{uid} e \acr{gid}) su cui si vuole operare, infine -l'ultimo argomento specifica l'indirizzo di una struttura dati che dipende di -nuovo dal comando. +La funzione richiede che il filesystem sul quale si vuole operare sia montato +con il supporto delle quote abilitato; esso deve essere specificato con il +nome del file di dispositivo nell'argomento \param{dev}. Per le operazioni che +lo richiedono inoltre si dovrà indicare con l'argomento \param{id} l'utente o +il gruppo (specificati rispettivamente per \acr{uid} e \acr{gid}) su cui si +vuole operare. Alcune operazioni usano l'argomento \param{addr} per indicare +un indirizzo ad un area di memoria il cui utilizzo dipende dall'operazione +stessa. + +Il tipo di operazione che si intende effettuare deve essere indicato tramite +il primo argomento \param{cmd}, questo in genere viene specificato con +l'ausilio della macro \macro{QCMD}: +\begin{functions} + \funcdecl{int QCMD(subcmd,type)} Imposta il comando \param{subcmd} per il + tipo di quote (utente o gruppo) \param{type}. +\end{functions} +\noindent che consente di specificare, oltre al tipo di operazione, se questa +deve applicarsi alle quote utente o alle quote gruppo, nel qual +caso \param{type} deve essere rispettivamente \const{USRQUOTA} o +\const{GRPQUOTA}. +Le diverse operazioni supportate da \func{quotactl}, da indicare con +l'argomento \param{subcmd} di \macro{QCMD}, sono riportate in tab. -Il funzionamento di \func{quotactl} è controllato dal valore del primo -argomento, che indica l'operazione che si vuole eseguire e se la si vuole -eseguire per le quote disco o le quote gruppo (posto che siano entrm +\begin{table}[htb] + \centering + \footnotesize + \begin{tabular}{|l|p{10cm}|} + \hline + \textbf{Tipo} & \textbf{Descrizione} \\ + \hline + \hline + \const{Q\_QUOTAON} & attiva l'applicazione delle quote disco per il + filesystem \param{dev}, si deve passare + in \param{addr} il pathname al file che mantiene le + quote, che deve esistere; l'operazione richiede i + privilegi di amministratore,\footnotemark \param{id} + viene ignorato.\\ + \const{Q\_QUOTAOFF} & disattiva l'applicazione delle quote disco per il + filesystem \param{dev}; l'operazione richiede i + privilegi di amministratore, \param{id} + e \param{addr} vengono ignorati.\\ + \const{Q\_GETQUOTA} & legge i limiti ed i valori correnti delle quote nel + filesystem \param{dev} per l'utente o il gruppo + specificato da \param{id}; si devono avere i + privilegi di amministratore per leggere i dati + relativi ad altri utenti o a gruppi di cui non si fa + parte, il risultato viene restituito in una struttura + \struct{dqblk} all'indirizzo indicato + da \param{addr}.\\ + \const{Q\_SETQUOTA} & imposta le quote nel filesystem \param{dev} per + l'utente o il gruppo specificato da \param{id} come + ottenuti dalla struttura \struct{dqblk} puntata + da \param{addr}; l'operazione richiede i + privilegi di amministratore.\\ + \const{Q\_GETINFO} & .\\ + \const{Q\_SETINFO} & .\\ + \const{Q\_GETFMT} & .\\ + \const{Q\_SYNC} & Aggiorna la copia su disco dei dati delle quote del + filesystem; in questo caso \param{dev} può anche + essere \val{NULL} nel qual caso vengono aggiornate + i dati per tutti i filesystem con quote + attive, \param{id} e \param{addr} vengono comunque + ignorati.\\ + \const{Q\_GETSTATS} & .\\ +% \const{} & .\\ + \hline + \end{tabular} + \caption{Possibili valori per l'argomento \param{subcommand} di + \macro{QCMD}.} + \label{tab:quotactl_commands} +\end{table} +\footnotetext{per tutte le operazioni privilegiate con le quote è richiesta la + \textit{capability} \const{CAP\_SYS\_ADMIN}.} -% TODO trattare quote disco -% vedi man quotactl +\begin{figure}[!htb] + \footnotesize \centering + \begin{minipage}[c]{15cm} + \includestruct{listati/dqblk.h} + \end{minipage} + \normalsize + \caption{La struttura \structd{dqblk} per i dati delle quote disco.} + \label{fig:dqblk_struct} +\end{figure} + +% TODO trattare quote disco +% vedi man quotactl \subsection{La gestione delle \textit{capabilities}} \label{sec:proc_capabilities} @@ -4302,8 +4375,8 @@ livello di sistema operativo, come \index{SELinux} SELinux. Con questo supporto e con le ulteriori modifiche introdotte con il kernel 2.6.25 il meccanismo delle \textit{capabilities} è stato totalmente -rivoluzionato, rendendolo più aderente alle intezioni originali dello standard -POSIX, rimovendo il significato che fino ad allora aveva avuto la capacità +rivoluzionato, rendendolo più aderente alle intenzioni originali dello standard +POSIX, rimuovendo il significato che fino ad allora aveva avuto la capacità \macro{CAP\_SETPCAP} e le modalità di funzionamento del cosiddetto \itindex{capabilities~bounding~set} \textit{capabilities bounding set}. Ulteriori modifiche sono state apportate con il kernel 2.6.26 per @@ -4333,7 +4406,7 @@ L'utilizzo di tre distinti insiemi serve a fornire una interfaccia flessibile per l'uso delle \textit{capabilities}, con scopi analoghi a quelli per cui sono mantenuti i diversi insiemi di identificatori di sez.~\ref{sec:proc_setuid}; il loro significato, che è rimasto sostanzialmente -lo stesso anche dopo le modifiche seguite alla instroduzione delle +lo stesso anche dopo le modifiche seguite alla introduzione delle \textit{file capabilities} è il seguente: \begin{basedescript}{\desclabelwidth{2.1cm}\desclabelstyle{\nextlinelabel}} \item[\textit{permitted}] l'insieme delle \textit{capabilities} @@ -4364,7 +4437,7 @@ altri tre insiemi associabili a ciascun file.\footnote{la realizzazione viene soltanto quando il file che le porta viene eseguito come programma con una \func{exec}, e forniscono un meccanismo che consente l'esecuzione dello stesso con maggiori privilegi; in sostanza sono una sorta di estensione dell'uso del -\acr{suid} di root. Anche questi tre insiemi sono identicati con gli stessi +\acr{suid} di root. Anche questi tre insiemi sono identificati con gli stessi nomi, ma il loro significato è diverso: \begin{basedescript}{\desclabelwidth{2.1cm}\desclabelstyle{\nextlinelabel}} \item[\textit{permitted}] (chiamato originariamente \textit{forced}) l'insieme @@ -4413,7 +4486,7 @@ non sarà più disponibile per nessun processo a meno di un riavvio, eliminando così in forma definitiva quella capacità per tutti, compreso l'amministratore.\footnote{la qual cosa, visto il default usato per il \textit{capabilities bounding set}, significa anche che \const{CAP\_SETPCAP} - non è stata praticamente mai usata nella sua forma orginale.} + non è stata praticamente mai usata nella sua forma originale.} Con il kernel 2.6.25 e le \textit{file capabilities} il \textit{bounding set} è diventato una proprietà di ciascun processo, che viene propagata invariata @@ -4731,7 +4804,7 @@ messaggi delle code del SysV IPC (vedi sez.~\ref{sec:ipc_sysv_mq}). Questo modo di intendere ... da fare ... per cui a partire dal 2.6.24/5 è divenuta quella di impostare una capacità del -\textit{bounding set} nelle proprie \textit{inheritable} o rimoverla dal +\textit{bounding set} nelle proprie \textit{inheritable} o rimuoverla dal \textit{bounding set} stesso. Per la gestione delle \textit{capabilities} il kernel mette a disposizione due @@ -5261,15 +5334,15 @@ programmi e librerie) di cui il server potrebbe avere bisogno. % LocalWords: int const char oldpath newpath errno EXDEV EPERM st Smack SysV % LocalWords: EEXIST EMLINK EACCES ENAMETOOLONG ENOTDIR EFAULT ENOMEM EROFS ls % LocalWords: ELOOP ENOSPC EIO pathname nlink stat vfat fsck EISDIR ENOENT cap -% LocalWords: POSIX socket fifo sticky root system call count crash nell' init +% LocalWords: POSIX socket fifo sticky root system call count crash init linux % LocalWords: descriptor remove rename rmdir stdio glibc libc NFS DT obj dup % LocalWords: ENOTEMPTY EBUSY mount point EINVAL soft symbolic tab symlink fig % LocalWords: dangling access chdir chmod chown creat exec lchown lstat mkdir % LocalWords: mkfifo mknod opendir pathconf readlink truncate path buff size -% LocalWords: grub bootloader grep linux MAXSYMLINKS cat VFS sys dirname fcntl +% LocalWords: grub bootloader grep MAXSYMLINKS cat VFS sys dirname fcntl % LocalWords: dev umask IFREG IFBLK IFCHR IFIFO SVr sgid BSD SVID NULL from to % LocalWords: stream dirent EMFILE ENFILE dirfd SOURCE fchdir readdir struct -% LocalWords: EBADF namlen HAVE thread entry result value argument fileno ino +% LocalWords: EBADF namlen HAVE thread entry result value argument fileno % LocalWords: name TYPE OFF RECLEN UNKNOWN REG SOCK CHR BLK type IFTODT DTTOIF % LocalWords: DTYPE off reclen seekdir telldir void rewinddir closedir select % LocalWords: namelist compar malloc qsort alphasort versionsort strcoll myls @@ -5279,21 +5352,21 @@ programmi e librerie) di cui il server potrebbe avere bisogno. % LocalWords: EINTR mktemp mkstemp stlib template filename XXXXXX OpenBSD buf % LocalWords: mkdtemp fstat filedes nell'header padding ISREG ISDIR ISCHR IFMT % LocalWords: ISBLK ISFIFO ISLNK ISSOCK IFSOCK IFLNK IFDIR ISUID UID ISGID GID -% LocalWords: ISVTX IRUSR IWUSR IXUSR IRGRP IWGRP IXGRP IROTH IWOTH IXOTH du -% LocalWords: blocks blksize holes lseek TRUNC ftruncate length lenght ETXTBSY +% LocalWords: ISVTX IRUSR IWUSR IXUSR IRGRP IWGRP IXGRP IROTH IWOTH IXOTH +% LocalWords: blocks blksize holes lseek TRUNC ftruncate ETXTBSY length % LocalWords: hole atime read utime mtime write ctime modification leafnode cp % LocalWords: make fchmod fchown utimbuf times actime modtime Mac owner uid fs % LocalWords: gid Control List patch mandatory control execute group other all -% LocalWords: dell' effective passwd IGID locking swap saved text IRWXU IRWXG -% LocalWords: IRWXO ext reiser capability FSETID mask capabilities chroot jail -% LocalWords: FTP Di filter reiserfs Attributes Solaris FreeBSD libacl hash +% LocalWords: effective passwd IGID locking swap saved text IRWXU IRWXG +% LocalWords: IRWXO capability FSETID mask capabilities chroot jail +% LocalWords: FTP filter Attributes Solaris FreeBSD libacl hash at % LocalWords: XFS SELinux namespace attribute security trusted Draft Modules % LocalWords: attributes mime ADMIN FOWNER libattr lattr getxattr lgetxattr of % LocalWords: fgetxattr attr ssize ENOATTR ENOTSUP NUL setxattr lsetxattr list % LocalWords: fsetxattr flags XATTR REPLACE listxattr llistxattr flistxattr by -% LocalWords: removexattr lremovexattr fremovexattr attributename lacl acl tv +% LocalWords: removexattr lremovexattr fremovexattr attributename acl % LocalWords: OBJ setfacl len any prefix separator options NUMERIC IDS SMART -% LocalWords: INDENT major number IDE Documentation makedev proc copy +% LocalWords: INDENT major number IDE Documentation makedev proc copy LNK long % LocalWords: euidaccess eaccess delete def tag qualifier permset calendar NOW % LocalWords: mutt noatime relatime strictatime atim nsec mtim ctim atimensec % LocalWords: mtimensec utimes timeval futimes lutimes ENOSYS futimens OMIT @@ -5306,8 +5379,13 @@ programmi e librerie) di cui il server potrebbe avere bisogno. % LocalWords: LEASE lease SETFCAP AUDIT permitted inherited inheritable AND % LocalWords: bounding execve fork capget capset header hdrp datap ESRCH undef % LocalWords: version libcap lcap clear ncap caps pag capgetp CapInh CapPrm -% LocalWords: fffffeff CapEff getcap dell'IPC scheduling dell'I lookup dcookie +% LocalWords: fffffeff CapEff getcap scheduling lookup % LocalWords: NEWNS unshare nice NUMA ioctl journaling close XOPEN fdopendir +% LocalWords: btrfs mkostemp extN ReiserFS JFS Posix usrquota grpquota EDQUOT +% LocalWords: aquota quotacheck limit grace period quotactl cmd caddr addr +% LocalWords: QUOTAON ENODEV ENOPKG ENOTBLK GETQUOTA SETQUOTA SETUSE SETQLIM +% LocalWords: forced allowed sendmail SYSLOG WAKE ALARM CLOCK BOOTTIME +% LocalWords: REALTIME securebits %%% Local Variables: %%% mode: latex diff --git a/listati/dqblk.h b/listati/dqblk.h new file mode 100644 index 0000000..d84d5b3 --- /dev/null +++ b/listati/dqblk.h @@ -0,0 +1,12 @@ +struct dqblk + { + u_int64_t dqb_bhardlimit; /* absolute limit on disk quota blocks alloc */ + u_int64_t dqb_bsoftlimit; /* preferred limit on disk quota blocks */ + u_int64_t dqb_curspace; /* current quota block count */ + u_int64_t dqb_ihardlimit; /* maximum # allocated inodes */ + u_int64_t dqb_isoftlimit; /* preferred inode limit */ + u_int64_t dqb_curinodes; /* current # allocated inodes */ + u_int64_t dqb_btime; /* time limit for excessive disk use */ + u_int64_t dqb_itime; /* time limit for excessive files */ + u_int32_t dqb_valid; /* bitmask of QIF_* constants */ + }; diff --git a/listati/dqinfo.h b/listati/dqinfo.h new file mode 100644 index 0000000..fcafc65 --- /dev/null +++ b/listati/dqinfo.h @@ -0,0 +1,7 @@ +struct dqinfo + { + u_int64_t dqi_bgrace; + u_int64_t dqi_igrace; + u_int32_t dqi_flags; + u_int32_t dqi_valid; + }; -- 2.30.2