लिनक्स सिस्टम कॉल क्या है?

What Is Linux System Call



इससे पहले कि हम लिनक्स सिस्टम कॉल की परिभाषा में तल्लीन हों और इसके निष्पादन के विवरण की जांच करें, एक विशिष्ट लिनक्स सिस्टम की विभिन्न सॉफ्टवेयर परतों को परिभाषित करने के साथ शुरू करना सबसे अच्छा है।

लिनक्स कर्नेल एक विशेष प्रोग्राम है जो आपके हार्डवेयर पर उपलब्ध न्यूनतम स्तर पर बूट और चलता है। इसमें कंप्यूटर पर चलने वाली हर चीज को व्यवस्थित करने का कार्य है, जिसमें कीबोर्ड, डिस्क और नेटवर्क ईवेंट को समानांतर में कई प्रोग्राम निष्पादित करने के लिए समय स्लाइस प्रदान करना शामिल है।







जब कर्नेल उपयोगकर्ता-स्तर के प्रोग्राम को निष्पादित करता है, तो यह मेमोरी स्पेस को वर्चुअलाइज करता है ताकि प्रोग्राम्स को विश्वास हो कि वे मेमोरी में चलने वाली एकमात्र प्रक्रिया हैं। हार्डवेयर और सॉफ्टवेयर अलगाव का यह सुरक्षात्मक बुलबुला सुरक्षा और विश्वसनीयता बढ़ाता है। एक गैर-विशेषाधिकार प्राप्त एप्लिकेशन अन्य कार्यक्रमों से संबंधित मेमोरी तक नहीं पहुंच सकता है, और यदि वह प्रोग्राम क्रैश हो जाता है, तो कर्नेल समाप्त हो जाता है ताकि वह बाकी सिस्टम को नुकसान न पहुंचा सके।



Linux सिस्टम कॉल के साथ बाधा को दूर करना

गैर-विशेषाधिकार प्राप्त अनुप्रयोगों के बीच अलगाव की यह परत सिस्टम पर अन्य अनुप्रयोगों और उपयोगकर्ताओं की सुरक्षा के लिए एक उत्कृष्ट सीमा प्रदान करती है। हालांकि, कंप्यूटर और बाहरी दुनिया में अन्य तत्वों के साथ इंटरफेस करने के किसी भी तरीके के बिना, प्रोग्राम कुछ भी हासिल करने में सक्षम नहीं होंगे।



अंतःक्रिया की सुविधा के लिए, कर्नेल एक सॉफ्टवेयर गेट निर्दिष्ट करता है जो चल रहे प्रोग्राम को यह अनुरोध करने की अनुमति देता है कि कर्नेल उसकी ओर से कार्य करे। इस इंटरफ़ेस को सिस्टम कॉल के रूप में जाना जाता है।





चूंकि लिनक्स यूनिक्स के दर्शन का पालन करता है, सब कुछ एक फाइल है, एक फाइल को खोलकर और पढ़कर या लिखकर कई कार्य किए जा सकते हैं, जो एक उपकरण हो सकता है। विंडोज़ पर, उदाहरण के लिए, आप यादृच्छिक बाइट्स तक पहुंचने के लिए CryptGenRandom नामक फ़ंक्शन का उपयोग कर सकते हैं। लेकिन लिनक्स पर, यह केवल फ़ाइल /dev/urandom को खोलकर और मानक फ़ाइल इनपुट/आउटपुट सिस्टम कॉल का उपयोग करके उसमें से बाइट्स पढ़कर किया जा सकता है। यह महत्वपूर्ण अंतर एक सरल सिस्टम कॉल इंटरफ़ेस की अनुमति देता है।

वेफर-पतला आवरण

अधिकांश अनुप्रयोगों में, सिस्टम कॉल सीधे कर्नेल में नहीं की जाती हैं। लगभग सभी प्रोग्राम मानक सी लाइब्रेरी में लिंक होते हैं, जो लिनक्स सिस्टम कॉल के आसपास एक पतला लेकिन महत्वपूर्ण आवरण प्रदान करता है। पुस्तकालय सुनिश्चित करता है कि फ़ंक्शन तर्कों को सही प्रोसेसर रजिस्टर में कॉपी किया गया है और फिर संबंधित लिनक्स सिस्टम कॉल जारी करता है। जब कॉल से डेटा प्राप्त होता है, तो रैपर परिणामों की व्याख्या करता है और इसे लगातार प्रोग्राम में वापस लौटाता है।



परदे के पीछे

प्रोग्राम में प्रत्येक फ़ंक्शन जो सिस्टम के साथ इंटरैक्ट करता है, अंततः सिस्टम कॉल में अनुवादित किया जाता है। इसे क्रिया में देखने के लिए, आइए एक बुनियादी उदाहरण से शुरू करें।

शून्यमुख्य() {
}

यह शायद अब तक का सबसे तुच्छ सी प्रोग्राम है। यह मुख्य प्रवेश बिंदु के माध्यम से नियंत्रण प्राप्त करता है और फिर बाहर निकलता है। यह एक मान भी नहीं लौटाता है क्योंकि मुख्य को शून्य के रूप में परिभाषित किया गया है। फ़ाइल को ctest.c के रूप में सहेजें और इसे संकलित करें:

जीसीसी सीटेस्ट।सी -सीटेस्ट

एक बार संकलित हो जाने के बाद, हम फ़ाइल का आकार 8664 बाइट्स के रूप में देख सकते हैं। यह आपके सिस्टम पर थोड़ा भिन्न हो सकता है, लेकिन यह लगभग 8k होना चाहिए। बस दर्ज करने और बाहर निकलने के लिए यह बहुत सारा कोड है! 8k का कारण यह है कि libc रनटाइम शामिल किया जा रहा है। भले ही हम प्रतीकों को हटा दें, फिर भी यह 6k से अधिक का है।

एक और भी सरल उदाहरण में, हम अपने लिए ऐसा करने के लिए सी रनटाइम के आधार पर लिनक्स सिस्टम को बाहर निकलने के लिए कॉल कर सकते हैं।

शून्य_प्रारंभ() {
एएसएम('movl $1,%eax;'
'xorl %ebx,%ebx;'
'इंट $0x80');
}

यहां हम 1 को EAX रजिस्टर में ले जाते हैं, EBX रजिस्टर को हटा देते हैं (जिसमें अन्यथा रिटर्न वैल्यू होता है) फिर Linux सिस्टम कॉल इंटरप्ट 0x80 (या दशमलव में 128) को कॉल करें। यह रुकावट हमारे कॉल को संसाधित करने के लिए कर्नेल को ट्रिगर करती है।

यदि हम अपना नया उदाहरण संकलित करते हैं, जिसे asmtest.c कहा जाता है, और प्रतीकों को हटा दें और मानक पुस्तकालय को बाहर कर दें:

जीसीसी-एस-nostdlib asmtest.सी -हे asmtest

हम 1k से कम बाइनरी उत्पन्न करेंगे (मेरे सिस्टम पर, यह 984 बाइट्स देता है)। इस कोड में से अधिकांश निष्पादन योग्य शीर्षलेख हैं। अब हम डायरेक्ट लिनक्स सिस्टम कॉल को कॉल कर रहे हैं।

सभी व्यावहारिक उद्देश्यों के लिए

लगभग सभी मामलों में, आपको कभी भी अपने सी प्रोग्राम में सीधे सिस्टम कॉल करने की आवश्यकता नहीं होगी। हालाँकि, यदि आप असेम्बली भाषा का प्रयोग करते हैं, तो इसकी आवश्यकता उत्पन्न हो सकती है। हालांकि, अनुकूलन में, सी पुस्तकालय कार्यों को सिस्टम कॉल करने देना सबसे अच्छा होगा और असेंबली निर्देशों में केवल आपका प्रदर्शन-महत्वपूर्ण कोड एम्बेडेड होगा।

सिस्टम कॉल ट्यूटोरियल कैसे प्रोग्राम करें

सभी सिस्टम कॉल की सूची

यदि आप Linux के लिए सभी उपलब्ध सिस्टम कॉल की सूची देखना चाहते हैं तो आप इन संदर्भ पृष्ठों को देख सकते हैं: LinuxHint.com पर सिस्टम कॉल की पूरी सूची, filippo.io/linux-syscall-table/ और या syscalls.kernelgrok.com