summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDenis Kenzior <denkenz@gmail.com>2009-05-21 16:14:01 -0500
committerDenis Kenzior <denkenz@gmail.com>2009-05-21 17:02:56 -0500
commit335749d1638e3975d952a7bffffaed91e568715e (patch)
tree32dc54133f79cb3cbc27564547bd718662398d86
parent77b0d38a1469b1ea1c5a37763c0e48af642b9404 (diff)
downloadofono-335749d1638e3975d952a7bffffaed91e568715e.tar.bz2
Fix Supplementary Service MMI strings per 22.030
-rw-r--r--src/common.c27
-rw-r--r--src/common.h2
2 files changed, 24 insertions, 5 deletions
diff --git a/src/common.c b/src/common.c
index f3ae3f63..6fb7c642 100644
--- a/src/common.c
+++ b/src/common.c
@@ -294,19 +294,34 @@ int mmi_service_code_to_bearer_class(int code)
{
int cls = 0;
+ /* Teleservices according to 22.004
+ * 1 - Voice
+ * 2 - SMS
+ * 3,4,5 - Unallocated
+ * 6 - Fax
+ * 7 - All Data Async
+ * 8 - All Data Sync
+ * 12 - Voice Group
+ */
+
switch (code) {
+ /* 22.030: 1 to 6, 12 */
case 10:
- cls = BEARER_CLASS_DEFAULT | BEARER_CLASS_SMS;
+ cls = BEARER_CLASS_VOICE | BEARER_CLASS_FAX | BEARER_CLASS_SMS;
break;
+ /* 22.030: 1 */
case 11:
cls = BEARER_CLASS_VOICE;
break;
+ /* 22.030: 2-6 */
case 12:
- cls = BEARER_CLASS_DATA;
+ cls = BEARER_CLASS_SMS | BEARER_CLASS_FAX;
break;
+ /* 22.030: 6 */
case 13:
cls = BEARER_CLASS_FAX;
break;
+ /* 22.030: 2 */
case 16:
cls = BEARER_CLASS_SMS;
break;
@@ -314,14 +329,15 @@ int mmi_service_code_to_bearer_class(int code)
case 17:
case 18:
break;
+ /* 22.030: 1, 3 to 6, 12 */
case 19:
- cls = BEARER_CLASS_DEFAULT;
+ cls = BEARER_CLASS_VOICE | BEARER_CLASS_FAX;
break;
- /* Funny, according to 22.030, 20 implies BS 7-11 */
+ /* 22.030: 7-11 */
/* 22.004 only defines BS 7 (Data Sync) & BS 8 (Data Async) */
case 20:
- cls = BEARER_CLASS_DATA_SYNC | BEARER_CLASS_DATA_ASYNC;
+ cls = BEARER_CLASS_DATA_ASYNC | BEARER_CLASS_DATA_SYNC;
break;
/* According to 22.030: All Async */
case 21:
@@ -555,6 +571,7 @@ const char *bearer_class_to_string(enum bearer_class cls)
case BEARER_CLASS_PAD:
return bearer_class_lut[7];
case BEARER_CLASS_DEFAULT:
+ case BEARER_CLASS_SS_DEFAULT:
break;
};
diff --git a/src/common.h b/src/common.h
index 4941ac5e..8fceaa26 100644
--- a/src/common.h
+++ b/src/common.h
@@ -111,6 +111,8 @@ enum bearer_class {
BEARER_CLASS_SMS = 8,
BEARER_CLASS_DATA_SYNC = 16,
BEARER_CLASS_DATA_ASYNC = 32,
+ /* According to 22.030, types 1-12 */
+ BEARER_CLASS_SS_DEFAULT = 61,
BEARER_CLASS_PACKET = 64,
BEARER_CLASS_PAD = 128
};