printk is used in kernel programming to print messages into the kernel logs.
The syntax of printk is
The log levels decide the importance of the message being printed, kernel defines 8 log levels in the file printk.h
We can see each log level corresponds to a number and the lower the number higher the importance of the message.
The levels are useful in deciding what should be displayed to the user on the console and what should not be.
Every console has log level called as the the console log level and any message with a log level number lesser than the console log level gets displayed on the console, and other messages which have a log level number higher or equal to the console log level are logged in the kernel log which can be looked into using the command "dmesg".
The console loglevel can be found by looking into the file /proc/sys/kernel/printk
The first number in the output is the console log level, the second is the default log level, third is the minimum log level and fourth is the maximum log level.
Log level 4 corresponds to KERN_WARNING. Thus all the messages with log levels 3,2,1 and 0 will get displayed on the screen as well as logged and the messages with log level 4,5,6,7 only get logged and can be viewed using "dmesg".
The console log level can be changed by writing into the proc entry
Now the console log level is set to 6, which is KERN_INFO.
We can test logging by using the following module
hello.c:
The printk called in the init function uses KERN_WARNING which is log level and lesser than 6 which is the console log level and hence should be seen on the screen.
The printk used in the exit function is KERN_INFO which is log level 6,same as the console log level, and hence should not be visible on the screen.
Note: We can test the operation of the code only by logging into a text mode as none of the messages are displayed on a terminal of GUI.
Makefile:
Compile and insert
We can see the hello world being printed on the screen.
The good bye world message gets logged but is not printed on the screen but can be see in the logs.
Thus using printk and the console log levels we can control the kernel messages visible to the user.
The syntax of printk is
The log levels decide the importance of the message being printed, kernel defines 8 log levels in the file printk.h
We can see each log level corresponds to a number and the lower the number higher the importance of the message.
The levels are useful in deciding what should be displayed to the user on the console and what should not be.
Every console has log level called as the the console log level and any message with a log level number lesser than the console log level gets displayed on the console, and other messages which have a log level number higher or equal to the console log level are logged in the kernel log which can be looked into using the command "dmesg".
The console loglevel can be found by looking into the file /proc/sys/kernel/printk
The first number in the output is the console log level, the second is the default log level, third is the minimum log level and fourth is the maximum log level.
Log level 4 corresponds to KERN_WARNING. Thus all the messages with log levels 3,2,1 and 0 will get displayed on the screen as well as logged and the messages with log level 4,5,6,7 only get logged and can be viewed using "dmesg".
The console log level can be changed by writing into the proc entry
Now the console log level is set to 6, which is KERN_INFO.
We can test logging by using the following module
hello.c:
The printk called in the init function uses KERN_WARNING which is log level and lesser than 6 which is the console log level and hence should be seen on the screen.
The printk used in the exit function is KERN_INFO which is log level 6,same as the console log level, and hence should not be visible on the screen.
Note: We can test the operation of the code only by logging into a text mode as none of the messages are displayed on a terminal of GUI.
Makefile:
Compile and insert
We can see the hello world being printed on the screen.
The good bye world message gets logged but is not printed on the screen but can be see in the logs.
Thus using printk and the console log levels we can control the kernel messages visible to the user.
Most valuable article. Really I got more knowledge from this article. Thanks.
ReplyDeletePlacement Training in Chennai
placement classes
Placement Training institutes
Placement Training in Adyar
soft skills training in chennai
soft skill training courses in chennai
clinical sas training in chennai
SAS Training in Chennai
Good Post and its informative one. Thank you for sharing this good article, it was so good to read and very useful to update my skill as updated one.
ReplyDeleteLinux Training in Electronic City
I have seen your blog and really amazing information put in this. If anyone needs Website Designing and Digital Marketing Services in India, visit Ogen Infosystem in Delhi to get a creative and responsive website.
ReplyDeleteBest Website Designing Company in India
Thanks for posting. Linux Tutorial
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by the author.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis comment has been removed by a blog administrator.
ReplyDeleteThis is a really informative blog for students. For those seeking essay help, the insights provided are particularly valuable. Special needs tutor Wellesley, keep up the good work!
ReplyDeleteprintk is a crucial tool in kernel programming for outputting messages to the kernel logs, aiding in debugging and system monitoring. For transforming your space with precision and style, explore the top fit out companies in Dubai.
ReplyDelete"Log levels help prioritize messages effectively based on their importance. For top-notch interior transformations, check out the fit out company Abu Dhabi!"
ReplyDelete