Skip to content

Latest commit

 

History

History
77 lines (46 loc) · 4.48 KB

README.md

File metadata and controls

77 lines (46 loc) · 4.48 KB

NetlinkGreetingExchange

A hands-on project showcasing bidirectional greeting message exchanges between Linux kernel and user space via Netlink sockets. Dive into kernel-user communication! 🚀🐧

Welcome to the repository dedicated to understanding and implementing communication between Linux kernel and user space using Netlink sockets.

This repo provides a step-by-step guide to the intricacies involved in establishing, sending, and receiving data via Netlink sockets. It's complemented by a series of markdown files which detail each phase of the implementation.


📁 Repository Structure:

  • 📄 1_NetlinkGreetExample.md: An introduction and basic greeting example using Netlink sockets.

  • 📄 2_NetlinkProtocolNumber.md: Dive into the Netlink protocol numbers, their significance, and how to use them.

  • 📄 3_NetlinkGreetCodWalk1.md: A code walk-through for the initial greeting implementation using Netlink.

  • 📄 4_KernelSocketbuffers.md: Detailed exploration of Kernel Socket Buffers, their role, and how they function.

  • 📄 5_NetlinkGreetCodeWalkReceivingUserSpaceMsg.md: Code walk-through detailing how to receive messages in user space using Netlink.

  • 📄 6_NetlinkGreetCodWal3SendingReplyUserspace.md: Code walk-through illustrating how to send replies from Kernel to user space.

  • 📄 7_UserspaceProgramThreadModel.md: Introduction to the userspace program thread model.

  • 📄 8_APISendmsgtoKernel.md: Detailed look into the API send message to Kernel.

  • 📄 9_CodeWalksend_netlink_msg_to_kernel().md: A code walk-through for the send_netlink_msg_to_kernel() function.

  • 📄 10_Userspace.c flowchart.md: A flowchart explaining the userspace.c file.

  • 📄 11_Userspace.cSendCodeImplementation.md: Dive into the implementation of the sending code for userspace.c.

  • 📄 12_Userspace.cRecvCodeImplementation.md: Understand the implementation of the receiving code for userspace.c.

  • 📂 pkg: Contains the source code for this project. Dive in to see the real implementation and get your hands dirty with some coding!

    • Inside the pkg directory, there's also a dedicated README.md which provides instructions on how to run the project.

🚀 Getting Started:

  1. If you're new to Netlink sockets, begin with 1_NetlinkGreetExample.md for a basic understanding and introduction.
  2. For those interested in the source code, head to the pkg directory. Make sure to check the README.md inside pkg for setup and running instructions.
  3. Navigate through the markdown files in sequence for a comprehensive understanding of Netlink sockets communication.

📚 Resources & References:


Feel free to explore these resources to deepen your understanding of Netlink sockets and their application in Linux Kernel-User communication.


🤝 Contribution:

Feel free to raise issues, send pull requests, or provide feedback to enhance the repository. All contributions are welcome!


License:

This project is licensed under the MIT License. See the LICENSE file for more details.


🙏 Acknowledgements:

A big shoutout to the Linux community and everyone who made the resources available to make this repo a reality.


Happy coding and learning! 💻🚀