From 529eecdb9771cbb9140af015e4a8a5fdb3df59a7 Mon Sep 17 00:00:00 2001 From: Aleksander Morgado Date: Fri, 31 Aug 2012 13:54:48 +0200 Subject: modem-helpers: new helper to convert from netmask string to CIDR --- src/mm-modem-helpers.c | 12 ++++++++++++ src/mm-modem-helpers.h | 2 ++ 2 files changed, 14 insertions(+) (limited to 'src') diff --git a/src/mm-modem-helpers.c b/src/mm-modem-helpers.c index 4c93045b..e595c45b 100644 --- a/src/mm-modem-helpers.c +++ b/src/mm-modem-helpers.c @@ -22,6 +22,7 @@ #include #include #include +#include #include #include @@ -135,6 +136,17 @@ mm_create_device_identifier (guint vid, /*****************************************************************************/ +guint +mm_netmask_to_cidr (const gchar *netmask) +{ + guint32 num = 0; + + inet_pton (AF_INET, netmask, &num); + return mm_count_bits_set (num); +} + +/*****************************************************************************/ + /* +CREG: (GSM 07.07 CREG=1 unsolicited) */ #define CREG1 "\\+(CREG|CGREG):\\s*0*([0-9])" diff --git a/src/mm-modem-helpers.h b/src/mm-modem-helpers.h index 4754e7f9..26169e97 100644 --- a/src/mm-modem-helpers.h +++ b/src/mm-modem-helpers.h @@ -58,6 +58,8 @@ gchar *mm_create_device_identifier (guint vid, const gchar *model, const gchar *manf); +guint mm_netmask_to_cidr (const gchar *netmask); + /*****************************************************************************/ /* 3GPP specific helpers and utilities */ /*****************************************************************************/ -- cgit v1.2.3-70-g09d2