summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohan Hedberg <johan.hedberg@nokia.com>2007-08-03 11:41:55 +0000
committerJohan Hedberg <johan.hedberg@nokia.com>2007-08-03 11:41:55 +0000
commit5f1807426113c8385415a8ecbd650b142e473103 (patch)
tree5503e6768c395066634d56b0ca405ae76b2a5049
parente929f72c17c104ed4eb6c15bda8f5d2be58c8084 (diff)
Check for invalid minor class string table index
-rw-r--r--hcid/dbus-adapter.c36
1 files changed, 29 insertions, 7 deletions
diff --git a/hcid/dbus-adapter.c b/hcid/dbus-adapter.c
index da2d0372..4a504067 100644
--- a/hcid/dbus-adapter.c
+++ b/hcid/dbus-adapter.c
@@ -58,6 +58,8 @@
#include "dbus-error.h"
#include "dbus-adapter.h"
+#define NUM_ELEMENTS(table) (sizeof(table)/sizeof(const char *))
+
static const char *service_cls[] = {
"positioning",
"networking",
@@ -3039,19 +3041,33 @@ const char *minor_class_str(uint32_t class)
switch (major_index) {
case 1: /* computer */
minor_index = (class >> 2) & 0x3F;
- return computer_minor_cls[minor_index];
+ if (minor_index < NUM_ELEMENTS(computer_minor_cls))
+ return computer_minor_cls[minor_index];
+ else
+ return "";
case 2: /* phone */
minor_index = (class >> 2) & 0x3F;
- return phone_minor_cls[minor_index];
+ if (minor_index < NUM_ELEMENTS(phone_minor_cls))
+ return phone_minor_cls[minor_index];
+ return "";
case 3: /* access point */
minor_index = (class >> 5) & 0x07;
- return access_point_minor_cls[minor_index];
+ if (minor_index < NUM_ELEMENTS(access_point_minor_cls))
+ return access_point_minor_cls[minor_index];
+ else
+ return "";
case 4: /* audio/video */
minor_index = (class >> 2) & 0x3F;
- return audio_video_minor_cls[minor_index];
+ if (minor_index < NUM_ELEMENTS(audio_video_minor_cls))
+ return audio_video_minor_cls[minor_index];
+ else
+ return "";
case 5: /* peripheral */
minor_index = (class >> 6) & 0x03;
- return peripheral_minor_cls[minor_index];
+ if (minor_index < NUM_ELEMENTS(peripheral_minor_cls))
+ return peripheral_minor_cls[minor_index];
+ else
+ return "";
case 6: /* imaging */
{
uint8_t shift_minor = 0;
@@ -3066,10 +3082,16 @@ const char *minor_class_str(uint32_t class)
break;
case 7: /* wearable */
minor_index = (class >> 2) & 0x3F;
- return wearable_minor_cls[minor_index];
+ if (minor_index < NUM_ELEMENTS(wearable_minor_cls))
+ return wearable_minor_cls[minor_index];
+ else
+ return "";
case 8: /* toy */
minor_index = (class >> 2) & 0x3F;
- return toy_minor_cls[minor_index];
+ if (minor_index < NUM_ELEMENTS(toy_minor_cls))
+ return toy_minor_cls[minor_index];
+ else
+ return "";
}
return "";