Fix: a non ascii byte will trigger BadAddress error
authorChengwei Yang <chengwei.yang@intel.com>
Sat, 29 Jun 2013 03:56:20 +0000 (11:56 +0800)
committerSimon McVittie <simon.mcvittie@collabora.co.uk>
Mon, 1 Jul 2013 11:09:02 +0000 (12:09 +0100)
commit32e5cab56a6707cf897f918999720ff7e455255e
treef4c55cd73b86efe2a4914f5f0474c5e241f86c77
parent160fbc9ec110fc3aa691b86971b50ee8dc740783
Fix: a non ascii byte will trigger BadAddress error

If a byte in DBusString *unescaped isn't a ascii byte, which will be
cast to char (signed char on most of platform), so that's the issue
unsigned char cast to signed char. e.g. "\303\266" is a valid unicode
character, if everything goes right, it will be escaped to "%c3%b6".
However, in fact, it escaped to "%<garbage-byte>3%<garbage-byte>6".

_dbus_string_append_byte_as_hex() take an int parameter, so negative
byte is valid, but cause get a negative index in array. So garbage value
will get. e.g. '\303' --> hexdigits[((signed byte)(-61)) >> 4] is
hexdigits[-4].

Bug: https://bugs.freedesktop.org/show_bug.cgi?id=53499
Sgne-off-by: Chengwei Yang <chengwei.yang@intel.com>
[fixed whitespace -smcv]
Reviewed-by: Simon McVittie <simon.mcvittie@collabora.co.uk>
dbus/dbus-address.c
dbus/dbus-string.c
dbus/dbus-string.h