diff options
-rw-r--r-- | src/mm-modem-helpers.c | 19 | ||||
-rw-r--r-- | src/mm-modem-helpers.h | 2 |
2 files changed, 21 insertions, 0 deletions
diff --git a/src/mm-modem-helpers.c b/src/mm-modem-helpers.c index f7ee0f62..1df64341 100644 --- a/src/mm-modem-helpers.c +++ b/src/mm-modem-helpers.c @@ -646,6 +646,25 @@ out: return mask; } +MMFlowControl +mm_parse_flow_control_tag (const gchar *flow_control_tag) +{ + MMFlowControl flow_control; + + if (g_strcmp0 ("xonxoff", flow_control_tag) == 0) + flow_control = MM_FLOW_CONTROL_XON_XOFF; + else if (g_strcmp0 ("rtscts", flow_control_tag) == 0) + flow_control = MM_FLOW_CONTROL_RTS_CTS; + else if (g_strcmp0 ("none", flow_control_tag) == 0) + flow_control = MM_FLOW_CONTROL_NONE; + else { + mm_warn ("Cannot parse flow control tag: '%s', setting as unknown", flow_control_tag); + flow_control = MM_FLOW_CONTROL_UNKNOWN; + } + + return flow_control; +} + /*************************************************************************/ /* +CREG: <stat> (GSM 07.07 CREG=1 unsolicited) */ diff --git a/src/mm-modem-helpers.h b/src/mm-modem-helpers.h index a7c7eaca..fcac9f13 100644 --- a/src/mm-modem-helpers.h +++ b/src/mm-modem-helpers.h @@ -112,6 +112,8 @@ typedef enum { /*< underscore_name=mm_flow_control >*/ MMFlowControl mm_parse_ifc_test_response (const gchar *response, GError **error); +MMFlowControl mm_parse_flow_control_tag (const gchar *flow_control); + /*****************************************************************************/ /* 3GPP specific helpers and utilities */ /*****************************************************************************/ |