[svn-commits] rizzo: branch rizzo/video_v2 r82591 - /team/rizzo/video_v2/channels/
SVN commits to the Digium repositories
svn-commits at lists.digium.com
Mon Sep 17 11:35:31 CDT 2007
Author: rizzo
Date: Mon Sep 17 11:35:31 2007
New Revision: 82591
URL: http://svn.digium.com/view/asterisk?view=rev&rev=82591
Log:
more debugging...
Modified:
team/rizzo/video_v2/channels/console_video.c
Modified: team/rizzo/video_v2/channels/console_video.c
URL: http://svn.digium.com/view/asterisk/team/rizzo/video_v2/channels/console_video.c?view=diff&rev=82591&r1=82590&r2=82591
==============================================================================
--- team/rizzo/video_v2/channels/console_video.c (original)
+++ team/rizzo/video_v2/channels/console_video.c Mon Sep 17 11:35:31 2007
@@ -922,53 +922,55 @@
*/
static struct ast_frame *split_frame(struct video_out_desc *out, int len)
{
- uint8_t *data;
struct ast_frame *cur = NULL, *first = NULL;
- uint8_t *start = out->decbuf.data;
- int have_psc = 0; /* did we skip 2 bytes for this frame ? */
- int l; /* size of the current fragment */
- l = len;
-
- for (;len > 0; start += l, len -= l) {
- /* First try to split on a psc. If not, create an artificial break */
+ uint8_t *d = out->decbuf.data;
+ int l = len; /* size of the current fragment. If 0, must look for a psc */
+ int totlen = len, frags = 0;
+
+ for (;len > 0; len -= l, d += l) {
+ uint8_t *data;
struct ast_frame *f;
-#if 0
- int max_size = len;
- max_size = MIN(len, out->mtu + 2);
- for (l = 0; l < max_size -2; l++) {
- if (start[l] == 0 && start[l+1] == 0)
- break;
- }
- if (l == 0) {
- l = 2;
- have_psc = 1; /* info for next frame */
- continue;
- }
- if (l > out->mtu) {
+ int i;
+
+ if (len >= 2 && d[0] == 0 && d[1] == 0) {
+ /* we are starting a new block, so look for a PSC. */
+ for (i = 2; i < len - 2; i++) {
+ if (d[i] == 0 && d[i+1] == 0) {
+ l = i;
+ break;
+ }
+ }
+ }
+ if (l > out->mtu || l > len) {
+ /* psc not found, split */
ast_log(LOG_WARNING, "no psc in frame sized %d\n", len);
- l = out->mtu;
- }
-#endif
- /* temporary - assume we have psc, drop first 2 bytes, send one large packet */
-
- ast_log(LOG_WARNING, "len %d\n", l);
+ l = MIN(len, out->mtu);
+ }
+ if (l < 1 || l > 128*1024) {
+ ast_log(LOG_WARNING, "--- frame error l %d\n", l);
+ break;
+ }
f = ast_calloc(1, sizeof(*f));
- data = ast_calloc(1, l+2);
- if (l < 1 || l > 128*1024 || f == NULL || data == NULL) {
+ data = ast_calloc(1, l+2); /* 2 extra bytes for header */
+ if (f == NULL || data == NULL) {
ast_log(LOG_WARNING, "--- frame error f %p d %p l %d\n",
- f, data, l);
+ f, d, l);
+ if (f)
+ ast_free(f);
+ if (d)
+ ast_free(d);
break;
}
f->mallocd = AST_MALLOCD_DATA | AST_MALLOCD_HDR;
f->data = data;
- if (data[0] == 0 && data[1] == 0) { /* a psc */
- memcpy(data, start, l);
- data[0] |= 0x04; // P == 1
+ if (d[0] == 0 && d[1] == 0) { /* we start with a psc */
+ memcpy(data, d, l);
+ data[0] |= 0x04; // set P == 1, and we are done
f->datalen = l;
- } else {
+ } else { /* no psc, create a header */
data[0] = data[1] = 0; // P == 0
- memcpy(data + 2, start, l);
+ memcpy(data + 2, d, l);
f->datalen = l + 2;
}
@@ -979,8 +981,6 @@
f->samples = 0;
f->offset = 0;
f->src = "Console";
- // This flags tells asterisk that the data and
- // the header are dinamically allocated
f->delivery.tv_sec = 0;
f->delivery.tv_usec = 0;
f->seqno = ++(out->lasttxframe);
@@ -991,13 +991,14 @@
else
first = f;
cur = f;
- have_psc = (l <= out->mtu);
+ frags++;
+ ast_log(LOG_WARNING, "-- frag %d size %d left %d\n", frags, f->datalen, len - l);
}
if (cur)
cur->subclass |= 1; // RTP Marker
- // ast_log(LOG_WARNING, "done, first %p\n", first);
+ ast_log(LOG_WARNING, "done, totlen %d frags %d\n", totlen, frags);
return first;
}
@@ -1073,7 +1074,6 @@
fprintf(stderr, "video_out_init fd %d\n", env->out.fd);
video_out_init(&env->out, CONSOLE_FORMAT_VIDEO);
}
- ast_log(LOG_WARNING, "console_video_start owner %p", owner);
env->out.ts = ast_tvnow();
}
#endif /* video support */
More information about the svn-commits
mailing list