diff options
author | songjinshi <songjinshi@xiaomi.com> | 2016-09-08 15:24:30 +0800 |
---|---|---|
committer | Adam Lesinski <adamlesinski@google.com> | 2016-10-03 20:13:12 +0000 |
commit | 5754b41c201a388e4e932b18d285d765d7e63536 (patch) | |
tree | 4ed936836cbad3be2bf58e65e3b6c71b380ea173 /tools/aapt2/java/JavaClassGenerator.cpp | |
parent | bf79852ae4ffdeee8c31d6b852ebc4ad8062de37 (diff) |
Fix thread race caused double free issue.
The SharedZip's Asset is not thread-safety,the getResourceTableAsset()
and setResourceTableAsset(Asset* asset) function of the SharedZip is
not sync with a same lock.
Consider the following sequence of events:
Thread A calls setResourceTableAsset(Asset* asset),it will set
mResourceTableAsset = asset; then to calls getBuffer() of the asset.
Thread B calls getResourceTableAsset(),which return mResourceTableAsset,
then to calls getBuffer() of the mResourceTableAsset,the asset and
mResourceTableAsset is same one object.
Thread A to delete mZipInflater in getBuffer().
Thread B to delete mZipInflater in getBuffer().
It will cause crash becuase double delete mZipInflater in getBuffer().
https://code.google.com/p/android/issues/detail?id=211941
Bug:31734545
Change-Id: I5a7d67fdf64c4aa03f505b37a2fa840f4443d158
Signed-off-by: songjinshi <songjinshi@xiaomi.com>
Diffstat (limited to 'tools/aapt2/java/JavaClassGenerator.cpp')
0 files changed, 0 insertions, 0 deletions