Improving Flash Memory Performance and Reliability for Smartphones With I/O Deduplication
Flash-based storage subsystem is the key component that affects the system performance, reliability, and cost efficiency of Android-based smartphones. In this paper, we first introduce a trace collection tool specifically designed to capture the I/O requests with important content features in Androi...
Gespeichert in:
Veröffentlicht in: | IEEE transactions on computer-aided design of integrated circuits and systems 2019-06, Vol.38 (6), p.1017-1027 |
---|---|
Hauptverfasser: | , , , , , |
Format: | Artikel |
Sprache: | eng |
Schlagworte: | |
Online-Zugang: | Volltext bestellen |
Tags: |
Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
|
container_end_page | 1027 |
---|---|
container_issue | 6 |
container_start_page | 1017 |
container_title | IEEE transactions on computer-aided design of integrated circuits and systems |
container_volume | 38 |
creator | Mao, Bo Zhou, Jindong Wu, Suzhen Jiang, Hong Chen, Xiao Yang, Weijian |
description | Flash-based storage subsystem is the key component that affects the system performance, reliability, and cost efficiency of Android-based smartphones. In this paper, we first introduce a trace collection tool specifically designed to capture the I/O requests with important content features in Android-based smartphones, which are critically important but rarely available in content-aware designs and optimizations, such as JProbe and Netlink. Based on the analysis of the traces collected from 15 popular mobile applications, we find that 20%-40% of the I/O requests on the I/O critical path of the storage stack are redundant and this data redundancy is minimally shared among different applications. Based on this key observation, we propose a content-aware optimization, called APP-Dedupe, that applies data deduplication on the I/O critical path to improve both performance and efficiency by reducing write amplification and improving GC efficiency of the flash storage on Android smartphones. The evaluation results show that APP-Dedupe reduces the GC overhead by an average of 41.5%, reduces the response times by up to 15.4% and reduces the amount of write data by an average of 45.2%. |
doi_str_mv | 10.1109/TCAD.2018.2834395 |
format | Article |
fullrecord | <record><control><sourceid>proquest_RIE</sourceid><recordid>TN_cdi_crossref_primary_10_1109_TCAD_2018_2834395</recordid><sourceformat>XML</sourceformat><sourcesystem>PC</sourcesystem><ieee_id>8356011</ieee_id><sourcerecordid>2227589133</sourcerecordid><originalsourceid>FETCH-LOGICAL-c336t-dd453aa83bb722c7f8a5f72dbee13cb04e676750c56bb855ffd86d73bea08bb43</originalsourceid><addsrcrecordid>eNo9kE1LAzEQhoMoWKs_QLwEPG-bj80meyyt1UKlohXxFJLdWZuyXybbQv-9W1o8zWGed4b3QeiekhGlJB2vp5PZiBGqRkzxmKfiAg1oymUUU0Ev0YAwqSJCJLlGNyFsCaGxYOkAfS-q1jd7V__geWnCBr9C1fgDfgNfNL4ydQbY1Dl-h9IZ60rXHXC_wB-V8V27aWoI-Mt1G7wYr_AM8l1busx0rqlv0VVhygB35zlEn_On9fQlWq6eF9PJMso4T7ooz2PBjVHcWslYJgtlRCFZbgEozyyJIZGJFCQTibVKiKLIVZJLbsEQZW3Mh-jxdLfv8buD0Olts_N1_1IzxqRQKeW8p-iJynwTgodCt971HQ6aEn00qI8G9dGgPhvsMw-njAOAf15xkRBK-R_p021i</addsrcrecordid><sourcetype>Aggregation Database</sourcetype><iscdi>true</iscdi><recordtype>article</recordtype><pqid>2227589133</pqid></control><display><type>article</type><title>Improving Flash Memory Performance and Reliability for Smartphones With I/O Deduplication</title><source>IEEE Electronic Library (IEL)</source><creator>Mao, Bo ; Zhou, Jindong ; Wu, Suzhen ; Jiang, Hong ; Chen, Xiao ; Yang, Weijian</creator><creatorcontrib>Mao, Bo ; Zhou, Jindong ; Wu, Suzhen ; Jiang, Hong ; Chen, Xiao ; Yang, Weijian</creatorcontrib><description>Flash-based storage subsystem is the key component that affects the system performance, reliability, and cost efficiency of Android-based smartphones. In this paper, we first introduce a trace collection tool specifically designed to capture the I/O requests with important content features in Android-based smartphones, which are critically important but rarely available in content-aware designs and optimizations, such as JProbe and Netlink. Based on the analysis of the traces collected from 15 popular mobile applications, we find that 20%-40% of the I/O requests on the I/O critical path of the storage stack are redundant and this data redundancy is minimally shared among different applications. Based on this key observation, we propose a content-aware optimization, called APP-Dedupe, that applies data deduplication on the I/O critical path to improve both performance and efficiency by reducing write amplification and improving GC efficiency of the flash storage on Android smartphones. The evaluation results show that APP-Dedupe reduces the GC overhead by an average of 41.5%, reduces the response times by up to 15.4% and reduces the amount of write data by an average of 45.2%.</description><identifier>ISSN: 0278-0070</identifier><identifier>EISSN: 1937-4151</identifier><identifier>DOI: 10.1109/TCAD.2018.2834395</identifier><identifier>CODEN: ITCSDI</identifier><language>eng</language><publisher>New York: IEEE</publisher><subject>Applications programs ; Component reliability ; Critical path ; Efficiency ; Flash memory (computers) ; Flash-based storage ; I/O deduplication ; Indexes ; Kernel ; Mobile applications ; Mobile computing ; Optimization ; Redundancy ; Smart phones ; Smartphones ; Subsystems ; trace collection</subject><ispartof>IEEE transactions on computer-aided design of integrated circuits and systems, 2019-06, Vol.38 (6), p.1017-1027</ispartof><rights>Copyright The Institute of Electrical and Electronics Engineers, Inc. (IEEE) 2019</rights><lds50>peer_reviewed</lds50><oa>free_for_read</oa><woscitedreferencessubscribed>false</woscitedreferencessubscribed><citedby>FETCH-LOGICAL-c336t-dd453aa83bb722c7f8a5f72dbee13cb04e676750c56bb855ffd86d73bea08bb43</citedby><cites>FETCH-LOGICAL-c336t-dd453aa83bb722c7f8a5f72dbee13cb04e676750c56bb855ffd86d73bea08bb43</cites><orcidid>0000-0002-4819-4583 ; 0000-0001-7656-7722 ; 0000-0002-1477-9751</orcidid></display><links><openurl>$$Topenurl_article</openurl><openurlfulltext>$$Topenurlfull_article</openurlfulltext><thumbnail>$$Tsyndetics_thumb_exl</thumbnail><linktohtml>$$Uhttps://ieeexplore.ieee.org/document/8356011$$EHTML$$P50$$Gieee$$H</linktohtml><link.rule.ids>314,780,784,796,27924,27925,54758</link.rule.ids><linktorsrc>$$Uhttps://ieeexplore.ieee.org/document/8356011$$EView_record_in_IEEE$$FView_record_in_$$GIEEE</linktorsrc></links><search><creatorcontrib>Mao, Bo</creatorcontrib><creatorcontrib>Zhou, Jindong</creatorcontrib><creatorcontrib>Wu, Suzhen</creatorcontrib><creatorcontrib>Jiang, Hong</creatorcontrib><creatorcontrib>Chen, Xiao</creatorcontrib><creatorcontrib>Yang, Weijian</creatorcontrib><title>Improving Flash Memory Performance and Reliability for Smartphones With I/O Deduplication</title><title>IEEE transactions on computer-aided design of integrated circuits and systems</title><addtitle>TCAD</addtitle><description>Flash-based storage subsystem is the key component that affects the system performance, reliability, and cost efficiency of Android-based smartphones. In this paper, we first introduce a trace collection tool specifically designed to capture the I/O requests with important content features in Android-based smartphones, which are critically important but rarely available in content-aware designs and optimizations, such as JProbe and Netlink. Based on the analysis of the traces collected from 15 popular mobile applications, we find that 20%-40% of the I/O requests on the I/O critical path of the storage stack are redundant and this data redundancy is minimally shared among different applications. Based on this key observation, we propose a content-aware optimization, called APP-Dedupe, that applies data deduplication on the I/O critical path to improve both performance and efficiency by reducing write amplification and improving GC efficiency of the flash storage on Android smartphones. The evaluation results show that APP-Dedupe reduces the GC overhead by an average of 41.5%, reduces the response times by up to 15.4% and reduces the amount of write data by an average of 45.2%.</description><subject>Applications programs</subject><subject>Component reliability</subject><subject>Critical path</subject><subject>Efficiency</subject><subject>Flash memory (computers)</subject><subject>Flash-based storage</subject><subject>I/O deduplication</subject><subject>Indexes</subject><subject>Kernel</subject><subject>Mobile applications</subject><subject>Mobile computing</subject><subject>Optimization</subject><subject>Redundancy</subject><subject>Smart phones</subject><subject>Smartphones</subject><subject>Subsystems</subject><subject>trace collection</subject><issn>0278-0070</issn><issn>1937-4151</issn><fulltext>true</fulltext><rsrctype>article</rsrctype><creationdate>2019</creationdate><recordtype>article</recordtype><sourceid>RIE</sourceid><recordid>eNo9kE1LAzEQhoMoWKs_QLwEPG-bj80meyyt1UKlohXxFJLdWZuyXybbQv-9W1o8zWGed4b3QeiekhGlJB2vp5PZiBGqRkzxmKfiAg1oymUUU0Ev0YAwqSJCJLlGNyFsCaGxYOkAfS-q1jd7V__geWnCBr9C1fgDfgNfNL4ydQbY1Dl-h9IZ60rXHXC_wB-V8V27aWoI-Mt1G7wYr_AM8l1busx0rqlv0VVhygB35zlEn_On9fQlWq6eF9PJMso4T7ooz2PBjVHcWslYJgtlRCFZbgEozyyJIZGJFCQTibVKiKLIVZJLbsEQZW3Mh-jxdLfv8buD0Olts_N1_1IzxqRQKeW8p-iJynwTgodCt971HQ6aEn00qI8G9dGgPhvsMw-njAOAf15xkRBK-R_p021i</recordid><startdate>20190601</startdate><enddate>20190601</enddate><creator>Mao, Bo</creator><creator>Zhou, Jindong</creator><creator>Wu, Suzhen</creator><creator>Jiang, Hong</creator><creator>Chen, Xiao</creator><creator>Yang, Weijian</creator><general>IEEE</general><general>The Institute of Electrical and Electronics Engineers, Inc. (IEEE)</general><scope>97E</scope><scope>RIA</scope><scope>RIE</scope><scope>AAYXX</scope><scope>CITATION</scope><scope>7SC</scope><scope>7SP</scope><scope>8FD</scope><scope>JQ2</scope><scope>L7M</scope><scope>L~C</scope><scope>L~D</scope><orcidid>https://orcid.org/0000-0002-4819-4583</orcidid><orcidid>https://orcid.org/0000-0001-7656-7722</orcidid><orcidid>https://orcid.org/0000-0002-1477-9751</orcidid></search><sort><creationdate>20190601</creationdate><title>Improving Flash Memory Performance and Reliability for Smartphones With I/O Deduplication</title><author>Mao, Bo ; Zhou, Jindong ; Wu, Suzhen ; Jiang, Hong ; Chen, Xiao ; Yang, Weijian</author></sort><facets><frbrtype>5</frbrtype><frbrgroupid>cdi_FETCH-LOGICAL-c336t-dd453aa83bb722c7f8a5f72dbee13cb04e676750c56bb855ffd86d73bea08bb43</frbrgroupid><rsrctype>articles</rsrctype><prefilter>articles</prefilter><language>eng</language><creationdate>2019</creationdate><topic>Applications programs</topic><topic>Component reliability</topic><topic>Critical path</topic><topic>Efficiency</topic><topic>Flash memory (computers)</topic><topic>Flash-based storage</topic><topic>I/O deduplication</topic><topic>Indexes</topic><topic>Kernel</topic><topic>Mobile applications</topic><topic>Mobile computing</topic><topic>Optimization</topic><topic>Redundancy</topic><topic>Smart phones</topic><topic>Smartphones</topic><topic>Subsystems</topic><topic>trace collection</topic><toplevel>peer_reviewed</toplevel><toplevel>online_resources</toplevel><creatorcontrib>Mao, Bo</creatorcontrib><creatorcontrib>Zhou, Jindong</creatorcontrib><creatorcontrib>Wu, Suzhen</creatorcontrib><creatorcontrib>Jiang, Hong</creatorcontrib><creatorcontrib>Chen, Xiao</creatorcontrib><creatorcontrib>Yang, Weijian</creatorcontrib><collection>IEEE All-Society Periodicals Package (ASPP) 2005-present</collection><collection>IEEE All-Society Periodicals Package (ASPP) 1998-Present</collection><collection>IEEE Electronic Library (IEL)</collection><collection>CrossRef</collection><collection>Computer and Information Systems Abstracts</collection><collection>Electronics & Communications Abstracts</collection><collection>Technology Research Database</collection><collection>ProQuest Computer Science Collection</collection><collection>Advanced Technologies Database with Aerospace</collection><collection>Computer and Information Systems Abstracts Academic</collection><collection>Computer and Information Systems Abstracts Professional</collection><jtitle>IEEE transactions on computer-aided design of integrated circuits and systems</jtitle></facets><delivery><delcategory>Remote Search Resource</delcategory><fulltext>fulltext_linktorsrc</fulltext></delivery><addata><au>Mao, Bo</au><au>Zhou, Jindong</au><au>Wu, Suzhen</au><au>Jiang, Hong</au><au>Chen, Xiao</au><au>Yang, Weijian</au><format>journal</format><genre>article</genre><ristype>JOUR</ristype><atitle>Improving Flash Memory Performance and Reliability for Smartphones With I/O Deduplication</atitle><jtitle>IEEE transactions on computer-aided design of integrated circuits and systems</jtitle><stitle>TCAD</stitle><date>2019-06-01</date><risdate>2019</risdate><volume>38</volume><issue>6</issue><spage>1017</spage><epage>1027</epage><pages>1017-1027</pages><issn>0278-0070</issn><eissn>1937-4151</eissn><coden>ITCSDI</coden><abstract>Flash-based storage subsystem is the key component that affects the system performance, reliability, and cost efficiency of Android-based smartphones. In this paper, we first introduce a trace collection tool specifically designed to capture the I/O requests with important content features in Android-based smartphones, which are critically important but rarely available in content-aware designs and optimizations, such as JProbe and Netlink. Based on the analysis of the traces collected from 15 popular mobile applications, we find that 20%-40% of the I/O requests on the I/O critical path of the storage stack are redundant and this data redundancy is minimally shared among different applications. Based on this key observation, we propose a content-aware optimization, called APP-Dedupe, that applies data deduplication on the I/O critical path to improve both performance and efficiency by reducing write amplification and improving GC efficiency of the flash storage on Android smartphones. The evaluation results show that APP-Dedupe reduces the GC overhead by an average of 41.5%, reduces the response times by up to 15.4% and reduces the amount of write data by an average of 45.2%.</abstract><cop>New York</cop><pub>IEEE</pub><doi>10.1109/TCAD.2018.2834395</doi><tpages>11</tpages><orcidid>https://orcid.org/0000-0002-4819-4583</orcidid><orcidid>https://orcid.org/0000-0001-7656-7722</orcidid><orcidid>https://orcid.org/0000-0002-1477-9751</orcidid><oa>free_for_read</oa></addata></record> |
fulltext | fulltext_linktorsrc |
identifier | ISSN: 0278-0070 |
ispartof | IEEE transactions on computer-aided design of integrated circuits and systems, 2019-06, Vol.38 (6), p.1017-1027 |
issn | 0278-0070 1937-4151 |
language | eng |
recordid | cdi_crossref_primary_10_1109_TCAD_2018_2834395 |
source | IEEE Electronic Library (IEL) |
subjects | Applications programs Component reliability Critical path Efficiency Flash memory (computers) Flash-based storage I/O deduplication Indexes Kernel Mobile applications Mobile computing Optimization Redundancy Smart phones Smartphones Subsystems trace collection |
title | Improving Flash Memory Performance and Reliability for Smartphones With I/O Deduplication |
url | https://sfx.bib-bvb.de/sfx_tum?ctx_ver=Z39.88-2004&ctx_enc=info:ofi/enc:UTF-8&ctx_tim=2025-01-02T23%3A52%3A38IST&url_ver=Z39.88-2004&url_ctx_fmt=infofi/fmt:kev:mtx:ctx&rfr_id=info:sid/primo.exlibrisgroup.com:primo3-Article-proquest_RIE&rft_val_fmt=info:ofi/fmt:kev:mtx:journal&rft.genre=article&rft.atitle=Improving%20Flash%20Memory%20Performance%20and%20Reliability%20for%20Smartphones%20With%20I/O%20Deduplication&rft.jtitle=IEEE%20transactions%20on%20computer-aided%20design%20of%20integrated%20circuits%20and%20systems&rft.au=Mao,%20Bo&rft.date=2019-06-01&rft.volume=38&rft.issue=6&rft.spage=1017&rft.epage=1027&rft.pages=1017-1027&rft.issn=0278-0070&rft.eissn=1937-4151&rft.coden=ITCSDI&rft_id=info:doi/10.1109/TCAD.2018.2834395&rft_dat=%3Cproquest_RIE%3E2227589133%3C/proquest_RIE%3E%3Curl%3E%3C/url%3E&disable_directlink=true&sfx.directlink=off&sfx.report_link=0&rft_id=info:oai/&rft_pqid=2227589133&rft_id=info:pmid/&rft_ieee_id=8356011&rfr_iscdi=true |