-
- Downloads
Fix read from uninitialized memory bug in GrpcBufferWriter.
This commit fixes an issue in which the following sequence of operations leads to use of uninitialized memory: 1. Caller invokes GrpcBufferWriter::Next(), and then makes use of 8191 bytes in the returned buffer (which is 8192 bytes in size). 2. Caller then returns the unused single byte via GrpcBufferWriter::BackUp(). This method invokes g_core_codegen_interface->grpc_slice_split_tail(), which causes backup_slice_ to be a grpc_slice with one byte. 3. At the next invocation of GrpcBufferWriter::Next(), a reference to the single byte grpc_slice is returned to the caller. The problem here is that the returned reference is to the inlined buffer in the grpc_slice, which is resident in slice_, not the location of the buffer inside slice_buffer_ after g_core_codegen_interface->grpc_slice_buffer_add() in GrpcBufferWriter::Next(). As a result, any data the caller writes to the returned void* data is lost. The solution is to avoid inlined backup slices.
Showing
- CMakeLists.txt 32 additions, 0 deletionsCMakeLists.txt
- Makefile 48 additions, 0 deletionsMakefile
- build.yaml 12 additions, 0 deletionsbuild.yaml
- include/grpc++/impl/codegen/proto_utils.h 8 additions, 1 deletioninclude/grpc++/impl/codegen/proto_utils.h
- test/cpp/codegen/codegen_test_full.cc 1 addition, 1 deletiontest/cpp/codegen/codegen_test_full.cc
- test/cpp/codegen/proto_utils_test.cc 93 additions, 0 deletionstest/cpp/codegen/proto_utils_test.cc
- tools/run_tests/generated/sources_and_headers.json 17 additions, 0 deletionstools/run_tests/generated/sources_and_headers.json
- tools/run_tests/generated/tests.json 22 additions, 0 deletionstools/run_tests/generated/tests.json
- vsprojects/vcxproj/test/proto_utils_test/proto_utils_test.vcxproj 248 additions, 0 deletions...ts/vcxproj/test/proto_utils_test/proto_utils_test.vcxproj
- vsprojects/vcxproj/test/proto_utils_test/proto_utils_test.vcxproj.filters 200 additions, 0 deletions...oj/test/proto_utils_test/proto_utils_test.vcxproj.filters
Loading
Please register or sign in to comment