diff options
author | John Keeping | 2013-04-01 19:03:34 +0100 |
---|---|---|
committer | Jason A. Donenfeld | 2013-04-08 15:59:46 +0200 |
commit | b1f17f168b91d709c0c0e62608de301a36f06da9 (patch) | |
tree | 9aff1fe903087cb5016ab2afdb32a7ca1cc139b2 /cgit.h | |
parent | 4b4a62d507adc61e20e75e2748301ef307a6c95f (diff) | |
download | cgit-b1f17f168b91d709c0c0e62608de301a36f06da9.tar.gz cgit-b1f17f168b91d709c0c0e62608de301a36f06da9.tar.bz2 cgit-b1f17f168b91d709c0c0e62608de301a36f06da9.zip |
Fix out-of-bounds memory accesses with virtual_root=""
The CGit configuration variable virtual_root is normalized so that it
does not have a trailing '/' character, but it is allowed to be empty
(the empty string and NULL have different meanings here) and there is
code that is insufficiently cautious when checking if it ends in a '/':
if (virtual_root[strlen(virtual_root) - 1] != '/')
Clearly this check is redundant, but rather than simply removing it we
get a slight efficiency improvement by switching the normalization so
that the virtual_root variable always ends in '/'. Do this with a new
"ensure_end" helper.
Signed-off-by: John Keeping <john@keeping.me.uk>
Diffstat (limited to 'cgit.h')
-rw-r--r-- | cgit.h | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -190,7 +190,7 @@ struct cgit_config { | |||
190 | char *script_name; | 190 | char *script_name; |
191 | char *section; | 191 | char *section; |
192 | char *repository_sort; | 192 | char *repository_sort; |
193 | char *virtual_root; | 193 | char *virtual_root; /* Always ends with '/'. */ |
194 | char *strict_export; | 194 | char *strict_export; |
195 | int cache_size; | 195 | int cache_size; |
196 | int cache_dynamic_ttl; | 196 | int cache_dynamic_ttl; |
@@ -300,6 +300,7 @@ extern int chk_positive(int result, char *msg); | |||
300 | extern int chk_non_negative(int result, char *msg); | 300 | extern int chk_non_negative(int result, char *msg); |
301 | 301 | ||
302 | extern char *trim_end(const char *str, char c); | 302 | extern char *trim_end(const char *str, char c); |
303 | extern char *ensure_end(const char *str, char c); | ||
303 | extern char *strlpart(char *txt, int maxlen); | 304 | extern char *strlpart(char *txt, int maxlen); |
304 | extern char *strrpart(char *txt, int maxlen); | 305 | extern char *strrpart(char *txt, int maxlen); |
305 | 306 | ||