经常需要通过串口发送十六进制数据,但linux找不到适合的串口调试工具,自己写了个小工具进行串口调试。
#include "../lib/serial/serial.h"
#include <stdlib.h>
#include <stdio.h>
#include <getopt.h>
#include <string.h>
int AscToHex(char hexstr[], char **out);
char CheckSum(char *buf, int len);
/*
typedef struct _usartAttr
{
int speed;
int bits;
int event;
int stop;
int fd;
int write_timeout;
int read_timeout;
int serialport;
}UsartAttr;
*/
void showUsage()
{
puts("Options:" );
puts(" -p, --serialport=portnum The serial port to send." );
puts(" -c, --checksum If add checksum at the end." );
puts(" -B, --baud=speed The serial speed eg.115200 9600 4800" );
puts(" -v, --version Print the version number and exit." );
puts(" -h, --help Print this message and exit." );
puts(" --buf=senddate The buf which need to send eg. " "ff 01 00 25 " "" );
exit(0);
}
int lopt;
static struct option longOpts[] = {
{ "serial-port", required_argument, NULL, 'p' },
{ "checksum", no_argument, NULL, 'c' },
{ "baud", required_argument, NULL, 'B' },
{ "version", no_argument, NULL, 'v' },
{ "help", no_argument, NULL, 'h' },
{ "buf", required_argument, &lopt, 'b' },
{ 0, 0, 0, 0 }
};
int main(char argc, char *argv[])
{
char flag_checksum = 0;
char *sendbuf = NULL;
int buflen = 0;
UsartAttr SerialAttr = { 115200, 8, 'N', 1, 0, 500, 500, 1 };
while (1)
{
int optIndex = 0;
char c = getopt_long(argc, argv, "p:b:cB:vh", longOpts, &optIndex);
if ( c == '?' || c == -1)
{
showUsage();
}
if (c == 0xff)
{
if (sendbuf == NULL)
{
showUsage();
}
break;
}
switch (c)
{
case 0:
{
switch (lopt)
{
case 'b':
{
buflen = AscToHex(optarg, &sendbuf);
if (buflen == -1)
{
printf("--buf error \n");
goto cleanup;
}
break;
}
}
break;
}
case 'p':
SerialAttr.serialport = *optarg - '0';
break;
case 'c':
flag_checksum = 1;
break;
case 'B':
SerialAttr.speed = atoi(optarg);
break;
case 'v':
printf("version: V1.0\n");
break;
case 'h':
showUsage();
break;
default:
break;
}
}
UsartOpenAPI(&SerialAttr);
UsartWriteAPI(&SerialAttr, sendbuf, buflen);
if (flag_checksum == 1)
{
char sum = CheckSum(sendbuf + 1, buflen - 1);
printf("Send check sum : ");
UsartWriteAPI(&SerialAttr, &sum, 1);
}
UsartCloseAPI(&SerialAttr);
cleanup:
free(sendbuf);
return 0;
}
char CheckSum(char *buf, int len)
{
char ret = 0;
for (int i = 0; i < len; i++)
{
ret += buf[i];
}
return ret;
}
char ChToNum(char ch)
{
char ret = 0;
if (ch >= '0' && ch <= '9')
{
ret = ch - '0';
}
else if (ch >= 'a' && ch <= 'f')
{
ret = ch - 'a' + 10;
}
else if (ch >= 'A' && ch <= 'F')
{
ret = ch - 'A' + 10;
}
return ret;
}
int AscToHex(char hexstr[], char **out)
{
int len = strlen(hexstr);
int i = 0, j = 0, k = 0;
k = len;
while (k--)
{
if (!((hexstr[k] == ' ') ||
(hexstr[k] >= '0' && hexstr[k] <= '9' ) ||
(hexstr[k] >= 'a' && hexstr[k] <= 'f' ) ||
(hexstr[k] >= 'A' && hexstr[k] <= 'F' )))
{
return -1;
}
}
char *hexstr2 = (char *)malloc(len);
while (i < len)
{
(hexstr[i] != ' ') ? (hexstr2[j++] = hexstr[i++]) : i++;
}
hexstr2[j--] = '\0';
*out = (char *)malloc(j / 2);
for (i = 0; i < j; i += 2)
{
(*out)[i / 2] = ((ChToNum(hexstr2[i])) << 4) + (ChToNum(hexstr2[i + 1]));
}
free(hexstr2);
return j / 2 + 1;
}