[PATCH] huawei: handle optional 0x prefix on hex numbers in ^DHCP response
Aleksander Morgado
aleksander at aleksander.es
Mon Jan 29 20:56:43 UTC 2018
On Fri, Jan 26, 2018 at 11:25 PM, Ben Chan <benchan at chromium.org> wrote:
>
> On Huawei ME936, the hex numbers in the response to AT^DHCP contain the 0x prefix, e.g.
>
> AT^DHCP?
>
> ^DHCP: 0xda7d0e0a,0xff000000,0xdb7d0e0a,0xdb7d0e0a,0x01261aac,0x00000000,100000000,50000000
>
> This patch updates mm_huawei_parse_dhcp_response() to handle the
> optional 0x prefix.
This was merged to git master already.
Thanks!
>
> ---
> plugins/huawei/mm-modem-helpers-huawei.c | 2 +-
> plugins/huawei/tests/test-modem-helpers-huawei.c | 6 ++++++
> 2 files changed, 7 insertions(+), 1 deletion(-)
>
> diff --git a/plugins/huawei/mm-modem-helpers-huawei.c b/plugins/huawei/mm-modem-helpers-huawei.c
> index fde1c791..e92552ed 100644
> --- a/plugins/huawei/mm-modem-helpers-huawei.c
> +++ b/plugins/huawei/mm-modem-helpers-huawei.c
> @@ -230,7 +230,7 @@ mm_huawei_parse_dhcp_response (const char *reply,
> * actually 10.10.1.1.
> */
>
> - r = g_regex_new ("\\^DHCP:\\s*([0-9a-fA-F]+),([0-9a-fA-F]+),([0-9a-fA-F]+),([0-9a-fA-F]+),([0-9a-fA-F]+),([0-9a-fA-F]+),.*$", 0, 0, NULL);
> + r = g_regex_new ("\\^DHCP:\\s*(?:0[xX])?([0-9a-fA-F]+),(?:0[xX])?([0-9a-fA-F]+),(?:0[xX])?([0-9a-fA-F]+),(?:0[xX])?([0-9a-fA-F]+),(?:0[xX])?([0-9a-fA-F]+),(?:0[xX])?([0-9a-fA-F]+),.*$", 0, 0, NULL);
> g_assert (r != NULL);
>
> matched = g_regex_match_full (r, reply, -1, 0, 0, &match_info, &match_error);
> diff --git a/plugins/huawei/tests/test-modem-helpers-huawei.c b/plugins/huawei/tests/test-modem-helpers-huawei.c
> index 46c90f44..70c40db2 100644
> --- a/plugins/huawei/tests/test-modem-helpers-huawei.c
> +++ b/plugins/huawei/tests/test-modem-helpers-huawei.c
> @@ -154,10 +154,16 @@ typedef struct {
> static const DhcpTest dhcp_tests[] = {
> { "^DHCP:a3ec5c64,f8ffffff,a1ec5c64,a1ec5c64,2200b10a,74bba80a,236800,236800\r\n",
> "100.92.236.163", 29, "100.92.236.161", "10.177.0.34", "10.168.187.116" },
> + { "^DHCP:0xa3ec5c64,0xf8ffffff,0xa1ec5c64,0xa1ec5c64,0x2200b10a,0x74bba80a,236800,236800\r\n",
> + "100.92.236.163", 29, "100.92.236.161", "10.177.0.34", "10.168.187.116" },
> { "^DHCP: 1010A0A,FCFFFFFF,2010A0A,2010A0A,0,0,150000000,150000000\r\n",
> "10.10.1.1", 30, "10.10.1.2", "0.0.0.0", "0.0.0.0" },
> { "^DHCP: CCDB080A,F8FFFFFF,C9DB080A,C9DB080A,E67B59C0,E77B59C0,85600,85600\r\n",
> "10.8.219.204", 29, "10.8.219.201", "192.89.123.230", "192.89.123.231" },
> + { "^DHCP: 0xCCDB080A,0xF8FFFFFF,0xC9DB080A,0xC9DB080A,0xE67B59C0,0xE77B59C0,85600,85600\r\n",
> + "10.8.219.204", 29, "10.8.219.201", "192.89.123.230", "192.89.123.231" },
> + { "^DHCP: 0XCCDB080A,0XF8FFFFFF,0XC9DB080A,0XC9DB080A,0XE67B59C0,0XE77B59C0,85600,85600\r\n",
> + "10.8.219.204", 29, "10.8.219.201", "192.89.123.230", "192.89.123.231" },
> { NULL }
> };
>
> --
> 2.16.0.rc1.238.g530d649a79-goog
>
--
Aleksander
https://aleksander.es
More information about the ModemManager-devel
mailing list