मॉड्यूल चिह्नित (एफ) में / खरीद / मॉड्यूल


9

मेरे 3.10 सिस्टम पर / proc / मॉड्यूल में सूचीबद्ध कुछ मॉड्यूल चिह्नित किए गए हैं (F)। मैं इसका (एफ) कारण ढूंढना चाहता हूं। मुझे यकीन है कि मॉड्यूल जबरदस्ती लोड नहीं किए गए थे और कर्नेल के साथ बनाए गए थे। क्या आप यह बता सकते हैं कि कर्नेल कोड क्या / proc / मॉड्यूल बनाता है?

usb_storage 56610 0 - Live 0xffffffffa005d000 (F)

यदि मैं अनलोड करता हूं और इस मॉड्यूल को वापस लोड करता हूं (F) चला जाता है।


कोड के अलावा (अभी भी उस बिट की तलाश में) मुझे अब तक मिले सबसे अच्छे संसाधनों में ये 2 हैं: unixhelp.ed.ac.uk/CGI/man-cgi?proc+5 & tldp.org/HOWTO/html_single/ मॉड्यूल- HOWTO । यह भी कुछ हद तक उपयोगी है: centos.org/docs/5/html/Deployment_Guide-en-US/...
SLM

धन्यवाद slm। आपका तीसरा पॉइंटर, / proc / मॉड्यूल का उल्लेख करने वाले अनुभाग में छठे कॉलम को बताता है जो मेमोरी ऑफसेट है। यह कहता है कि यह जानकारी प्रोफाइलर्स द्वारा उपयोग की जाती है - यह मेरी समस्या है। प्रोफाइलर मॉड्यूल (एफ) के चिह्नित होने पर चुपचाप काम करने से इनकार कर देता है।
Stephan T.

जवाबों:


11

आउटपुट में कॉलम /proc/modulesनिम्नानुसार हैं।

usb_storage 56610 0    -   Live 0xffffffffa005d000 (F)
  (1)        (2) (3)  (4)  (5)         (6)         (7)

नोट: मुझे इस बात का कोई उल्लेख नहीं मिला कि 7 वें कॉलम में क्या दिखाई देता है, लेकिन मैं इसे लेबल कर रहा हूं जैसे कि 6 वें कॉलम के लिए विवरण (नीचे देखें) वहां प्रदर्शित होने वाली जानकारी को कवर नहीं करता है।

उद्धरण - http://www.centos.org/docs/5/html/Deployment_Guide-en-US/s1-proc-topfiles.html

  • पहले कॉलम में मॉड्यूल का नाम शामिल है।
  • दूसरा कॉलम बाइट्स में मॉड्यूल के मेमोरी साइज को संदर्भित करता है।
  • तीसरा कॉलम बताता है कि वर्तमान में मॉड्यूल के कितने उदाहरण लोड किए गए हैं। शून्य का मान एक अनलोड किए गए मॉड्यूल का प्रतिनिधित्व करता है।
  • चौथा स्तंभ बताता है कि यदि मॉड्यूल कार्य करने के लिए किसी अन्य मॉड्यूल पर निर्भर करता है, और उन अन्य मॉड्यूल को सूचीबद्ध करता है।
  • पांचवां कॉलम सूचीबद्ध करता है कि मॉड्यूल किस लोड स्थिति में है: लाइव, लोड हो रहा है, या लोड करना केवल संभव मान हैं।
  • छठा कॉलम लोड किए गए मॉड्यूल के लिए वर्तमान कर्नेल मेमोरी ऑफसेट को सूचीबद्ध करता है। यह जानकारी डीबगिंग उद्देश्यों के लिए, या अफीम जैसे प्रोफाइलिंग टूल के लिए उपयोगी हो सकती है।

मेरा मानना ​​है कि इस (F)(यानी 7 वें कॉलम) के साथ जो कॉलम चिह्नित किया गया है वह इस फाइल में यहाँ से आता है - panic.c

/**
 *  print_tainted - return a string to represent the kernel taint state.
 *
 *  'P' - Proprietary module has been loaded.
 *  'F' - Module has been forcibly loaded.
 *  'S' - SMP with CPUs not designed for SMP.
 *  'R' - User forced a module unload.
 *  'M' - System experienced a machine check exception.
 *  'B' - System has hit bad_page.
 *  'U' - Userspace-defined naughtiness.
 *  'D' - Kernel has oopsed before
 *  'A' - ACPI table overridden.
 *  'W' - Taint on warning.
 *  'C' - modules from drivers/staging are loaded.
 *  'I' - Working around severe firmware bug.
 *  'O' - Out-of-tree module has been loaded.
 *  'E' - Unsigned module has been loaded.
 *
 *  The string is overwritten by the next call to print_tainted().
 */

ये कोड उन बिटमैप के लिए एक प्रतिनिधित्व हैं जो kernel.txtसंदर्भ प्रलेखन में भी मौजूद हैं।

tainted:

 Non-zero if the kernel has been tainted.  Numeric values, which
 can be ORed together:

    1 - A module with a non-GPL license has been loaded, this
        includes modules with no license.
        Set by modutils >= 2.4.9 and module-init-tools.
    2 - A module was force loaded by insmod -f.
        Set by modutils >= 2.4.9 and module-init-tools.
    4 - Unsafe SMP processors: SMP with CPUs not designed for SMP.
    8 - A module was forcibly unloaded from the system by rmmod -f.
   16 - A hardware machine check error occurred on the system.
   32 - A bad page was discovered on the system.
   64 - The user has asked that the system be marked "tainted".  This
        could be because they are running software that directly modifies
        the hardware, or for other reasons.
  128 - The system has died.
  256 - The ACPI DSDT has been overridden with one supplied by the user
         instead of using the one provided by the hardware.
  512 - A kernel warning has occurred.
 1024 - A module from drivers/staging was loaded.
 2048 - The system is working around a severe firmware bug.
 4096 - An out-of-tree module has been loaded.
 8192 - An unsigned module has been loaded in a kernel supporting module
        signature.

संदर्भ

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.