summaryrefslogtreecommitdiff
path: root/main/frame.c
diff options
context:
space:
mode:
authorJoshua Colp <jcolp@digium.com>2009-06-26 19:27:24 +0000
committerJoshua Colp <jcolp@digium.com>2009-06-26 19:27:24 +0000
commit59c1998d67ecd9c2ade02c288aaef7596fcdfd4a (patch)
tree7d14c88d204bd105f7d39b32a5bf704bb486d3d6 /main/frame.c
parent5ebf0f3c501f4f4f3801efd3b6e9b72e889b4100 (diff)
Improve T.38 negotiation by exchanging session parameters between application and channel.
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@203699 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'main/frame.c')
-rw-r--r--main/frame.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/main/frame.c b/main/frame.c
index e305580ac..09c11dbda 100644
--- a/main/frame.c
+++ b/main/frame.c
@@ -857,6 +857,25 @@ void ast_frame_dump(const char *name, struct ast_frame *f, char *prefix)
}
snprintf(subclass, sizeof(subclass), "T38/%s", message);
break;
+ case AST_CONTROL_T38_PARAMETERS:
+ if (f->datalen != sizeof(struct ast_control_t38_parameters *)) {
+ message = "Invalid";
+ } else {
+ struct ast_control_t38_parameters *parameters = f->data.ptr;
+ enum ast_control_t38 state = parameters->request_response;
+ if (state == AST_T38_REQUEST_NEGOTIATE)
+ message = "Negotiation Requested";
+ else if (state == AST_T38_REQUEST_TERMINATE)
+ message = "Negotiation Request Terminated";
+ else if (state == AST_T38_NEGOTIATED)
+ message = "Negotiated";
+ else if (state == AST_T38_TERMINATED)
+ message = "Terminated";
+ else if (state == AST_T38_REFUSED)
+ message = "Refused";
+ }
+ snprintf(subclass, sizeof(subclass), "T38_Parameters/%s", message);
+ break;
case -1:
strcpy(subclass, "Stop generators");
break;