рдпрд╣рд╛рдВ рддрдХ тАЛтАЛрдХрд┐ рдЙрдмрдВрдЯреВ рдХреЗ рд╕рд╛рде рдЕрдкрдиреЗ рдкрд░рд┐рдЪрд┐рдд рдХреЗ рдкрд╣рд▓реЗ рд╡рд░реНрд╖ рдореЗрдВ, рдореБрдЭреЗ рдЗрд╕ рдмрд╛рдд рдореЗрдВ рджрд┐рд▓рдЪрд╕реНрдкреА рд╣реЛ рдЧрдИ рдХрд┐ рдЗрд╕ рдУрдПрд╕ рдХреЗ рдХрд░реНрдиреЗрд▓ рдХреИрд╕реЗ рдХрд╛рдо рдХрд░рддреЗ рд╣реИрдВред рдореИрдВрдиреЗ рдЗрд╕рдХрд╛ рдкрддрд╛ рд▓рдЧрд╛рдиреЗ рдХреЗ рд▓рд┐рдП рдкреВрд░реА рдЧрдВрднреАрд░рддрд╛ рдХреЗ рд╕рд╛рде рдирд┐рд░реНрдгрдп рд▓рд┐рдпрд╛, 80-рдореЗрдЧрд╛рдмрд╛рдЗрдЯ рд╕реНрд░реЛрдд рд╕рдВрдЧреНрд░рд╣ рдбрд╛рдЙрдирд▓реЛрдб рдХрд┐рдпрд╛, рдФрд░ ... рдпрд╣ рдмрд╛рдд рд╣реИ! рдореБрдЭреЗ рдирд╣реАрдВ рдкрддрд╛ рдерд╛ рдХрд┐ рдХрд╣рд╛рдВ рд╕реЗ рд╢реБрд░реВ рдХрд░рдирд╛ рд╣реИ, рди рд╣реА рдХреИрд╕реЗ рдЦрддреНрдо рдХрд░рдирд╛ рд╣реИред рдореИрдВрдиреЗ рдмрджрд▓реЗ рдореЗрдВ рдпрд╛рджреГрдЪреНрдЫрд┐рдХ рдлрд╛рдЗрд▓реЗрдВ рдЦреЛрд▓реАрдВ рдФрд░ рд╡рд╣реАрдВ рдЦреЛ рдЧрдпрд╛ред рдореБрдЭреЗ рд▓рдЧрддрд╛ рд╣реИ рдХрд┐ рдпрд╣ рд╣рд░ рдЕрдиреБрднрд╡реА Linuxoid рдХреЗ рд╕рд╛рде рд╣реБрдЖред рдЕрдм рдореБрдЭреЗ рдЕрдиреБрднрд╡ рдкреНрд░рд╛рдкреНрдд рд╣реБрдЖ рд╣реИ рдФрд░ рдореИрдВ рдЗрд╕реЗ рд╕рд╛рдЭрд╛ рдХрд░рдирд╛ рдЪрд╛рд╣реВрдВрдЧрд╛редрдЗрд╕ рд▓реЗрдЦ рдореЗрдВ рдореИрдВ рд╕рдордЭрд╛рдКрдВрдЧрд╛ рдХрд┐ рдореИрдВрдиреЗ mkdir рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХреЛрдб рдХреА рдЦреЛрдЬ рдХреИрд╕реЗ рдХреАред
рд╢реБрд░реБрдЖрдд рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП, mkdir рдлрд╝рдВрдХреНрд╢рди рдХреЛ
sys/stat.h
рдореЗрдВ рдкрд░рд┐рднрд╛рд╖рд┐рдд рдХрд┐рдпрд╛ рдЧрдпрд╛ рд╣реИред рдкреНрд░реЛрдЯреЛрдЯрд╛рдЗрдк рдЗрд╕ рдкреНрд░рдХрд╛рд░ рд╣реИ:
extern int mkdir (__const char *__path, __mode_t __mode) __THROW __nonnull ((1));
рдпрд╣ рд╣реЗрдбрд░ рдлрд╝рд╛рдЗрд▓ POSIX рдорд╛рдирдХ рдХрд╛ рд╣рд┐рд╕реНрд╕рд╛ рд╣реИред рд▓рд┐рдирдХреНрд╕ рд▓рдЧрднрдЧ рдкреВрд░реА рддрд░рд╣ рд╕реЗ POSIX- рд╕рдВрдЧрдд рд╣реИ, рдЬрд┐рд╕рдХрд╛ рдЕрд░реНрде рд╣реИ рдХрд┐ рдЗрд╕реЗ рдХреЗрд╡рд▓ рд╣рд╕реНрддрд╛рдХреНрд╖рд░ рдХреЗ рд╕рд╛рде mkdir рдХреЛ рд▓рд╛рдЧреВ рдХрд░рдирд╛ рдЪрд╛рд╣рд┐рдПред
рд▓реЗрдХрд┐рди рд╣рд╕реНрддрд╛рдХреНрд╖рд░ рдЬрд╛рдирдиреЗ рдХреЗ рдмрд╛рд╡рдЬреВрдж, рд╡рд╛рд╕реНрддрд╡рд┐рдХ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХреЛрдб рдвреВрдВрдврдирд╛ рдЖрд╕рд╛рди рдирд╣реАрдВ рд╣реИ ...
рдФрд░ рд╕рдЪ рдореЗрдВ
ack "int mkdir"
рд╡рд╛рдкрд╕ рдЖрдПрдЧрд╛:
рд╕реБрд░рдХреНрд╖рд╛ / рдЗрдирдХреЛрдб
103: рд╕реНрдерд┐рд░ рдЗрдВрдЯ mkdir (рд╕реНрдЯреНрд░рдХреНрдЪрд░ рдЗрдиреЛрдб * dir, рд╕реНрдЯреНрд░рдХреНрдЪрд░ рдбреЗрдВрдЯреНрд░реА * рдбреЗрдВрдЯреНрд░реА, рдЗрдВрдЯ рдореЛрдб)
рдЙрдкрдХрд░рдг / рдкреВрд░реНрдг / рдЙрдкрдпреЛрдЧ / рдЙрдкрдпреЛрдЧ.c
4: int mkdir_p (char * path, mode_t mode)
рдЙрдкрдХрд░рдг / рдЗрддреНрд░ / рдЙрдкрдпреЛрдЧ / рдЙрдкрдпреЛрдЧ
259: int mkdir_p (char * path, mode_t mode);
рдпрд╣ рд╕реНрдкрд╖реНрдЯ рд╣реИ рдХрд┐ рдПрдХ рднреА рд╣рд╕реНрддрд╛рдХреНрд╖рд░ рдкреВрд░реА рддрд░рд╣ рд╕реЗ рдореЗрд▓ рдирд╣реАрдВ рдЦрд╛рддрд╛ рд╣реИред рдПрдордХреЗрдбреАрдЖрд░ рдлрд╝рдВрдХреНрд╢рди рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рдХрд╣рд╛рдБ рд╕реНрдерд┐рдд рд╣реИ? рд▓рд┐рдирдХреНрд╕ рдХрд░реНрдиреЗрд▓ рдореЗрдВ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХреЗ рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рдХреЛ рдЦреЛрдЬрдиреЗ рдХреЗ рд▓рд┐рдП рдПрд▓реНрдЧреЛрд░рд┐рдереНрдо рдХреНрдпрд╛ рд╣реИ?
рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдирд┐рдпрдорд┐рдд рдХрд╛рд░реНрдпреЛрдВ рдХреА рддрд░рд╣ рдХрд╛рдо рдирд╣реАрдВ рдХрд░рддреЗ рд╣реИрдВред рдЕрдзрд┐рдХ рд╕рдЯреАрдХ рд░реВрдк рд╕реЗ, рд╡реЗ рд╕рднреА рдХрд╛рд░реНрдп рдирд╣реАрдВ рд╣реИрдВред рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХреЛ рдирд┐рд╖реНрдкрд╛рджрд┐рдд рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП, рдЖрдкрдХреЛ рдХреБрдЫ рдХреЛрдбрд╛рдВрддрд░рдХ рдХреЛрдб рдХреА рдЖрд╡рд╢реНрдпрдХрддрд╛ рд╣реЛрддреА рд╣реИред рджреНрд╡рд╛рд░рд╛ рдФрд░ рдмрдбрд╝реЗ, рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдирдВрдмрд░ рдХреЛ EAX рд░рдЬрд┐рд╕реНрдЯрд░ рдореЗрдВ рд░рдЦрд╛ рдЬрд╛рддрд╛ рд╣реИ (рд╡реИрд╕реЗ, рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдирдВрдмрд░ рджреНрд╡рд╛рд░рд╛ рдПрдХреНрд╕реЗрд╕ рдХрд┐рдпрд╛ рдЬрд╛рддрд╛ рд╣реИ, рдПрдбреНрд░реЗрд╕ рдирд╣реАрдВ), рд╢реЗрд╖ рд░рдЬрд┐рд╕реНрдЯрд░ рдореЗрдВ рджрд▓реАрд▓реЗрдВ рд░рдЦреА рдЬрд╛рддреА рд╣реИрдВ: рдкрд╣рд▓рд╛ EBX рдореЗрдВ, рджреВрд╕рд░рд╛ ECX рдореЗрдВ, рджреВрд╕рд░рд╛ EDX рдореЗрдВ, ESX рдореЗрдВ рдЪреМрдерд╛ред рдИрдбреАрдЖрдИ рдореЗрдВ рдкрд╛рдВрдЪрд╡реЗрдВред рд╡реИрд╕реЗ, рдпрд╣реА рдХрд╛рд░рдг рд╣реИ рдХрд┐ рдПрдХ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдореЗрдВ 5 рд╕реЗ рдЕрдзрд┐рдХ рддрд░реНрдХ рдирд╣реАрдВ рд╣реЛ рд╕рдХрддреЗ рд╣реИрдВред рд╕рднреА рдЖрд╡рд╢реНрдпрдХ рдорд╛рди рд╕реНрдерд┐рдд рд╣реЛрдиреЗ рдХреЗ рдмрд╛рдж, рдкреНрд░реЛрдЧреНрд░рд╛рдо рдЬреЛ рдПрдХ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХрд░рдирд╛ рдЪрд╛рд╣рддрд╛ рд╣реИ, рд╡рд╣ 128 рд╡рд╛рдВ рд╡реНрдпрд╡рдзрд╛рди рдХрд░рддрд╛ рд╣реИ (рдХреЛрдбрд╛рдВрддрд░рдХ: рдЗрдВрдЯ 0 08080 рдкрд░)ред рд░реБрдХрд╛рд╡рдЯ рдкреНрд░реЛрд╕реЗрд╕рд░ рдХреЛ рдХрд░реНрдиреЗрд▓ рдореЛрдб рдореЗрдВ рд░рдЦрддрд╛ рд╣реИ рдФрд░ рдХрд░реНрдиреЗрд▓ рдХреЗ рд╕рд╛рде рдкрд╣рд▓реЗ рд╕реЗ рд╕рд╣рдордд рдкрддреЗ рдкрд░ рдирд┐рдпрдВрддреНрд░рдг рд╕реНрдерд╛рдирд╛рдВрддрд░рд┐рдд рдХрд░рддрд╛ рд╣реИред рдЬреИрд╕рд╛ рдХрд┐ рдЖрдк рджреЗрдЦ рд╕рдХрддреЗ рд╣реИрдВ, рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рд╕реА-рдлрд╝рдВрдХреНрд╢рдВрд╕ рдХреА рддреБрд▓рдирд╛ рдореЗрдВ рдирд┐рдЪрд▓реЗ рд╕реНрддрд░ рдкрд░ рдХрд╛рдо рдХрд░рддреЗ рд╣реИрдВред
рдХрд┐рд╕реА рднреА рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХреА рд╕рдВрдЦреНрдпрд╛
usr/include/asm*/unistd.h
рдореЗрдВ рдкрд╛рдИ рдЬрд╛ рд╕рдХрддреА рд╣реИ
usr/include/asm*/unistd.h
:
#define __NR_mkdir 83 __SYSCALL(__NR_mkdir, sys_mkdir)
рдпрд╛рдиреА mkdir рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ 83 рдирдВрдмрд░ рдХреА рд╣реИред
рдпрджрд┐ рдЖрдкрдиреЗ рд▓рд┐рдирдХреНрд╕ рдХреЗ рддрд╣рдд рдпреВрдЬрд░ рд╕реНрдкреЗрд╕ рдореЗрдВ рдкреНрд░реЛрдЧреНрд░рд╛рдо рдХрд┐рдпрд╛ рд╣реИ, рддреЛ рдЖрдк рд╢рд╛рдпрдж рдЬрд╛рдирддреЗ рд╣реИрдВ рдХрд┐, рдПрдХ рдирд┐рдпрдо рдХреЗ рд░реВрдк рдореЗрдВ, рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП C рдлрд╝рдВрдХреНрд╢рди рдХрд╛ рдЙрдкрдпреЛрдЧ рдХрд┐рдпрд╛ рдЬрд╛рддрд╛ рд╣реИред рд╡реЗ рдХрд╣рд╛рдБ рд╕реЗ рдЖрддреЗ рд╣реИрдВ? рд╡реЗ рдХрд╛рд░реНрдп GNU libc рд▓рд╛рдЗрдмреНрд░реЗрд░реА рд╕реЗ рд╕рд┐рд░реНрдл рд░реИрдкрд░ рд╣реИрдВред рдкреНрд░рддреНрдпреЗрдХ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдореЗрдВ рдПрдХ рд░реИрдкрд░ рдлрд╝рдВрдХреНрд╢рди рд╣реЛрддрд╛ рд╣реИред рдХрд╛рд░реНрдп рд╕реНрд╡рдпрдВ рд╕рднреА рд╕рдорд╛рди рд╡реНрдпрд╡рдзрд╛рди рдХрд░рддреЗ рд╣реИрдВред
рддреЛ рдЕрдм рдореБрдХреНрджрд┐рд░ рдХреА рддрд▓рд╛рд╢ рдХрд╣рд╛рдБ рдХрд░реЗрдВ? рд╕рд┐рджреНрдзрд╛рдВрдд рд░реВрдк рдореЗрдВ, рдПрдХ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХреЛ рдХреЗрд╡рд▓ рдХреЛрдбрд╛рдВрддрд░рдХ рдореЗрдВ рд▓рд╛рдЧреВ рдХрд┐рдпрд╛ рдЬрд╛ рд╕рдХрддрд╛ рд╣реИ, рдлрд┐рд░ рд╕рдВрдмрдВрдзрд┐рдд рд╕реА-рдлрд╝рдВрдХреНрд╢рди рдмрд╕ рдореМрдЬреВрдж рдирд╣реАрдВ рд╣реЛрдЧрд╛, рд▓реЗрдХрд┐рди рдРрд╕рд╛ рдирд╣реАрдВ рд╣реИред рд▓рд┐рдирдХреНрд╕ рдкрд░, рд╣рд░ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓
include/linux/syscalls.h
:
asmlinkage long sys_mkdir(const char __user *pathname, int mode);
рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рдХрд░реНрдиреЗрд▓ рдХреЗ рд╕рдВрдЧрдд рднрд╛рдЧ рдореЗрдВ рд╕реНрдерд┐рдд рд╣реИред рдпрд╣рд╛рдБ рдЖрдкрдХреЛ рдпрд╣ рдЬрд╛рдирдирд╛ рд╣реЛрдЧрд╛ рдХрд┐ mkdir VFS рдлрд╛рдЗрд▓ рд╕рдмрд╕рд┐рд╕реНрдЯрдо рдХрд╛ рд╣рд┐рд╕реНрд╕рд╛ рд╣реИ рдФрд░ рдЗрд╕реЗ
fs/namei.c
рдореЗрдВ рдкрд░рд┐рднрд╛рд╖рд┐рдд рдХрд┐рдпрд╛ рдЧрдпрд╛ рд╣реИ:
SYSCALL_DEFINE2(mkdir, const char __user *, pathname, umode_t, mode) { return sys_mkdirat(AT_FDCWD, pathname, mode); }
SYSCALL_DEFINE2 SYSCALL_DEFINEx рд╢реНрд░реГрдВрдЦрд▓рд╛ рдореЗрдВ рдореИрдХреНрд░реЛрдЬрд╝ рдореЗрдВ рд╕реЗ рдПрдХ рд╣реИ, рдЬрд╣рд╛рдБ x рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХреЗ рд▓рд┐рдП рддрд░реНрдХреЛрдВ рдХреА рд╕рдВрдЦреНрдпрд╛ рд╣реИред рдЙрдкрд░реЛрдХреНрдд рдХреЛрдб рдореЗрдВ, рдПрдХ рдФрд░ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХрд╣рд╛ рдЬрд╛рддрд╛ рд╣реИ - sys_mkdirat, рдЬреЛ
fs/namei.c
рдореЗрдВ рднреА рд╕реНрдерд┐рдд рд╣реИред рдХреГрдкрдпрд╛ рдзреНрдпрд╛рди рджреЗрдВ рдХрд┐ рдпрд╣рд╛рдВ рдлрд╝рдВрдХреНрд╢рди рдХреЙрд▓ рдХрд░рдХреЗ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдХрд┐рдпрд╛ рдЬрд╛рддрд╛ рд╣реИ, рдХреНрдпреЛрдВрдХрд┐ рдХреЙрд▓рд┐рдВрдЧ рдХреЛрдб рдкрд╣рд▓реЗ рд╕реЗ рд╣реА рдХрд░реНрдиреЗрд▓ рдореЛрдб рдореЗрдВ рдирд┐рд╖реНрдкрд╛рджрд┐рдд рд╣реЛ рд░рд╣рд╛ рд╣реИред
SYSCALL_DEFINE3(mkdirat, int, dfd, const char __user *, pathname, umode_t, mode) { struct dentry *dentry; struct path path; int error; dentry = user_path_create(dfd, pathname, &path, 1); if (IS_ERR(dentry)) return PTR_ERR(dentry); if (!IS_POSIXACL(path.dentry->d_inode)) mode &= ~current_umask(); error = security_path_mkdir(&path, dentry, mode); if (!error) error = vfs_mkdir(path.dentry->d_inode, dentry, mode); done_path_create(&path, dentry); return error; }
рдФрд░ рдпрд╣рд╛рдБ рдкрд╣рд▓реЗ рд╕реЗ рд╣реА рджрд┐рд▓рдЪрд╕реНрдк рд╣реИ! рд╣рдо рдкрд╣рд▓реЗ рдЪреЗрдХ рдФрд░ рдлрд┐рд░ рд╕реЗ рджреВрд╕рд░реЗ рдлрд╝рдВрдХреНрд╢рди рдкрд░ рдирд┐рдпрдВрддреНрд░рдг рдХреЗ рд╣рд╕реНрддрд╛рдВрддрд░рдг рдХреЛ рдкреВрд░рд╛ рдХрд░рддреЗ рд╣реИрдВ - vfs_mkdir, рдЬреЛ рд╕рднреА рдХреЛ рдПрдХ рд╣реА
fs/namei.h
рдореЗрдВ рдкрд░рд┐рднрд╛рд╖рд┐рдд рдХрд┐рдпрд╛ рдЧрдпрд╛ рд╣реИ:
int vfs_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode) { int error = may_create(dir, dentry); unsigned max_links = dir->i_sb->s_max_links; if (error) return error; if (!dir->i_op->mkdir) return -EPERM; mode &= (S_IRWXUGO|S_ISVTX); error = security_inode_mkdir(dir, dentry, mode); if (error) return error; if (max_links && dir->i_nlink >= max_links) return -EMLINK; error = dir->i_op->mkdir(dir, dentry, mode); if (!error) fsnotify_mkdir(dir, dentry); return error; }
рдПрдХ рдФрд░ рдЬрд╛рдБрдЪ, рдирд┐рдпрдВрддреНрд░рдг рдХрд╛ рдПрдХ рдФрд░ рд╣рд╕реНрддрд╛рдВрддрд░рдгред рдпрд╣ рдХрд╣рдиреЗ рдпреЛрдЧреНрдп рд╣реИ рдХрд┐ рд▓рд┐рдирдХреНрд╕ рдПрдХ рдмрд╣реБ-рд╕реНрддрд░реАрдп рдкреНрд░рдгрд╛рд▓реА рд╣реИ, рдЬрд╣рд╛рдВ рд╕рд┐рд╕реНрдЯрдо рдХреЗ рд╡рд┐рднрд┐рдиреНрди рд╣рд┐рд╕реНрд╕реЛрдВ рдореЗрдВ рдЬрд┐рдореНрдореЗрджрд╛рд░рд┐рдпрд╛рдВ рд╡рд┐рддрд░рд┐рдд рдХреА рдЬрд╛рддреА рд╣реИрдВред рдЗрд╕рд▓рд┐рдП, рдпрд╣ рдЕрдЬреАрдм рдирд╣реАрдВ рд╣реИ рдХрд┐ рдКрдкрд░ рджрд┐рдП рдЧрдП рдХреЛрдб рдореЗрдВ, рддрд░реНрдХ рдХреЛ рд▓рдЧрд╛рддрд╛рд░ рдкреНрд░рддреНрдпрд╛рдпреЛрдЬрд┐рдд рдХрд┐рдпрд╛ рдЬрд╛рддрд╛ рд╣реИред рдХреЛрдб рдХреЗ рдЕрдВрддрд┐рдо рдЯреБрдХрдбрд╝реЗ рдореЗрдВ, dir-> i_op-> mkdir (dir, dentry, mode) рдХрд╣рд╛ рдЬрд╛рддрд╛ рд╣реИред рд░рд╛рд╣ рдХрд╛ рдЕрдиреБрд╕рд░рдг рдХрд░реЛ! dir рдЯрд╛рдЗрдк рдЗрдиреЛрдб * рдХрд╛ рд╣реИред рдЗрдиреЛрдб рд╕рдВрд░рдЪрдирд╛ рдХреА рдкрд░рд┐рднрд╛рд╖рд╛ рд╕реЗ, рд╣рдо рд╕реАрдЦрддреЗ рд╣реИрдВ рдХрд┐ i_op рдкреЙрдЗрдВрдЯрд░ inode_operations * рдкреНрд░рдХрд╛рд░ рдХрд╛ рд╣реИред рдЕрдВрддрд┐рдо рд╕рдВрд░рдЪрдирд╛ рдореЗрдВ рдЗрд╕ рдиреЛрдб рдкрд░ рдХрд┐рдП рдЬрд╛рдиреЗ рд╡рд╛рд▓реЗ рд╕рдВрдЪрд╛рд▓рди рдХреЗ рдХрд╛рд░реНрдпреЛрдВ рдХреЗ рд▓рд┐рдП рдкреЙрдЗрдВрдЯрд░реНрд╕ рд╣реЛрддреЗ рд╣реИрдВ, рдФрд░ рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рдЕрд▓рдЧ-рдЕрд▓рдЧ рдлрд╝рд╛рдЗрд▓ рд╕рд┐рд╕реНрдЯрдо рдХреЗ рд▓рд┐рдП рдЕрд▓рдЧ-рдЕрд▓рдЧ рд╣реЛрддреЗ рд╣реИрдВред рдпрд╣ рд╣реИ рдХрд┐, рдЬреЛ рдлрд╝рд╛рдЗрд▓ рд╕рд┐рд╕реНрдЯрдо рд╣рдорд╛рд░реЗ dir рд╕реЗ рд╕рдВрдмрдВрдзрд┐рдд рд╣реИ, рдЙрд╕ рдкрд░ рдирд┐рд░реНрднрд░ рдХрд░рддрд╛ рд╣реИ рдХрд┐ рдЗрдиреЛрдб_рдСрдкрд░реЗрд╢рди рд╕рдВрд░рдЪрдирд╛ рдореЗрдВ рдХреБрдЫ рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рдХреЗ рд▓рд┐рдП рдкреЙрдЗрдВрдЯрд░реНрд╕ рд╣реЛрдВрдЧреЗред
рдЙрджрд╛рд╣рд░рдг рдХреЗ рд▓рд┐рдП, ext4 рдХреЗ рд▓рд┐рдП, рд╣рдо fs / ext4 / namei.c рдореЗрдВ mkdir рдХрд╛ рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рдкрд╛рддреЗ рд╣реИрдВ
рд╡рд╛рд╕реНрддрд╡ рдореЗрдВ рд╡рд╛рдВрдЫрд┐рдд рдХреЛрдб! static int ext4_mkdir(struct inode *dir, struct dentry *dentry, umode_t mode) { handle_t *handle; struct inode *inode; struct buffer_head *dir_block = NULL; struct ext4_dir_entry_2 *de; struct ext4_dir_entry_tail *t; unsigned int blocksize = dir->i_sb->s_blocksize; int csum_size = 0; int err, retries = 0; if (EXT4_HAS_RO_COMPAT_FEATURE(dir->i_sb, EXT4_FEATURE_RO_COMPAT_METADATA_CSUM)) csum_size = sizeof(struct ext4_dir_entry_tail); if (EXT4_DIR_LINK_MAX(dir)) return -EMLINK; dquot_initialize(dir); retry: handle = ext4_journal_start(dir, EXT4_DATA_TRANS_BLOCKS(dir->i_sb) + EXT4_INDEX_EXTRA_TRANS_BLOCKS + 3 + EXT4_MAXQUOTAS_INIT_BLOCKS(dir->i_sb)); if (IS_ERR(handle)) return PTR_ERR(handle); if (IS_DIRSYNC(dir)) ext4_handle_sync(handle); inode = ext4_new_inode(handle, dir, S_IFDIR | mode, &dentry->d_name, 0, NULL); err = PTR_ERR(inode); if (IS_ERR(inode)) goto out_stop; inode->i_op = &ext4_dir_inode_operations; inode->i_fop = &ext4_dir_operations; inode->i_size = EXT4_I(inode)->i_disksize = inode->i_sb->s_blocksize; if (!(dir_block = ext4_bread(handle, inode, 0, 1, &err))) { if (!err) { err = -EIO; ext4_error(inode->i_sb, "Directory hole detected on inode %lu\n", inode->i_ino); } goto out_clear_inode; } BUFFER_TRACE(dir_block, "get_write_access"); err = ext4_journal_get_write_access(handle, dir_block); if (err) goto out_clear_inode; de = (struct ext4_dir_entry_2 *) dir_block->b_data; de->inode = cpu_to_le32(inode->i_ino); de->name_len = 1; de->rec_len = ext4_rec_len_to_disk(EXT4_DIR_REC_LEN(de->name_len), blocksize); strcpy(de->name, "."); ext4_set_de_type(dir->i_sb, de, S_IFDIR); de = ext4_next_entry(de, blocksize); de->inode = cpu_to_le32(dir->i_ino); de->rec_len = ext4_rec_len_to_disk(blocksize - (csum_size + EXT4_DIR_REC_LEN(1)), blocksize); de->name_len = 2; strcpy(de->name, ".."); ext4_set_de_type(dir->i_sb, de, S_IFDIR); set_nlink(inode, 2); if (csum_size) { t = EXT4_DIRENT_TAIL(dir_block->b_data, blocksize); initialize_dirent_tail(t, blocksize); } BUFFER_TRACE(dir_block, "call ext4_handle_dirty_metadata"); err = ext4_handle_dirty_dirent_node(handle, inode, dir_block); if (err) goto out_clear_inode; set_buffer_verified(dir_block); err = ext4_mark_inode_dirty(handle, inode); if (!err) err = ext4_add_entry(handle, dentry, inode); if (err) { out_clear_inode: clear_nlink(inode); unlock_new_inode(inode); ext4_mark_inode_dirty(handle, inode); iput(inode); goto out_stop; } ext4_inc_count(handle, dir); ext4_update_dx_flag(dir); err = ext4_mark_inode_dirty(handle, dir); if (err) goto out_clear_inode; unlock_new_inode(inode); d_instantiate(dentry, inode); out_stop: brelse(dir_block); ext4_journal_stop(handle); if (err == -ENOSPC && ext4_should_retry_alloc(dir->i_sb, &retries)) goto retry; return err; }
рдХрд░реНрдиреЗрд▓ рдХреЗ рд╕рдВрдЪрд╛рд▓рди рдХреЛ рд╕рдордЭрдирд╛ рдХрд┐рд╕реА рднреА рд▓рд┐рдирдХреНрд╕реЙрдЗрдб рдХреЗ рд╢рд╕реНрддреНрд░рд╛рдЧрд╛рд░ рдореЗрдВ рдПрдХ рдЙрдкрдпреЛрдЧреА рдХреМрд╢рд▓ рд╣реИред рдЖрд╢рд╛ рд╣реИ рдХрд┐ рдпрд╣ рд▓реЗрдЦ рднреА рдЙрдкрдпреЛрдЧреА рд░рд╣рд╛ рд╣реИ!
рд╕рдВрд╕рд╛рдзрди:
рд▓рд┐рдирдХреНрд╕ рд╕рд┐рд╕реНрдЯрдо рдХреЙрд▓ рдЯреЗрдмрд▓рд▓рд┐рдирдХреНрд╕ 3.6 рд╕реНрд░реЛрддUnix.stackexchange.com рдкрд░ рдЪрд░реНрдЪрд╛