diff options
author | Cheney Ni <cheneyni@google.com> | 2018-08-07 21:32:07 +0800 |
---|---|---|
committer | Tim Schumacher <timschumi@gmx.de> | 2018-11-18 07:45:39 +0000 |
commit | aa1c0edaabb7d7f33177dc2de1877eaa30478ec2 (patch) | |
tree | f02d3b415c3e9efddf664f6770d69c11af0aa195 | |
parent | dab3cc747a5b073b4eac6a73719b97fe217afb5f (diff) | |
download | android_system_bt-aa1c0edaabb7d7f33177dc2de1877eaa30478ec2.tar.gz android_system_bt-aa1c0edaabb7d7f33177dc2de1877eaa30478ec2.tar.bz2 android_system_bt-aa1c0edaabb7d7f33177dc2de1877eaa30478ec2.zip |
Add packet length checks in mca_ccb_hdl_req
Bug: 110791536
Test: manual
Change-Id: Ica5d8037246682fdb190b2747a86ed8d44c2869a
(cherry picked from commit 4de7ccdd914b7a178df9180d15f675b257ea6e02)
-rw-r--r-- | stack/mcap/mca_cact.c | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/stack/mcap/mca_cact.c b/stack/mcap/mca_cact.c index 8ac75bf21..6be5b4f4b 100644 --- a/stack/mcap/mca_cact.c +++ b/stack/mcap/mca_cact.c @@ -22,6 +22,7 @@ * Functions. * ******************************************************************************/ +#include <log/log.h> #include <string.h> #include "bt_target.h" #include "bt_utils.h" @@ -276,9 +277,18 @@ void mca_ccb_hdl_req(tMCA_CCB *p_ccb, tMCA_CCB_EVT *p_data) p_rx_msg = (tMCA_CCB_MSG *)p_pkt; p = (UINT8 *)(p_pkt + 1) + p_pkt->offset; evt_data.hdr.op_code = *p++; - BE_STREAM_TO_UINT16 (evt_data.hdr.mdl_id, p); reject_opcode = evt_data.hdr.op_code+1; + if (p_pkt->len >= 3) + { + BE_STREAM_TO_UINT16(evt_data.hdr.mdl_id, p); + } + else + { + android_errorWriteLog(0x534e4554, "110791536"); + evt_data.hdr.mdl_id = 0; + } + MCA_TRACE_DEBUG ("received mdl id: %d ", evt_data.hdr.mdl_id); if (p_ccb->status == MCA_CCB_STAT_PENDING) { |