Welcome to the Linux Foundation Forum!
Signal handling for 3 serial interrupt.
sbm143
Posts: 9
Hi all,
I have 3 different devices Dev1, Dev2 & Dev3 connected to UART 1, UART 2 & UART 3 respectively. I am using these 3 devices alternatively.
I want to write signal handler for these 3 devices interrupts. I am able to handle one signal handler at a time.
But problem is that when I have tried to write signal handler for other (means two signal handler at a time for SIGIO signal), my programs does not work.
Can anybody tell me how to solve this problem?
Please help me.
Thanks
0
Comments
-
You can only have one handler for each signal at any particular time. You could use sigqueue() and pass some information in the sigval structure that indicates which port generated the interrupt. Then, your handler can determine what to do with the port in question.0
-
Thanks for your suggestion.
I have also one more problem in signal handling. I have connected a GPRS modem to UART1 (serial port).
In the code i am just sending "AT" command continuously and trying to check its reply. But problem is that sometimes I get reply "OK" and sometimes not.
Also after some time my code is does not get interrupted even though there is reply from modem.. I have checked this using Hyper Terminal.
Please help me out what is the prolem?0 -
Without seeing your code, I can't say what is your problem, and then I might not be able to determine what's going on. Please explain exactly what you are trying to do. There may be some conflict with system software that is detecting the GPRS modem and trying to connect with it, resulting in some sort of race condition.0
-
Hi.
In the source code I am just sending "AT" command and trying to check its "OK" response.
My code is....#include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <termios.h> #include <stdio.h> #include<sys/signal.h> #include<sys/ioctl.h> #define BAUDRATE B9600 #define Modem "/dev/ttyAM1" #define _POSIX_SOURCE 1 /* POSIX compliant source */ #define FALSE 0 #define TRUE 1 /******************************************** Functions Prototype *****************************************************/ void Modem_Interface(void); void sig_handler(int status); void serial_cnfg(void); void modemdelay(void); void modemdelay1(void); /*************************************************************************************************************************/ /************************************************* Structures **********************************************************/ struct termios oldtio,newtio; struct termios oldtio1,newtio1; /*************************************************************************************************************************/ /********************************************** Global Variables *******************************************************/ int FD_Printer, FD_Modem, FD_CM; unsigned char sig_flag; int data; int fd,cashfd,c, res,cntr=0,virus=0; unsigned int CM_rply_Cntr=0; char CM_rply_Buf[250]; char rx_data,rx_cntr=0; /*************************************************************************************************************************/ void sig_handler(int status) { read(FD_Modem,&rx_data,1); //read(FD_Modem,CM_rply_Buf,100); //CM_rply_Buf[rx_cntr++]=rx_data; printf("rx_data=%c\n",rx_data); } void modemdelay(void) { unsigned int i=0,j; for(i=0;i<5632;i++) for(j=0;j<4234;j++); } void modemdelay1(void) { unsigned int i=0,j; for(i=0;i<632;i++) for(j=0;j<234;j++); } void serial_cnfg(void) { struct sigaction sa; sa.sa_handler = sig_handler; sa.sa_flags = 0; sa.sa_restorer = NULL; sigemptyset(&sa.sa_mask); sigaction(SIGIO,&sa,NULL); fcntl(FD_Modem,F_SETOWN,getpid()); fcntl(FD_Modem,F_SETFL,FASYNC); } void Modem_Interface(void) { char cmd[]="AT",data,enter=0x0D; unsigned int i=0; printf("Transmitting \n"); while(cmd[i]!='\0') { data=cmd[i++]; write(FD_Modem,&data,1); } write(FD_Modem,0x0D,1); } int main(void) { unsigned int i; while(1) { FD_Printer = open(Printer, O_WRONLY | O_NOCTTY ); if (FD_Printer <0) {perror(Printer); exit(-1); } FD_Modem = open(Modem, O_RDWR | O_NOCTTY ); //for modem if (FD_Modem <0) {perror(Modem); exit(-1); } serial_cnfg(); tcgetattr(FD_Modem,&oldtio); bzero(&newtio, sizeof(newtio)); newtio.c_cflag = BAUDRATE | CRTSCTS | CS8 | CLOCAL | CREAD; newtio.c_iflag = IGNPAR; newtio.c_oflag = 0; newtio.c_lflag = 0; /* set input mode (non-canonical, no echo,...) */ newtio.c_cc[VTIME] = 2; /* inter-character timer unused */ tcflush(FD_Modem, TCIFLUSH); tcsetattr(FD_Modem,TCSANOW,&newtio); modemdelay(); for(i=0;i<248;i++) CM_rply_Buf[i]='\0'; rx_cntr=0; rx_data='\0'; //printf("\nIn Modem_Interface"); Modem_Interface(); modemdelay(); modemdelay(); } tcsetattr(FD_Modem,TCSANOW,&oldtio); return 0; }
I am using wavecom GPRS ( Q24PL002) modem, with 9600 baud rate. I am setting everything in while loop beacuse whenever i used while(1) for only command transmission after some time signal handler did not worked.0 -
1.Are you able to receive data properly? i mean only receiving data packet from your GPRS device?
i have done a program for my project exactly the same way which you want ?
its working for fine N0 HARDWARE control
see the file attached [file name=serail.txt size=2624]http://www.linux.com/media/kunena/attachments/legacy/files/serail.txt[/file]0 -
1.Are you able to receive data properly? i mean only receiving data packet from your GPRS device?
Not always. But sometimes i get "AT" reply from modem.I have tested this code on Hyper Terminal (instead of GPRS modem) it works fine. Sometime it also fails.0 -
how frequent you are sending AT command ?0
-
Not exactly but nearly about after every 6-9 seconds i am sending "AT" command0
-
Hi
have you done a loop test in serial port (short 2 and 3 pin )
write data in serial port and check are you getting the data in your signal handler .
if it works fine then your program is ok
then go for device .0 -
Yes i have tested my code without modem also. It works fine.0
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
- 1 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
- 1.4K LFS258 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
- 946 Programming and Development
- 310 Kernel Development
- 618 Software Development
- 979 Software
- 371 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)