e816dd9689780664c30c9d25f1acfc4833d64a0d
[dahdi/tools.git] / patgen.c
1 /*
2  * Written by Mark Spencer <markster@digium.com>
3  * Based on previous works, designs, and architectures conceived and
4  * written by Jim Dixon <jim@lambdatel.com>.
5  *
6  * Copyright (C) 2001 Jim Dixon / Zapata Telephony.
7  * Copyright (C) 2001-2008 Digium, Inc.
8  *
9  * All rights reserved.
10  *
11  * Primary Author: Mark Spencer <markster@digium.com>
12  * Radio Support by Jim Dixon <jim@lambdatel.com>
13  */
14
15 /*
16  * See http://www.asterisk.org for more information about
17  * the Asterisk project. Please do not directly contact
18  * any of the maintainers of this project for assistance;
19  * the project provides a web site, mailing lists and IRC
20  * channels for your use.
21  *
22  * This program is free software, distributed under the terms of
23  * the GNU General Public License Version 2 as published by the
24  * Free Software Foundation. See the LICENSE file included with
25  * this program for more details.
26  */
27
28 #include <stdio.h>
29 #include <fcntl.h>
30 #include <string.h>
31 #include <errno.h>
32 #include <stdio.h>
33 #include <linux/types.h>
34 #include <linux/ppp_defs.h> 
35 #include <sys/ioctl.h>
36 #include <unistd.h>
37 #include <stdlib.h>
38 #include "bittest.h"
39
40 #include <dahdi/user.h>
41 #include "dahdi_tools_version.h"
42
43 /* #define BLOCK_SIZE 2048 */
44 #define BLOCK_SIZE 2041
45 #define DEVICE    "/dev/dahdi/channel"
46
47 static const char       rcsid[] = "$Id$";
48 char                    *prog_name;
49
50 static void usage(void)
51 {
52         fprintf(stderr, "Usage: %s <dahdi_chan>\n", prog_name);
53         fprintf(stderr, "   e.g.: %s /dev/dahdi/55\n", prog_name);
54         fprintf(stderr, "         %s 455\n", prog_name);
55         fprintf(stderr, "%s version %s\n", prog_name, rcsid);
56         exit(1);
57 }
58
59 void print_packet(unsigned char *buf, int len)
60 {
61         int x;
62         printf("{ ");
63         for (x=0;x<len;x++)
64                 printf("%02x ",buf[x]);
65         printf("}\n");
66 }
67
68 int channel_open(char *name, int *bs)
69 {
70         int                     channo;
71         int                     fd;
72         struct                  dahdi_params tp;
73         char                    *dev;
74
75         channo = atoi(name);
76         /* channo==0: The user passed a file name to be opened. */
77         dev = channo ? DEVICE : name;
78
79         fd = open(dev, O_RDWR, 0600);
80
81         if (fd < 0) {
82                 perror(DEVICE);
83                 return -1;
84         }
85
86         /* If we got a channel number, get it from /dev/dahdi/channel: */
87         if(channo && ioctl(fd, DAHDI_SPECIFY, &channo) < 0) {
88                 perror("SPECIFY");
89                 return -1;
90         }
91         if(ioctl(fd, DAHDI_SET_BLOCKSIZE, bs) < 0) {
92                 perror("SET_BLOCKSIZE");
93                 return -1;
94         }
95
96         if (ioctl(fd, DAHDI_GET_PARAMS, &tp)) {
97                 fprintf(stderr, "Unable to get channel parameters\n");
98                 return -1;
99         }
100
101         return fd;
102 }
103
104 int main(int argc, char *argv[])
105 {
106         int fd;
107         int res, res1, x;
108         int bs = BLOCK_SIZE;
109         unsigned char c=0;
110         unsigned char outbuf[BLOCK_SIZE];
111
112         prog_name = argv[0];
113
114         if (argc < 2) {
115                 usage();
116         }
117
118         fd = channel_open(argv[1], &bs);
119         if (fd < 0)
120                 exit(1);
121
122         ioctl(fd, DAHDI_GETEVENT);
123 #if 0
124         print_packet(outbuf, res);
125         printf("FCS is %x, PPP_GOODFCS is %x\n",
126         fcs,PPP_GOODFCS);
127 #endif
128         for(;;) {
129                 res = bs;
130                 for (x=0;x<bs;x++) {
131                         outbuf[x] = c;
132                         c = bit_next(c);
133                 }
134                 res1 = write(fd, outbuf, res);
135                 if (res1 < res) {
136                         int e;
137                         struct dahdi_spaninfo zi;
138                         res = ioctl(fd,DAHDI_GETEVENT,&e);
139                         if (res == -1)
140                         {
141                                 perror("DAHDI_GETEVENT");
142                                 exit(1);
143                         }
144                         if (e == DAHDI_EVENT_NOALARM)
145                                 printf("ALARMS CLEARED\n");
146                         if (e == DAHDI_EVENT_ALARM)
147                         {
148                                 zi.spanno = 0;
149                                 res = ioctl(fd,DAHDI_SPANSTAT,&zi);
150                                 if (res == -1)
151                                 {
152                                         perror("DAHDI_SPANSTAT");
153                                         exit(1);
154                                 }
155                                 printf("Alarm mask %x hex\n",zi.alarms);
156                         }
157                         continue;
158                 }
159 #if 0
160                 printf("(%d) Wrote %d bytes\n", packets++, res);
161 #endif
162         }
163         
164 }