लिनक्स कर्नेल कोड में __init का क्या अर्थ है?


91

लिनक्स कर्नेल स्रोत कोड में मुझे यह फ़ंक्शन मिला:

static int __init clk_disable_unused(void) 
{
   // some code
}

यहां मैं समझ नहीं पा रहा हूं कि __initइसका क्या मतलब है।

जवाबों:


76

include/linux/init.h

/* These macros are used to mark some functions or 
 * initialized data (doesn't apply to uninitialized data)
 * as `initialization' functions. The kernel can take this
 * as hint that the function is used only during the initialization
 * phase and free up used memory resources after
 *
 * Usage:
 * For functions:
 * 
 * You should add __init immediately before the function name, like:
 *
 * static void __init initme(int x, int y)
 * {
 *    extern int z; z = x * y;
 * }
 *
 * If the function has a prototype somewhere, you can also add
 * __init between closing brace of the prototype and semicolon:
 *
 * extern int initialize_foobar_device(int, int, int) __init;
 *
 * For initialized data:
 * You should insert __initdata between the variable name and equal
 * sign followed by value, e.g.:
 *
 * static int init_variable __initdata = 0;
 * static const char linux_logo[] __initconst = { 0x32, 0x36, ... };
 *
 * Don't forget to initialize data not at file scope, i.e. within a function,
 * as gcc otherwise puts the data into the bss section and not into the init
 * section.
 * 
 * Also note, that this data cannot be "const".
 */

/* These are for everybody (although not all archs will actually
   discard it in modules) */
#define __init      __section(.init.text) __cold notrace
#define __initdata  __section(.init.data)
#define __initconst __section(.init.rodata)
#define __exitdata  __section(.exit.data)
#define __exit_call __used __section(.exitcall.exit)

55

ये अंतिम निष्पादन बाइनरी में विशेष क्षेत्रों में लिनक्स कोड के कुछ हिस्सों का पता लगाने के लिए केवल मैक्रोज़ हैं। __init, उदाहरण के लिए (या बेहतर __attribute__ ((__section__ (".init.text")))यह मैक्रो का विस्तार) कंपाइलर को इस फ़ंक्शन को एक विशेष तरीके से चिह्नित करने का निर्देश देता है। अंत में लिंकर बाइनरी फ़ाइल के अंत (या शुरुआत) में इस चिह्न के साथ सभी फ़ंक्शन एकत्र करता है।

जब कर्नेल शुरू होता है, तो यह कोड केवल एक बार (प्रारंभ) चलता है। इसके चलने के बाद, कर्नेल इस मेमोरी को पुन: उपयोग करने के लिए मुक्त कर सकता है और आपको कर्नेल संदेश दिखाई देगा:

मुक्त अप्रयुक्त कर्नेल मेमोरी: 108k मुक्त

इस सुविधा का उपयोग करने के लिए, आपको एक विशेष लिंकर स्क्रिप्ट फ़ाइल की आवश्यकता है, जो लिंकर को बताए कि सभी चिह्नित कार्यों का पता लगाने के लिए कहां है।


11
चालाक! तो यह है कि "मुक्त अप्रयुक्त कर्नेल मेमोरी: 108k मुक्त" का मतलब था। :-) मुझे इन वर्षों में आश्चर्य हुआ है। मैंने मान लिया कि यह किसी तरह का बफ़र या कुछ था, कोड नहीं।
प्रो। फल्केन

6

यह कर्नेल 2.2 और बाद की विशेषता प्रदर्शित करता है। initऔर cleanupकार्यों की परिभाषा में परिवर्तन पर ध्यान दें । __initमैक्रो का कारण बनता है initसमारोह खारिज किया जा करने के लिए और उसके स्मृति एक बार मुक्त कर दिया initनिर्मित ड्राइवरों, लेकिन नहीं लोड करने योग्य मॉड्यूल के लिए समारोह खत्म। यदि आप सोचते हैं कि initफ़ंक्शन कब लागू किया गया है, तो यह सही समझ में आता है।

स्रोत


5

__init में परिभाषित एक मैक्रो है ।/include/linux/init.h जो फैलता है __attribute__ ((__section__(".init.text")))

यह संकलक को इस फ़ंक्शन को एक विशेष तरीके से चिह्नित करने का निर्देश देता है। अंत में लिंकर बाइनरी फ़ाइल के अंत में (या शुरू) इस निशान के साथ सभी फ़ंक्शन एकत्र करता है। जब कर्नेल शुरू होता है, तो यह कोड केवल एक बार (प्रारंभ) चलता है। इसके चलने के बाद, कर्नेल इस मेमोरी को पुन: उपयोग करने के लिए मुक्त कर सकता है और आप कर्नेल देखेंगे


3

Linux / init.h में टिप्पणी (और उसी समय डॉक्स) पढ़ें

आपको यह भी पता होना चाहिए कि gcc के पास लिनक्स कर्नेल कोड के लिए विशेष रूप से बनाए गए कुछ एक्सटेंशन हैं और ऐसा लगता है कि यह मैक्रो उनमें से किसी एक का उपयोग करता है।


1

जब आप एक लिनक्स कर्नेल मॉड्यूल को कर्नेल में संकलित करते हैं और सम्मिलित करते हैं, तो निष्पादित होने वाला पहला फ़ंक्शन __init होता है। यह फ़ंक्शन मूल रूप से प्रारंभ करने के लिए उपयोग किया जाता है इससे पहले कि आप डिवाइस ड्राइवर आदि को पंजीकृत करने जैसे मुख्य संचालन करते हैं, इसके विपरीत प्रभाव के साथ एक और फ़ंक्शन है। __exit जिसे तब कहा जाता है जब आप कर्नेल मॉड्यूल को हटाते हैं जो फिर से कुछ पंजीकृत डिवाइस या इस तरह के किसी भी फ़ंक्शन को निकालने के लिए उपयोग किया जाता है

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