FreeCalypso > hg > ice1-trau-tester
annotate pcm/pcm_tx.c @ 23:0d70444b5070
ater: more robust msgb handling in TRAU-UL output
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Mon, 24 Jun 2024 18:21:01 +0000 |
parents | 27ca01bb5b11 |
children | fa341317c844 |
rev | line source |
---|---|
7
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
1 /* |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
2 * In this module we implement PCM Tx toward the TRAU. |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
3 */ |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
4 |
10
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
5 #include <sys/types.h> |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
6 #include <sys/file.h> |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
7 #include <sys/stat.h> |
8
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
8 #include <ctype.h> |
7
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
9 #include <stdint.h> |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
10 #include <stdbool.h> |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
11 #include <stdio.h> |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
12 #include <stdlib.h> |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
13 #include <string.h> |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
14 #include <unistd.h> |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
15 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
16 #include <osmocom/core/select.h> |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
17 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
18 #include "globals.h" |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
19 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
20 static const uint8_t dmw_alaw[8] = |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
21 {0x34, 0x21, 0x21, 0x34, 0xB4, 0xA1, 0xA1, 0xB4}; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
22 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
23 static uint8_t pcm_fill_octet = 0x54; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
24 static bool dmw_active; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
25 static uint8_t *play_buffer; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
26 static unsigned play_buf_nframes, play_buf_ptr; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
27 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
28 static void fill_with_dmw(uint8_t *buf) |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
29 { |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
30 unsigned n; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
31 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
32 for (n = 0; n < 20; n++) { |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
33 memcpy(buf, dmw_alaw, 8); |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
34 buf += 8; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
35 } |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
36 } |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
37 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
38 static void fill_with_play(uint8_t *outbuf) |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
39 { |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
40 memcpy(outbuf, play_buffer + play_buf_ptr * 160, 160); |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
41 play_buf_ptr++; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
42 if (play_buf_ptr < play_buf_nframes) |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
43 return; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
44 free(play_buffer); |
10
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
45 play_buffer = NULL; |
7
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
46 printf("file play finished\n"); |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
47 } |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
48 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
49 void transmit_pcm_20ms(void) |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
50 { |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
51 uint8_t buf[160]; |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
52 |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
53 if (play_buffer) |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
54 fill_with_play(buf); |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
55 else if (dmw_active) |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
56 fill_with_dmw(buf); |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
57 else |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
58 memset(buf, pcm_fill_octet, 160); |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
59 write(ts_fd, buf, 160); |
ca351324187a
pcm: implement Tx on the E1 timeslot
Mychaela Falconia <falcon@freecalypso.org>
parents:
diff
changeset
|
60 } |
8
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
61 |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
62 void cmd_pcm_fill(int argc, char **argv) |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
63 { |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
64 u_long val; |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
65 char *cp; |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
66 |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
67 if (argc != 2) { |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
68 printf("error: pcm-fill command needs 1 argument\n"); |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
69 return; |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
70 } |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
71 if (!isxdigit(argv[1][0])) { |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
72 inv_arg: printf("error: argument is not a valid hex octet\n"); |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
73 return; |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
74 } |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
75 val = strtoul(argv[1], &cp, 16); |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
76 if (*cp) |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
77 goto inv_arg; |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
78 if (val > 0xFF) |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
79 goto inv_arg; |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
80 pcm_fill_octet = val; |
70aa8cbdbde9
pcm: implement pcm-fill command
Mychaela Falconia <falcon@freecalypso.org>
parents:
7
diff
changeset
|
81 } |
9
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
82 |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
83 void cmd_dmw_on(int argc, char **argv) |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
84 { |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
85 dmw_active = true; |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
86 } |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
87 |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
88 void cmd_dmw_off(int argc, char **argv) |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
89 { |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
90 dmw_active = false; |
e3d16d490ce2
pcm: implement dmw-on and dmw-off commands
Mychaela Falconia <falcon@freecalypso.org>
parents:
8
diff
changeset
|
91 } |
10
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
92 |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
93 void cmd_play_file(int argc, char **argv) |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
94 { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
95 int fd; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
96 struct stat st; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
97 |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
98 if (argc != 2) { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
99 printf("error: play command needs 1 argument\n"); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
100 return; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
101 } |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
102 if (play_buffer) { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
103 printf("error: file play already in progress\n"); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
104 return; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
105 } |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
106 fd = open(argv[1], O_RDONLY); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
107 if (fd < 0) { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
108 perror(argv[1]); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
109 return; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
110 } |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
111 fstat(fd, &st); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
112 if (!S_ISREG(st.st_mode)) { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
113 close(fd); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
114 fprintf(stderr, "error: %s is not a regular file\n", argv[1]); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
115 return; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
116 } |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
117 if (!st.st_size) { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
118 close(fd); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
119 fprintf(stderr, "error: %s is an empty file\n", argv[1]); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
120 return; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
121 } |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
122 if (st.st_size % 160) { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
123 close(fd); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
124 fprintf(stderr, |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
125 "error: size of %s is not a multiple of 160 bytes\n", |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
126 argv[1]); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
127 return; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
128 } |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
129 play_buffer = malloc(st.st_size); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
130 if (!play_buffer) { |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
131 close(fd); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
132 fprintf(stderr, "unable to malloc buffer for %s\n", argv[1]); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
133 return; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
134 } |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
135 read(fd, play_buffer, st.st_size); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
136 close(fd); |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
137 play_buf_nframes = st.st_size / 160; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
138 play_buf_ptr = 0; |
5cf7818a7d08
pcm: implement play command
Mychaela Falconia <falcon@freecalypso.org>
parents:
9
diff
changeset
|
139 } |
11
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
140 |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
141 void cmd_play_offset(int argc, char **argv) |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
142 { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
143 int fd; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
144 struct stat st; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
145 unsigned offset, pre_offset; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
146 |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
147 if (argc != 3) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
148 printf("error: play-offset command needs 2 arguments\n"); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
149 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
150 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
151 if (play_buffer) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
152 printf("error: file play already in progress\n"); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
153 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
154 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
155 offset = strtoul(argv[2], NULL, 0); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
156 if (offset < 1 || offset > 159) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
157 printf("error: offset argument out of range\n"); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
158 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
159 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
160 fd = open(argv[1], O_RDONLY); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
161 if (fd < 0) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
162 perror(argv[1]); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
163 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
164 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
165 fstat(fd, &st); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
166 if (!S_ISREG(st.st_mode)) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
167 close(fd); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
168 fprintf(stderr, "error: %s is not a regular file\n", argv[1]); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
169 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
170 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
171 if (!st.st_size) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
172 close(fd); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
173 fprintf(stderr, "error: %s is an empty file\n", argv[1]); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
174 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
175 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
176 if (st.st_size % 160) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
177 close(fd); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
178 fprintf(stderr, |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
179 "error: size of %s is not a multiple of 160 bytes\n", |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
180 argv[1]); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
181 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
182 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
183 play_buffer = malloc(st.st_size + 160); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
184 if (!play_buffer) { |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
185 close(fd); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
186 fprintf(stderr, "unable to malloc buffer for %s\n", argv[1]); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
187 return; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
188 } |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
189 pre_offset = 160 - offset; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
190 memset(play_buffer, pcm_fill_octet, pre_offset); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
191 read(fd, play_buffer + pre_offset, st.st_size); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
192 close(fd); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
193 memset(play_buffer + pre_offset + st.st_size, pcm_fill_octet, offset); |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
194 play_buf_nframes = st.st_size / 160 + 1; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
195 play_buf_ptr = 0; |
e149ca1dd14f
pcm: implement play-offset command
Mychaela Falconia <falcon@freecalypso.org>
parents:
10
diff
changeset
|
196 } |
12
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
197 |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
198 void cmd_play_stop(int argc, char **argv) |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
199 { |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
200 if (!record_file) { |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
201 printf("error: no file play in progress\n"); |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
202 return; |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
203 } |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
204 free(play_buffer); |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
205 play_buffer = NULL; |
27ca01bb5b11
pcm: implement play-stop command
Mychaela Falconia <falcon@freecalypso.org>
parents:
11
diff
changeset
|
206 } |