server: Add the name length to the object_attributes structure so that other variable length data can be present after object_attributes.
diff --git a/server/trace.c b/server/trace.c
index 30d6efd..0f0e17d 100644
--- a/server/trace.c
+++ b/server/trace.c
@@ -790,14 +790,16 @@
{
const WCHAR *str;
fprintf( stderr, "rootdir=%p,sd=", objattr->rootdir );
- if (objattr->sd_len > size - sizeof(*objattr)) return;
+ if (objattr->sd_len > size - sizeof(*objattr) ||
+ objattr->name_len > size - sizeof(*objattr) - objattr->sd_len)
+ return;
dump_inline_security_descriptor( (const struct security_descriptor *)(objattr + 1), objattr->sd_len );
- str = (const WCHAR *)cur_data + (sizeof(*objattr) + objattr->sd_len) / sizeof(WCHAR);
+ str = (const WCHAR *)objattr + (sizeof(*objattr) + objattr->sd_len) / sizeof(WCHAR);
fprintf( stderr, ",name=L\"" );
- dump_strW( str, (size - sizeof(*objattr) - objattr->sd_len) / sizeof(WCHAR),
- stderr, "\"\"" );
+ dump_strW( str, objattr->name_len / sizeof(WCHAR), stderr, "\"\"" );
fputc( '\"', stderr );
- remove_data( size );
+ remove_data( ((sizeof(*objattr) + objattr->sd_len) / sizeof(WCHAR)) * sizeof(WCHAR) +
+ objattr->name_len );
}
fputc( '}', stderr );
}