⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mbs.c

📁 libmodbus version 0.04
💻 C
字号:
#include <modbus.h>unsigned char Mbs_slave;				/* slave number */pthread_t Mbs_thread;					/* slave thread */int Mbs_device;							/* slave device *//***********************************************************************************   	   Mbs_read : read one data and call pointer function if !=NULL************************************************************************************input :-------unsigned char c : pointer of the char         no output***********************************************************************************/void Mbs_read(unsigned char *c){   read(Mbs_device,c,1);   if(Mb_ptr_rcv_data!=NULL)      (*Mb_ptr_rcv_data)(*c);}/***********************************************************************************   	   Mbs_write: write packet and call pointer function if !=NULL************************************************************************************input :-------trame 	: packet to sendlongeur	: length of the packetno output***********************************************************************************/void Mbs_write(unsigned char trame[256], int longeur){   int i;   for(i=0;i<longeur;i++)   {      write(Mbs_device,&trame[i],1);      if(Mb_ptr_snd_data!=NULL)         (*Mb_ptr_snd_data)(trame[i]);   }}      /**********************************************************************************   	   Mbs : Main slave function ***********************************************************************************input not usedno output**********************************************************************************/void Mbs(void *ptr){	unsigned char fonction,c,c1,c2,trame[256];   int adresse,longueur,data,i;   int data_to_write[255];	do {		Mbs_read(&c);		if (c==Mbs_slave)		{         if (Mb_verbose) fprintf(stderr,"Master call me !\n");			Mbs_read(&fonction);			if (Mb_verbose) fprintf(stderr,"function 0x%x \n",c);         trame[0]=Mbs_slave;         trame[1]=fonction;			switch (fonction)   		{            /*********************************************************************/      		case 0x03:      		case 0x04:         		/* read n byte */               /* get adress */               Mbs_read(&c1);               Mbs_read(&c2);               adresse=(c1<<8)+c2;               trame[2]=c1;               trame[3]=c2;               if (Mb_verbose) fprintf(stderr,"adress %d (%x %x) \n",adresse,c1,c2);               /* get length */               Mbs_read(&c1);               Mbs_read(&c2);               longueur=(c1<<8)+c2;               if (Mb_verbose) fprintf(stderr,"lenght %d \n",longueur);               trame[4]=c1;               trame[5]=c2;                              /* get crc16 */               Mbs_read(&c1);               Mbs_read(&c2);               trame[6]=c1;               trame[7]=c2;               if (Mb_verbose) fprintf(stderr,"crc  %x%x \n",c1,c2);               /* check crc16 */               if (Mb_test_crc(trame,6))               {                  if (Mb_verbose) fprintf(stderr,"crc error\n");                  if(Mb_ptr_end_slve!=NULL)                     (*Mb_ptr_end_slve)(-1,0,0);                  break;               }               if (Mb_verbose)                   for(i=0;i<=7;i++)                     fprintf(stderr,"sended packet[%d] = %0x\n",i,trame[i]);               /* comput answer packet */               trame[2]=longueur*2;               for (i=0;i<longueur;i++)               {                  if (Mb_verbose)                      fprintf(stderr,"Mbs_data[%d] = %0x\n",adresse+i,Mbs_data[adresse+i]);                  trame[3+i*2]=Mbs_data[adresse+i]>>8;                  trame[4+i*2]=Mbs_data[adresse+i]&0xff;               }               Mb_calcul_crc(trame,(longueur*2)+3);               if (Mb_verbose)               {                  fprintf(stderr,"answer :\n");                  for(i=0;i<longueur*2+5;i++)                     fprintf(stderr,"answer packet[%d] = %0x\n",i,trame[i]);               }               Mbs_write(trame,(longueur*2)+5);               if(Mb_ptr_end_slve!=NULL)                  (*Mb_ptr_end_slve)(fonction,adresse,longueur);         		break;               /*********************************************************************/      		case 0x06:         		/* write on byte */               /* get adress */               Mbs_read(&c1);               Mbs_read(&c2);               adresse=(c1<<8)+c2;               trame[2]=c1;               trame[3]=c2;               if (Mb_verbose) fprintf(stderr,"adress %d (%x %x) \n",adresse,c1,c2);               /* get data */               Mbs_read(&c1);               Mbs_read(&c2);               data=(c1<<8)+c2;               if (Mb_verbose) fprintf(stderr,"data %d \n",data);               trame[4]=c1;               trame[5]=c2;                              /* get crc16 */               Mbs_read(&c1);               Mbs_read(&c2);               trame[6]=c1;               trame[7]=c2;               if (Mb_verbose) fprintf(stderr,"crc  %x%x \n",c1,c2);               /* check crc16 */               if (Mb_test_crc(trame,6))               {                  if (Mb_verbose) fprintf(stderr,"crc error\n");                  if(Mb_ptr_end_slve!=NULL)                     (*Mb_ptr_end_slve)(-1,0,0);                  break;               }               if (Mb_verbose)                   for(i=0;i<=7;i++)                     fprintf(stderr,"sended packet[%d] = %0x\n",i,trame[i]);                              /* store data */               Mbs_data[adresse]=data;               if (Mb_verbose)                   fprintf(stderr,"data %d stored at : %d %x\n",data,adresse,adresse);                              /* answer trame is the same ;-)*/               Mbs_write(trame,8);               if(Mb_ptr_end_slve!=NULL)                  (*Mb_ptr_end_slve)(fonction,adresse,1);                        		break;            /*********************************************************************/      		case 0x07:         		/* read status */               /* get crc16 */               Mbs_read(&c1);               Mbs_read(&c2);               trame[2]=c1;               trame[3]=c2;               if (Mb_verbose) fprintf(stderr,"crc  %x%x \n",c1,c2);               /* check crc16 */               if (Mb_test_crc(trame,2))               {                  if (Mb_verbose) fprintf(stderr,"crc error\n");                  if(Mb_ptr_end_slve!=NULL)                     (*Mb_ptr_end_slve)(-1,0,0);                  break;               }               if (Mb_verbose)                   for(i=0;i<=3;i++)                     fprintf(stderr,"sended packet[%d] = %0x\n",i,trame[i]);               /* comput answer packet */               trame[2]=Mb_status;               Mb_calcul_crc(trame,3);               if (Mb_verbose)               {                  fprintf(stderr,"answer :\n");                  for(i=0;i<=4;i++)                     fprintf(stderr,"answer packet[%d] = %0x\n",i,trame[i]);               }               Mbs_write(trame,5);               if(Mb_ptr_end_slve!=NULL)                  (*Mb_ptr_end_slve)(fonction,0,0);         		break;                     /*********************************************************************/				case 0x08:         		/* line test */               for (i=0;i<4;i++)               {                  Mbs_read(&c);                  if (c!=0) break;                  trame[i+2]=c;               }               if (c!=0) break;               /* get crc16 */               Mbs_read(&c1);               Mbs_read(&c2);               trame[6]=c1;               trame[7]=c2;               if (Mb_verbose) fprintf(stderr,"crc  %x%x \n",c1,c2);               /* check crc16 */               if (Mb_test_crc(trame,6))               {                  if (Mb_verbose) fprintf(stderr,"crc error\n");                  if(Mb_ptr_end_slve!=NULL)                     (*Mb_ptr_end_slve)(-1,0,0);                  break;               }               if (Mb_verbose)                   for(i=0;i<=7;i++)                     fprintf(stderr,"sended packet[%d] = %0x\n",i,trame[i]);               /* return the same packet, it's cool */               Mbs_write(trame,8);               if(Mb_ptr_end_slve!=NULL)                  (*Mb_ptr_end_slve)(fonction,0,0);         		break;                     /*********************************************************************/      		case 0x10:         		/* write n byte  */               /* get adress */               Mbs_read(&c1);               Mbs_read(&c2);               adresse=(c1<<8)+c2;               trame[2]=c1;               trame[3]=c2;               if (Mb_verbose) fprintf(stderr,"adress %d 0x%x%x \n",adresse,c1,c2);               /* get length */               Mbs_read(&c1);               Mbs_read(&c2);               longueur=(c1<<8)+c2;               if (Mb_verbose) fprintf(stderr,"length %d \n",longueur);               trame[4]=c1;               trame[5]=c2;                              /* read for nothing */               Mbs_read(&c);               trame[6]=c;                              /* read data to write */               for (i=0;i<longueur;i++)               {                  Mbs_read(&c1);                  Mbs_read(&c2);                  data_to_write[i]=(c1<<8)+c2;                  trame[7+(i*2)]=c1;                  trame[8+(i*2)]=c2;               }                              /* get crc16 */               Mbs_read(&c1);               Mbs_read(&c2);               trame[7+longueur*2]=c1;               trame[8+longueur*2]=c2;               if (Mb_verbose) fprintf(stderr,"crc  %x%x \n",c1,c2);               /* check crc16 */               if (Mb_test_crc(trame,7+longueur*2))               {                  if (Mb_verbose) fprintf(stderr,"crc error\n");                  if(Mb_ptr_end_slve!=NULL)                     (*Mb_ptr_end_slve)(-1,0,0);                  break;               }               if (Mb_verbose)                   for(i=0;i<=8+longueur*2;i++)                     fprintf(stderr,"sended packet[%d] = %0x\n",i,trame[i]);               /* comput answer packet */               Mb_calcul_crc(trame,6);               if (Mb_verbose)               {                  fprintf(stderr,"answer :\n");                  for(i=0;i<8;i++)                     fprintf(stderr,"answer packet[%d] = %0x\n",i,trame[i]);               }               Mbs_write(trame,8);                              /* copy data to modbus data*/               for(i=0;i<longueur;i++)               {                  Mbs_data[adresse+i]=data_to_write[i];                  if (Mb_verbose)                     fprintf(stderr,"data[%x] = %x\n",adresse+i,data_to_write[i]);               }               if(Mb_ptr_end_slve!=NULL)                  (*Mb_ptr_end_slve)(fonction,adresse,longueur);         		break;      		default:         		break;         }   	}	} while (1);}/***********************************************************************************   	   Mb_slave : start slave thread************************************************************************************input :-------mbsdevice  : device to usemsslave    : slave numberptrfoncsnd : function to call when slave send data (can be NULL if you don't whant to use it)ptrfoncrcv : function to call when slave receive data (can be NULL if you don't whant to use it)ptrfoncend : function to call when slave finish to send answer (can be NULL if you don't whant to use it)no output***********************************************************************************/void Mb_slave(int mbsdevice,int mbsslave, void *ptrfoncsnd, void *ptrfoncrcv, void *ptrfoncend){   Mbs_device=mbsdevice;	Mbs_slave=mbsslave;   Mb_ptr_snd_data=ptrfoncsnd;   Mb_ptr_rcv_data=ptrfoncrcv;   Mb_ptr_end_slve=ptrfoncend;   pthread_create(&Mbs_thread, NULL,(void*)&Mbs,NULL);}/***********************************************************************************   	   Mb_slave_stop : stop slave thread************************************************************************************no inputno output***********************************************************************************/void Mb_slave_stop(){   pthread_cancel(Mbs_thread);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -