* commit 'ca609e4300d88ad1e815581ebc6a478b446d3882': Check the padded size of the read byte array
This commit is contained in:
commit
75d8406934
@ -943,7 +943,8 @@ void Parcel::remove(size_t /*start*/, size_t /*amt*/)
|
|||||||
|
|
||||||
status_t Parcel::read(void* outData, size_t len) const
|
status_t Parcel::read(void* outData, size_t len) const
|
||||||
{
|
{
|
||||||
if ((mDataPos+PAD_SIZE(len)) >= mDataPos && (mDataPos+PAD_SIZE(len)) <= mDataSize) {
|
if ((mDataPos+PAD_SIZE(len)) >= mDataPos && (mDataPos+PAD_SIZE(len)) <= mDataSize
|
||||||
|
&& len <= PAD_SIZE(len)) {
|
||||||
memcpy(outData, mData+mDataPos, len);
|
memcpy(outData, mData+mDataPos, len);
|
||||||
mDataPos += PAD_SIZE(len);
|
mDataPos += PAD_SIZE(len);
|
||||||
ALOGV("read Setting data pos of %p to %d\n", this, mDataPos);
|
ALOGV("read Setting data pos of %p to %d\n", this, mDataPos);
|
||||||
@ -954,7 +955,8 @@ status_t Parcel::read(void* outData, size_t len) const
|
|||||||
|
|
||||||
const void* Parcel::readInplace(size_t len) const
|
const void* Parcel::readInplace(size_t len) const
|
||||||
{
|
{
|
||||||
if ((mDataPos+PAD_SIZE(len)) >= mDataPos && (mDataPos+PAD_SIZE(len)) <= mDataSize) {
|
if ((mDataPos+PAD_SIZE(len)) >= mDataPos && (mDataPos+PAD_SIZE(len)) <= mDataSize
|
||||||
|
&& len <= PAD_SIZE(len)) {
|
||||||
const void* data = mData+mDataPos;
|
const void* data = mData+mDataPos;
|
||||||
mDataPos += PAD_SIZE(len);
|
mDataPos += PAD_SIZE(len);
|
||||||
ALOGV("readInplace Setting data pos of %p to %d\n", this, mDataPos);
|
ALOGV("readInplace Setting data pos of %p to %d\n", this, mDataPos);
|
||||||
|
Loading…
Reference in New Issue
Block a user