summaryrefslogtreecommitdiffhomepage
path: root/contrib/lar/lar.c
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2009-04-06 17:54:55 +0000
committerJo-Philipp Wich <jow@openwrt.org>2009-04-06 17:54:55 +0000
commitbfa91018ace069edf3deb6c7e0bbe235ed6ecd3f (patch)
treed41433ff54a2eec72ff9ba5b7a14227e1bec9cdd /contrib/lar/lar.c
parent50ccdfccce792d5bd013cae9eb93588a16a7ec62 (diff)
contrib/lar: check for buffer overflows in lar_find_archive() and lar_find_member()
Diffstat (limited to 'contrib/lar/lar.c')
-rw-r--r--contrib/lar/lar.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/contrib/lar/lar.c b/contrib/lar/lar.c
index 57a16e9ff7..ad6cfc8e5d 100644
--- a/contrib/lar/lar.c
+++ b/contrib/lar/lar.c
@@ -182,7 +182,12 @@ lar_archive * lar_find_archive( const char *package )
LAR_FNAME(buffer);
for( len = 0; package[len] != '\0'; len++ )
+ {
+ if( len >= sizeof(buffer) )
+ LAR_DIE("Package name exceeds maximum allowed length");
+
if( package[len] == '.' ) seg++;
+ }
while( seg > 0 )
{
@@ -213,7 +218,12 @@ lar_member * lar_find_member( lar_archive *ar, const char *package )
LAR_FNAME(buffer);
for( len = 0; package[len] != '\0'; len++ )
+ {
+ if( len >= sizeof(buffer) )
+ LAR_DIE("Package name exceeds maximum allowed length");
+
buffer[len] = ( package[len] == '.' ) ? '/' : package[len];
+ }
buffer[len+0] = '.'; buffer[len+1] = 'l'; buffer[len+2] = 'u';
buffer[len+3] = 'a'; buffer[len+4] = '\0';