diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-02-27 13:36:50 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-02-27 13:36:50 -0500 |
| commit | bb7d43b149ef88cd0d3cb38bb49ebb69a460b42b (patch) | |
| tree | b14dd606cb5059f5b703c54d3868516d279d22f2 /drivers/mtd | |
| parent | d2a0476307e67a6e6a293563a4f4ad4ec79ac0e5 (diff) | |
| parent | 5547fec74a566e1f5e00a937b9a367f7c6a94a8b (diff) | |
Merge tag 'upstream-3.14-rc5' of git://git.infradead.org/linux-ubifs
Pull ubifs fix from Artem Bityutskiy:
"Just a single fix for the UBI module unload path which makes sure we
do not touch freed memory"
* tag 'upstream-3.14-rc5' of git://git.infradead.org/linux-ubifs:
UBI: fix some use after free bugs
Diffstat (limited to 'drivers/mtd')
| -rw-r--r-- | drivers/mtd/ubi/fastmap.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/drivers/mtd/ubi/fastmap.c b/drivers/mtd/ubi/fastmap.c index ead861307b3c..c5dad652614d 100644 --- a/drivers/mtd/ubi/fastmap.c +++ b/drivers/mtd/ubi/fastmap.c | |||
| @@ -463,8 +463,8 @@ static int scan_pool(struct ubi_device *ubi, struct ubi_attach_info *ai, | |||
| 463 | } | 463 | } |
| 464 | } | 464 | } |
| 465 | if (found_orphan) { | 465 | if (found_orphan) { |
| 466 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 467 | list_del(&tmp_aeb->u.list); | 466 | list_del(&tmp_aeb->u.list); |
| 467 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 468 | } | 468 | } |
| 469 | 469 | ||
| 470 | new_aeb = kmem_cache_alloc(ai->aeb_slab_cache, | 470 | new_aeb = kmem_cache_alloc(ai->aeb_slab_cache, |
| @@ -846,16 +846,16 @@ fail_bad: | |||
| 846 | ret = UBI_BAD_FASTMAP; | 846 | ret = UBI_BAD_FASTMAP; |
| 847 | fail: | 847 | fail: |
| 848 | list_for_each_entry_safe(tmp_aeb, _tmp_aeb, &used, u.list) { | 848 | list_for_each_entry_safe(tmp_aeb, _tmp_aeb, &used, u.list) { |
| 849 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 850 | list_del(&tmp_aeb->u.list); | 849 | list_del(&tmp_aeb->u.list); |
| 850 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 851 | } | 851 | } |
| 852 | list_for_each_entry_safe(tmp_aeb, _tmp_aeb, &eba_orphans, u.list) { | 852 | list_for_each_entry_safe(tmp_aeb, _tmp_aeb, &eba_orphans, u.list) { |
| 853 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 854 | list_del(&tmp_aeb->u.list); | 853 | list_del(&tmp_aeb->u.list); |
| 854 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 855 | } | 855 | } |
| 856 | list_for_each_entry_safe(tmp_aeb, _tmp_aeb, &free, u.list) { | 856 | list_for_each_entry_safe(tmp_aeb, _tmp_aeb, &free, u.list) { |
| 857 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 858 | list_del(&tmp_aeb->u.list); | 857 | list_del(&tmp_aeb->u.list); |
| 858 | kmem_cache_free(ai->aeb_slab_cache, tmp_aeb); | ||
| 859 | } | 859 | } |
| 860 | 860 | ||
| 861 | return ret; | 861 | return ret; |
