]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
chan_dahdi: Fix "dahdi show channels group" for groups greater than 31.
authorRichard Mudgett <rmudgett@digium.com>
Wed, 30 Jan 2013 21:51:12 +0000 (21:51 +0000)
committerRichard Mudgett <rmudgett@digium.com>
Wed, 30 Jan 2013 21:51:12 +0000 (21:51 +0000)
The variable type used was not large enough to hold a group bit field.
........

Merged revisions 380572 from http://svn.asterisk.org/svn/asterisk/branches/1.8

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/11@380575 65c4cc65-6c06-0410-ace0-fbb531ad65f3

channels/chan_dahdi.c

index c60379795e425f264605acee5ea211ff54245158..bb621acabc8f8fadae07ab8beef9cb36e2da5458 100644 (file)
@@ -15516,7 +15516,7 @@ static char *dahdi_show_channels(struct ast_cli_entry *e, int cmd, struct ast_cl
 {
 #define FORMAT "%7s %-10.10s %-15.15s %-10.10s %-20.20s %-10.10s %-10.10s %-32.32s\n"
 #define FORMAT2 "%7s %-10.10s %-15.15s %-10.10s %-20.20s %-10.10s %-10.10s %-32.32s\n"
-       int targetnum = 0;
+       ast_group_t targetnum = 0;
        int filtertype = 0;
        struct dahdi_pvt *tmp = NULL;
        char tmps[20] = "";
@@ -15543,9 +15543,10 @@ static char *dahdi_show_channels(struct ast_cli_entry *e, int cmd, struct ast_cl
        if (a->argc == 5) {
                if (!strcasecmp(a->argv[3], "group")) {
                        targetnum = atoi(a->argv[4]);
-                       if ((targetnum < 0) || (targetnum > 63))
+                       if (63 < targetnum) {
                                return CLI_SHOWUSAGE;
-                       targetnum = 1 << targetnum;
+                       }
+                       targetnum = ((ast_group_t) 1) << targetnum;
                        filtertype = 1;
                } else if (!strcasecmp(a->argv[3], "context")) {
                        filtertype = 2;