- unstable 4.31.0-1
| fanotify_mark(2) | System Calls Manual | fanotify_mark(2) |
الاسم¶
fanotify_mark - إضافة علامة fanotify على كائن نظام ملفات، أو إزالتها، أو تعديلها
المكتبة¶
مكتبة سي المعيارية (libc، -lc)
موجز¶
#include <sys/fanotify.h>
int fanotify_mark(int fanotify_fd, unsigned int flags,
uint64_t mask, int dirfd,
const char *_Nullable path);
الوصف¶
للحصول على نظرة عامة حول واجهة برمجة تطبيقات fanotify، راجع fanotify(7).
تضيف fanotify_mark() علامة fanotify على كائن نظام ملفات، أو تزيلها، أو تعدلها. يجب أن يمتلك المستدعِي إذن القراءة على كائن نظام الملفات المراد وسمه.
المعطى fanotify_fd هو واصف ملف أعادته الدالة fanotify_init(2).
flags هو قناع بتات يصف التعديل المراد تنفيذه. يجب أن يتضمن قيمة واحدة بالضبط من القيم التالية:
- FAN_MARK_ADD
- ستُضاف الأحداث في mask إلى قناع العلامة (أو إلى قناع التجاهل). يجب ألا يكون mask فارغًا وإلا سيحدث الخطأ EINVAL.
- FAN_MARK_REMOVE
- ستُزال الأحداث في المعطى mask من قناع العلامة (أو من قناع التجاهل). يجب ألا يكون mask فارغًا وإلا سيحدث الخطأ EINVAL.
- FAN_MARK_FLUSH
- إزالة إما كافة علامات أنظمة الملفات، أو كافة علامات نقاط الوصل، أو كافة علامات الأدلة والملفات من مجموعة fanotify. إذا احتوى flags على FAN_MARK_MOUNT، فستُزال كافة علامات نقاط الوصل من المجموعة. وإذا احتوى flags على FAN_MARK_FILESYSTEM، فستُزال كافة علامات أنظمة الملفات من المجموعة. خلاف ذلك، تُزال كافة علامات الأدلة والملفات. لا يمكن استخدام أي علم آخر مع FAN_MARK_FLUSH سوى واحد على الأكثر من الأعلام FAN_MARK_MNTNS أو FAN_MARK_MOUNT أو FAN_MARK_FILESYSTEM. يُتجاهل mask.
إذا لم تُحدد أي من القيم أعلاه، أو حُدد أكثر من واحدة، سيفشل الاستدعاء بالخطأ EINVAL.
بالإضافة إلى ذلك، يمكن دمج صفر أو أكثر من القيم التالية مع flags باستخدام العملية المنطقية OR:
- FAN_MARK_DONT_FOLLOW
- إذا كان path وصلة رمزية، فستوسم الوصلة نفسها بدلاً من الملف الذي تشير إليه. (بشكل مبدئي، تتبع fanotify_mark() الوصلة path إذا كانت وصلة رمزية).
- FAN_MARK_ONLYDIR
- إذا لم يكن كائن نظام الملفات المراد وسمه دليلاً، فسيُرفع الخطأ ENOTDIR.
- FAN_MARK_MNTNS (منذ لينكس 6.14)
- وسم مساحة اسم الوصل المحددة بواسطة path. إذا كان path لا يمثل مساحة اسم وصل (مثلاً /proc/pid/ns/mnt)، سيفشل الاستدعاء بالخطأ EINVAL. يتطلب ذلك مجموعة fanotify هُيئت بالعلم FAN_REPORT_MNT.
- FAN_MARK_MOUNT
- وسم الوصلة المحددة بواسطة path. إذا لم يكن path نقطة وصل بحد ذاته، فستُوسم الوصلة التي تحتوي على path. ستُراقب جميع الأدلة، والأدلة الفرعية، والملفات الموجودة في الوصلة. لا يمكن تقديم الأحداث التي تتطلب تعريف كائنات نظام الملفات بواسطة مقابض الملفات، مثل FAN_CREATE و FAN_ATTRIB و FAN_MOVE و FAN_DELETE_SELF، كقناع mask_ عندما تحتوي flags على FAN_MARK_MOUNT. ستؤدي محاولة القيام بذلك إلى إرجاع الخطأ EINVAL. يتطلب استخدام هذه الراية قدرة CAP_SYS_ADMIN.
- FAN_MARK_FILESYSTEM (منذ لينكس 4.20)
- وسم نظام الملفات المحدد بواسطة path. سيُوسم نظام الملفات الذي يحتوي على path. ستُراقب كافة الملفات والأدلة الموجودة في نظام الملفات من أي نقطة وصل. يتطلب استخدام هذا العلم صلاحية CAP_SYS_ADMIN.
- FAN_MARK_IGNORED_MASK
- ستُضاف الأحداث في mask إلى قناع التجاهل أو تُزال منه.لاحظ أن العلمين FAN_ONDIR و FAN_EVENT_ON_CHILD ليس لهما أي تأثير عند تقديمهما مع هذا العلم. إن تأثير ضبط العلمين FAN_ONDIR و FAN_EVENT_ON_CHILD في قناع العلامة على الأحداث المضبوطة في قناع التجاهل غير محدد ويعتمد على إصدار نواة لينكس.تحديداً، قبل لينكس 5.9، لم يكن ضبط قناع علامة على ملف وعلامة بقناع تجاهل على دليله الأب يؤدي إلى تجاهل الأحداث على الملف، بغض النظر عن علم FAN_EVENT_ON_CHILD في قناع علامة الدليل الأب. وعند تحديث قناع التجاهل بالعلم FAN_MARK_IGNORED_MASK على علامة حُدثت سابقاً بالعلم FAN_MARK_IGNORE، يفشل التحديث بالخطأ B.
- FAN_MARK_IGNORE (منذ لينكس 6.0، 5.15.154، و 5.10.220)
- لهذا العلم تأثير مشابه لضبط العلم FAN_MARK_IGNORED_MASK. ستُضاف الأحداث في I إلى قناع التجاهل أو تُزال منه. وعلى عكس العلم FAN_MARK_IGNORED_MASK، فإن هذا العلم يجعل العلمين FAN_ONDIR و FAN_EVENT_ON_CHILD يسريان على قناع التجاهل. تحديداً، ما لم يُضبط العلم FAN_ONDIR مع FAN_MARK_IGNORE، فلن تُتجاهل الأحداث على الأدلة. وإذا ضُبط العلم FAN_EVENT_ON_CHILD مع FAN_MARK_IGNORE، فستُتجاهل الأحداث على الأبناء. على سبيل المثال، علامة على دليل بمزيج من قناع به حدث FAN_CREATE وعلم FAN_ONDIR وقناع تجاهل به حدث FAN_CREATE وبدون علم FAN_ONDIR، ستؤدي إلى الحصول فقط على أحداث إنشاء الأدلة الفرعية. عند استخدام العلم FAN_MARK_IGNORE للإضافة إلى قناع تجاهل لوصل أو نظام ملفات أو علامة inode لدليل، يجب تحديد العلم FAN_MARK_IGNORED_SURV_MODIFY. سيؤدي الفشل في القيام بذلك إلى الخطأ EINVAL أو EISDIR.
- FAN_MARK_IGNORED_SURV_MODIFY
- يجب أن يبقى قناع التجاهل بعد أحداث التعديل. إذا لم يُضبط هذا العلم، سيُمسح قناع التجاهل عند وقوع حدث تعديل على الكائن الموشوم. يُستخدم حذف هذا العلم عادةً لكبح الأحداث (مثل FAN_OPEN) لملف معين حتى يُعدل محتوى ذلك الملف. من غير المفيد كبح الأحداث على نظام ملفات كامل أو وصل أو كافة الملفات داخل دليل حتى يُعدل محتوى ملف ما؛ ولهذا السبب، يتطلب العلم FAN_MARK_IGNORE وجود العلم FAN_MARK_IGNORED_SURV_MODIFY على علامات الوصل أو أنظمة الملفات أو علامات inode للأدلة. لا يمكن إزالة هذا العلم من العلامة بمجرد ضبطه. وعند تحديث قناع التجاهل بدون هذا العلم على علامة حُدثت سابقاً بالأعلام FAN_MARK_IGNORE و FAN_MARK_IGNORED_SURV_MODIFY، سيفشل التحديث بالخطأ EEXIST.
- FAN_MARK_IGNORE_SURV
- هذا مرادف لـ (FAN_MARK_IGNORE|FAN_MARK_IGNORED_SURV_MODIFY).
- FAN_MARK_EVICTABLE (منذ لينكس 5.19، 5.15.154، و 5.10.220)
- عند إنشاء علامة inode بهذا العلم، لن يُثبّت كائن inode في خبيئة الـ inode، مما يسمح بطرد كائن inode من الخبيئة عندما يكون ضغط الذاكرة على النظام مرتفعاً. يؤدي طرد كائن inode إلى فقدان العلامة القابلة للطرد أيضًا. وعند تحديث قناع علامة inode قابلة للطرد دون استخدام العلم FAN_MARK_EVICTABLE، يُثبّت الـ inode الموشوم في خبيئة الـ inode وتصبح العلامة غير قابلة للطرد. وعند تحديث قناع علامة inode غير قابلة للطرد بالعلم FAN_MARK_EVICTABLE، تظل العلامة غير قابلة للطرد ويفشل التحديث بالخطأ EEXIST. الوصلات وأنظمة الملفات ليست كائنات قابلة للطرد، لذا فإن محاولة إنشاء علامة وصل أو نظام ملفات بالعلم FAN_MARK_EVICTABLE ستؤدي إلى الخطأ EINVAL. على سبيل المثال، يمكن استخدام علامات inode بالاشتراك مع علامات الوصل لتقليل كمية الأحداث من المسارات غير المهمة؛ يقرأ مستمع الأحداث الحدث، ويتحقق مما إذا كان المسار المذكور فيه مهماً، وإذا لم يكن كذلك، يضع المستمع علامة بقناع تجاهل على الدليل. تسمح علامات inode القابلة للطرد باستخدام هذه الطريقة لعدد كبير من الأدلة دون القلق من تثبيت كافة الـ inodes واستنفاد ذاكرة النظام.
يحدد mask الأحداث التي يجب الاستماع إليها (أو التي يجب تجاهلها). وهو قناع بتات يتكون من القيم التالية:
- FAN_ACCESS
- إنشاء حدث عند الوصول إلى ملف أو دليل (قراءة) (لكن انظر BUGS).
- FAN_MODIFY
- إنشاء حدث عند تعديل ملف (كتابة).
- FAN_CLOSE_WRITE
- إنشاء حدث عند إغلاق ملف قابل للكتابة.
- FAN_CLOSE_NOWRITE
- إنشاء حدث عند إغلاق ملف أو دليل للقراءة فقط.
- FAN_OPEN
- إنشاء حدث عند فتح ملف أو دليل.
- FAN_OPEN_EXEC (منذ لينكس 5.0)
- إنشاء حدث عند فتح ملف بقصد تنفيذه. انظر NOTES لمزيد من التفاصيل.
- FAN_ATTRIB (منذ لينكس 5.1)
- إنشاء حدث عند تغير البيانات الوصفية لملف أو دليل. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات.
- FAN_CREATE (منذ لينكس 5.1)
- إنشاء حدث عند إنشاء ملف أو دليل في دليل أب موشوم. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات.
- FAN_DELETE (منذ لينكس 5.1)
- إنشاء حدث عند حذف ملف أو دليل في دليل أب موشوم. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات.
- FAN_DELETE_SELF (منذ لينكس 5.1)
- إنشاء حدث عند حذف ملف أو دليل موشوم نفسه. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات.
- FAN_MOVED_FROM (منذ لينكس 5.1)
- إنشاء حدث عند نقل ملف أو دليل من دليل أب موشوم. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات.
- FAN_MOVED_TO (منذ لينكس 5.1)
- إنشاء حدث عند نقل ملف أو دليل إلى دليل أب موشوم. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات.
- FAN_RENAME (منذ لينكس 5.17، 5.15.154، و 5.10.220)
- يحتوي هذا الحدث على نفس المعلومات التي يوفرها الحدثان FAN_MOVED_FROM و FAN_MOVED_TO، ومع ذلك فإنه يُمثَّل بحدث واحد يحتوي على سجلين من المعلومات كحد أقصى. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات. وإذا لم يكن كائن نظام الملفات المراد وسمه دليلاً، فسيُرفع الخطأ ENOTDIR.
- FAN_MOVE_SELF (منذ لينكس 5.1)
- إنشاء حدث عند نقل ملف أو دليل موشوم نفسه. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات.
- FAN_MNT_ATTACH
- FAN_MNT_DETACH (كلاهما منذ لينكس 6.14)
- إنشاء حدث عند وصل نقطة وصل أو فصلها من مساحة اسم وصل موشومة، على التوالي. ستؤدي محاولة ضبط هذا العلم على علامة inode أو وصل أو نظام ملفات إلى الخطأ EINVAL. يتطلب ذلك مجموعة fanotify هُيئت بالعلم FAN_REPORT_MNT وعلم العلامة FAN_MARK_MNTNS. يُعاد سجل معلومات إضافي من النوع FAN_EVENT_INFO_TYPE_MNT مع الحدث. انظر fanotify(7) لمزيد من التفاصيل.
- FAN_FS_ERROR (منذ لينكس 5.16، 5.15.154، و 5.10.220)
- إنشاء حدث عند اكتشاف خطأ في نظام الملفات يؤدي إلى عدم اتساق بياناته الوصفية. يُعاد سجل معلومات إضافي من النوع FAN_EVENT_INFO_TYPE_ERROR لكل حدث في دارئ القراءة. يتطلب ذلك مجموعة fanotify تميز كائنات نظام الملفات عبر مقابض الملفات. تعتمد الأحداث من هذا النوع على دعم نظام الملفات الأساسي. في وقت الكتابة، نظام الملفات ext4 هو الوحيد الذي يبلغ عن أحداث FAN_FS_ERROR. انظر fanotify(7) لمزيد من التفاصيل.
- FAN_OPEN_PERM
- إنشاء حدث عند طلب إذن لفتح ملف أو دليل. يتطلب ذلك واصف ملف fanotify أُنشئ باستخدام FAN_CLASS_PRE_CONTENT أو FAN_CLASS_CONTENT.
- FAN_OPEN_EXEC_PERM (منذ لينكس 5.0)
- إنشاء حدث عند طلب إذن لفتح ملف للتنفيذ. يتطلب ذلك واصف ملف fanotify أُنشئ باستخدام FAN_CLASS_PRE_CONTENT أو FAN_CLASS_CONTENT. انظر NOTES لمزيد من التفاصيل.
- FAN_ACCESS_PERM
- إنشاء حدث عند طلب إذن لقراءة ملف أو دليل. يتطلب ذلك واصف ملف fanotify أُنشئ باستخدام FAN_CLASS_PRE_CONTENT أو FAN_CLASS_CONTENT.
- FAN_PRE_ACCESS (منذ لينكس 6.14)
- إنشاء حدث قبل الوصول للقراءة أو الكتابة إلى نطاق من الملف، مما يتيح لمستمع الأحداث فرصة لتعديل محتوى الملف قبل الوصول إلى المحتوى في النطاق المحدد. يُعاد سجل معلومات إضافي من النوع FAN_EVENT_INFO_TYPE_RANGE لكل حدث في دارئ القراءة. يتطلب ذلك واصف ملف fanotify أُنشئ باستخدام FAN_CLASS_PRE_CONTENT.
- FAN_ONDIR
- إنشاء أحداث للأدلة—على سبيل المثال، عند استدعاء opendir(3) و readdir(3) (لكن انظر BUGS) و closedir(3). بدون هذا العلم، تُنشأ الأحداث للملفات فقط. في سياق أحداث إدخالات الأدلة، مثل FAN_CREATE و FAN_DELETE و FAN_MOVED_FROM و FAN_MOVED_TO، يُشترط تحديد العلم FAN_ONDIR لإنشاء أحداث عند تعديل إدخالات الأدلة الفرعية (أي mkdir(2) أو rmdir(2)).
- FAN_EVENT_ON_CHILD
- يجب إنشاء أحداث للأبناء المباشرين للأدلة الموشومة. ليس لهذا العلم تأثير عند وسم الوصلات وأنظمة الملفات. لاحظ أن الأحداث لا تُولّد لأبناء الأدلة الفرعية للأدلة الموشومة. وبشكل أكثر تحديداً، لا تُولّد أحداث تعديل إدخالات الأدلة FAN_CREATE و FAN_DELETE و FAN_MOVED_FROM و FAN_MOVED_TO لأي تعديلات تُجرى داخل الأدلة الفرعية للأدلة الموشومة. لاحظ أن الحدثين FAN_DELETE_SELF و FAN_MOVE_SELF لا يُولّدان لأبناء الأدلة الموشومة. ولمراقبة أشجار الأدلة الكاملة، من الضروري وسم الوصل أو نظام الملفات ذي الصلة.
تُعرَّف القيم المركبة التالية:
- FAN_CLOSE
- أُغلق ملف (FAN_CLOSE_WRITE|FAN_CLOSE_NOWRITE).
- FAN_MOVE
- نُقل ملف أو دليل (FAN_MOVED_FROM|FAN_MOVED_TO).
يُحدد كائن نظام الملفات المراد وسمه بواسطة واصف الملف dirfd واسم المسار المحدد في path:
- •
- إذا كان path هو NULL، فإن dirfd يحدد كائن نظام الملفات المراد وسمه.
- •
- إذا كان path هو NULL، واتخذ dirfd القيمة الخاصة AT_FDCWD، فسيُوسم دليل العمل الحالي.
- •
- إذا كان path مساراً مطلقاً، فإنه يحدد كائن نظام الملفات المراد وسمه، ويُتجاهل dirfd.
- •
- إذا كان المسار path نسبيًا، ولم تكن قيمة dirfd هي AT_FDCWD، فإن كائن نظام الملفات المراد وسمه يُحدد عبر تفسير path بالنسبة إلى الدليل الذي يشير إليه dirfd.
- •
- إذا كان المسار path نسبيًا، وكانت قيمة dirfd هي AT_FDCWD، فإن كائن نظام الملفات المراد وسمه يُحدد عبر تفسير path بالنسبة إلى دليل العمل الحالي. (انظر openat(2) لشرح حول سبب فائدة المعطى dirfd.)
قيمة الإرجاع¶
عند النجاح، تعيد fanotify_mark() القيمة 0. وعند حدوث خطأ، تُعاد -1، ويُضبط errno للإشارة إلى الخطأ.
الأخطاء¶
- EBADF
- مُرر واصف ملف غير صالح في fanotify_fd.
- EBADF
- المسار path نسبي ولكن dirfd ليس AT_FDCWD ولا واصف ملف صالح.
- EEXIST
- كائن نظام الملفات المشار إليه بواسطة dirfd و path لديه علامة حُدّثت بدون الراية FAN_MARK_EVICTABLE، وحاول المستخدم تحديث العلامة باستخدام الراية FAN_MARK_EVICTABLE.
- EEXIST
- كائن نظام الملفات المشار إليه بواسطة dirfd و path لديه علامة حُدّثت باستخدام الراية FAN_MARK_IGNORE، وحاول المستخدم تحديث العلامة باستخدام الراية FAN_MARK_IGNORED_MASK.
- EEXIST
- كائن نظام الملفات المشار إليه بواسطة dirfd و path لديه علامة حُدّثت باستخدام الرايتين FAN_MARK_IGNORE و FAN_MARK_IGNORED_SURV_MODIFY، وحاول المستخدم تحديث العلامة باستخدام الراية FAN_MARK_IGNORE فقط.
- EINVAL
- مُررت قيمة غير صالحة في flags أو mask، أو لم يكن fanotify_fd واصف ملف fanotify.
- EINVAL
- فُتح واصف ملف fanotify باستخدام FAN_CLASS_NOTIF أو أن مجموعة fanotify تُعرف كائنات نظام الملفات عبر مقابض الملفات والقناع يحتوي على راية لأحداث الأذونات (FAN_OPEN_PERM أو FAN_ACCESS_PERM).
- EINVAL
- هُيئت المجموعة بدون FAN_REPORT_FID ولكن نوع حدث واحد أو أكثر محدد في mask يتطلب ذلك.
- EINVAL
- تحتوي flags على FAN_MARK_IGNORE، وإما FAN_MARK_MOUNT أو FAN_MARK_FILESYSTEM، ولكنها لا تحتوي على FAN_MARK_IGNORED_SURV_MODIFY.
- EISDIR
- تحتوي flags على FAN_MARK_IGNORE، ولكنها لا تحتوي على FAN_MARK_IGNORED_SURV_MODIFY، ويحدد dirfd و path دليلاً.
- ENODEV
- كائن نظام الملفات المشار إليه بواسطة dirfd و path مرتبط بنظام ملفات يبلغ عن fsid صفري (مثلاً fuse(4)). يمكن إرجاع هذا الخطأ فقط مع مجموعة fanotify التي تُعرف كائنات نظام الملفات عبر مقابض الملفات. منذ لينكس 6.8، يمكن إرجاع هذا الخطأ عند محاولة إضافة علامة وصل أو نظام ملفات.
- ENOENT
- كائن نظام الملفات المشار إليه بواسطة dirfd و path غير موجود. يحدث هذا الخطأ أيضًا عند محاولة إزالة علامة من كائن غير موسوم.
- ENOMEM
- تعذر تخصيص الذاكرة اللازمة.
- ENOSPC
- تجاوز عدد العلامات لهذا المستخدم الحد المسموح به ولم تُحدد الراية FAN_UNLIMITED_MARKS عند إنشاء واصف ملف fanotify باستخدام fanotify_init(2). انظر fanotify(7) لتفاصيل حول هذا الحد.
- ENOSYS
- هذه النواة لا تُنفذ fanotify_mark(). واجهة fanotify البرمجية متاحة فقط إذا ضُبطت النواة باستخدام CONFIG_FANOTIFY.
- ENOTDIR
- تحتوي flags على FAN_MARK_ONLYDIR، ولا يحدد dirfd و path دليلاً.
- ENOTDIR
- تحتوي mask_ على FAN_RENAME، ولا يحدد dirfd و path دليلاً.
- ENOTDIR
- تحتوي flags على FAN_MARK_IGNORE، أو هُيئت مجموعة fanotify بالراية FAN_REPORT_TARGET_FID، وتحتوي mask_ على أحداث تعديل مدخلات الدليل (مثل FAN_CREATE، FAN_DELETE)، أو رايات أحداث الدليل (مثل FAN_ONDIR، FAN_EVENT_ON_CHILD)، ولا يحدد dirfd و path دليلاً.
- EOPNOTSUPP
- الكائن المشار إليه بواسطة path مرتبط بنظام ملفات لا يدعم ترميز مقابض الملفات. يمكن إرجاع هذا الخطأ فقط مع مجموعة fanotify التي تُعرف كائنات نظام الملفات عبر مقابض الملفات. يمكن استخدام استدعاء name_to_handle_at(2) مع الراية AT_HANDLE_FID (منذ لينكس 6.5) كاختبار للتحقق مما إذا كان نظام الملفات يدعم الإبلاغ عن الأحداث بمقابض الملفات.
- EPERM
- العملية غير مسموح بها لأن المستدعِي يفتقر إلى قدرة مطلوبة.
- EXDEV
- كائن نظام الملفات المشار إليه بواسطة path يقع ضمن وحدة فرعية لنظام ملفات (مثلاً btrfs(5)) تستخدم fsid مختلفًا عن كتلة السوبر الجذرية الخاصة بها. يمكن إرجاع هذا الخطأ فقط مع مجموعة fanotify التي تُعرف كائنات نظام الملفات عبر مقابض الملفات. منذ لينكس 6.8، سيُعاد هذا الخطأ عند محاولة إضافة علامة وصل أو نظام ملفات على وحدة فرعية، أو عند محاولة إضافة علامات inode في وحدات فرعية مختلفة، أو عند محاولة إضافة علامات inode في وحدة فرعية btrfs(5) وفي نظام ملفات آخر. منذ لينكس 6.8، سيُعاد هذا الخطأ أيضًا عند محاولة إضافة علامات في أنظمة ملفات مختلفة، حيث يبلغ أحد أنظمة الملفات عن fsid صفري (مثلاً fuse(4)).
المعايير¶
لينكس.
التاريخ¶
لينكس 2.6.37.
ملاحظات¶
FAN_OPEN_EXEC و FAN_OPEN_EXEC_PERM¶
عند استخدام إما FAN_OPEN_EXEC أو FAN_OPEN_EXEC_PERM ضمن mask_، ستُعاد أحداث من هذه الأنواع فقط عند حدوث تنفيذ مباشر لبرنامج. وبشكل أكثر تحديدًا، يعني هذا أن أحداثًا من هذه الأنواع ستُولد للملفات التي تُفتح باستخدام execve(2) أو execveat(2) أو uselib(2). لن تُرفع أحداث من هذه الأنواع في الحالة التي يُمرر فيها ملف إلى مفسر (أو يقرأه المفسر) للتفسير.
بالإضافة إلى ذلك، إذا وُضعت علامة أيضًا على الرابط الديناميكي للينكس، فيجب أن يتوقع المستخدم أيضًا تلقي حدث له عندما يُفتح كائن ELF بنجاح باستخدام execve(2) أو execveat(2).
على سبيل المثال، إذا استُدعي ملف ELF الثنائي التالي ووُضعت علامة FAN_OPEN_EXEC على /:
$ /bin/echo foo
سيتلقى التطبيق المستمع في هذه الحالة أحداث FAN_OPEN_EXEC لكل من ملف ELF الثنائي والمفسر، على التوالي:
/bin/echo /lib64/ld-linux-x86-64.so.2
العلل¶
كانت العلل التالية موجودة قبل لينكس 3.16:
- •
- إذا احتوت flags على FAN_MARK_FLUSH، فيجب أن يحدد dirfd و path كائن نظام ملفات صالحًا، على الرغم من أن هذا الكائن لا يُستخدم.
- •
- لا يولد readdir(2) حدث FAN_ACCESS.
- •
- إذا استُدعي fanotify_mark() باستخدام FAN_MARK_FLUSH، فلا يُتحقق من flags بحثًا عن قيم غير صالحة.
انظر أيضًا¶
ترجمة¶
تُرجمت هذه الصفحة من الدليل بواسطة زايد السعيدي <zayed.alsaidi@gmail.com>
هذه الترجمة هي وثيقة مجانية؛ راجع رخصة جنو العامة الإصدار 3 أو ما بعده للاطلاع على شروط حقوق النشر. لا توجد أي ضمانات.
إذا وجدت أي أخطاء في ترجمة صفحة الدليل هذه، يرجى إرسال بريد إلكتروني إلى قائمة بريد المترجمين: kde-l10n-ar@kde.org.
| 6 أكتوبر 2025 | صفحات دليل لينكس 6.18 |