What is the takeaway from lab 4.1
I am new to C and fairly new to linux. What is the takeaway from the lab 4.1?
Comments
-
It shows you how many times you can handle particular signals and what order they are handled in.
0 -
so is it queuing up signals 1-64 and then emitting them FIFO?
0 -
the signals are sent out in order. How they handled and in what order is controlled by a bunch of factors, such as whether they are "real time" signals (> 32) or not (real time signals can queue up, ordinary signals do not) for example. The exact order they run is a kernel question which has varied with time. The answer is not really completely controlled by any standard.
1 -
Hi @bfmcneill ,
I used this small piece of code to make a test on a web session:
#include <stdio.h> #include <unistd.h> #include <signal.h> /* This is a test that shows that a signal 2 (SIGINT can be handled. So, first CTRL+C it gives a message, then second time it receives it, the program is terminated. */ void my_signal_interrupt(int sig) { printf("I got signal %d\n", sig); (void) signal(SIGINT, SIG_DFL); } int main() { (void) signal(SIGINT,my_signal_interrupt); while(1) { printf("Waiting for interruption...\n"); sleep(1); } }So you can put that into a file, let's say signal_int.c and them compile it: gcc signal_int.c -o signal_int . Then run it: ./signal_int . Once it's running, on the same terminal hit CTRL+C once, and then a second time; on the second time the program will be terminated. It's a very simple test, of course.
Regards,
Luis.1 -
Hi @luisviveropena and @coop ,
I'm looking for some help to understand this better as well.If more than one of a given signal is raised while the process has blocked it, does the process receive it multiple times?
What is the 'process' in this context? Is it the
signalscript? And how to observe if it's blocked? Is there a way to observe the queue in real time?Thanks for posting that script @luisviveropena I'd like to dig a bit deeper into signals to improve my understanding, is the office hours video where this was discussed still available anywhere? Do you have a recommendation for extra resources?
Thank you
0 -
The process is whichever program to which the signal is being sent, which may or not be the process sending the signal (yes, a process can kill itself which is what you do whenever you hit Ctl-C for example)
There is only one way to see what signals may be pending or blocked that i know of. Looc at /proc/[pid]/status and look at the bit mask of fields such as SigPnd and SigBlk etc, where for pid you put in some pid (you can also look at /proc/self/status where self is the current process. It's a little too much work to deciper the bit mask in this course, but have fun figuring out. This pseudofile has other information for the curious.
0 -
Hi @GRO 108 ,
The Office Hours recording are kept for one day only, so that one is gone.
I think it could be useful to search for other "C" codes that does similar things. There are also some code in Python that works with signals as well, that could be easier to read and modify.
Many regards,
Luis.0 -
Hi Luis and Coop.
Good morning to you both and thank you for your explanation. However, I am still a bit confuse as to how to compile it and run the signal. c programme on my virtual machine.
0 -
HI Luis,
I have compiled the signal.c program and ran it. See below stdout.

Please let me know if am doing something wrong.
Kind regards,
Andre0 -
you need to run "signal" not "signal.c" which is the source. Just do ./signal. Although I am mystified why you get the result you do
1 -
Hi Coop,
Thank you for your swift response.
I am equally surprised about my own result lol. I will try it again and let you know the outcome.
Best regards,
Andre1
Categories
- All Categories
- 175 LFX Mentorship
- 175 LFX Mentorship: Linux Kernel
- 745 Linux Foundation IT Professional Programs
- 372 Cloud Engineer IT Professional Program
- 168 Advanced Cloud Engineer IT Professional Program
- 73 DevOps IT Professional Program - Discontinued
- 3 DevOps & GitOps IT Professional Program
- 98 Cloud Native Developer IT Professional Program
- 7.6K Training Courses & Learning Paths
- AI & ML Training
- Blockchain & Decentralized Identity Training
- Cloud & Containers Training
- Cybersecurity Training
- DevOps & Site-Reliability Training
- Linux Kernel Development Training
- Networking Training
- Open Source Best Practice Training
- System Administration Training
- System Engineering Training
- Web & Application Development Training
- 2 LFD103-JP クラス フォーラム
- 4 LFD210-CN Class Forum
- 764 LFD259 Class Forum
- 681 LFS101 Class Forum
- 2 LFS158-JP クラス フォーラム
- 162 LFS207 Class Forum
- 3 LFS207-DE-Klassenforum
- 4 LFS207-JP クラス フォーラム
- 61 LFS241 Class Forum
- 52 LFS242 Class Forum
- 42 LFS243 Class Forum
- 19 LFS244 Class Forum
- 4 LFS250-JP クラス フォーラム
- 166 LFS253 Class Forum
- 19 LFS256 Class Forum
- 1.4K LFS258 Class Forum
- 165 LFS261 Class Forum
- 26 LFS267 Class Forum
- 792 Hardware
- 202 Drivers
- 68 I/O Devices
- 37 Monitors
- 95 Multimedia
- 173 Networking
- 91 Printers & Scanners
- 87 Storage
- 768 Linux Distributions
- 81 Debian
- 67 Fedora
- 22 Linux Mint
- 13 Mageia
- 24 openSUSE
- 150 Red Hat Enterprise
- 31 Slackware
- 13 SUSE Enterprise
- 356 Ubuntu
- 465 Linux System Administration
- 31 Cloud Computing
- 73 Command Line/Scripting
- Github systems admin projects
- 98 Linux Security
- 78 Network Management
- 101 System Management
- 46 Web Management
- 106 Mobile Computing
- 18 Android
- 73 Development
- 1.2K New to Linux
- 1K Getting Started with Linux
- 392 Off Topic
- 121 Introductions
- 181 Small Talk
- 29 Study Material
- 944 Programming and Development
- 310 Kernel Development
- 616 Software Development
- 977 Software
- 369 Applications
- 182 Command Line
- 5 Compiling/Installing
- 68 Games
- 317 Installation
- Archived
- 2 LFD140 Class Forum
Upcoming Training
-
August 20, 2018
Kubernetes Administration (LFS458)
-
August 20, 2018
Linux System Administration (LFS301)
-
August 27, 2018
Open Source Virtualization (LFS462)
-
August 27, 2018
Linux Kernel Debugging and Security (LFD440)

