30.10.2012 Views

Advanced Wear Leveling

Advanced Wear Leveling

Advanced Wear Leveling

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

<strong>Advanced</strong> <strong>Wear</strong> <strong>Leveling</strong><br />

HW Development Dept.<br />

14 May 2009


<strong>Advanced</strong> wear leveling<br />

A technique applied to extend the service life of<br />

SSD. The program/erase cycle of each block in<br />

the wear leveling group will be evenly distributed.<br />

Dynamic data and Static data are both used in<br />

the wear leveling process<br />

This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

2


Ex.<br />

Flash block management<br />

User block、System block、Spare block<br />

Flash total blocks (per chip or group)<br />

User block = Logical capacity<br />

User block Spare block<br />

Spare block = Free block and bad block pool for wear leveling<br />

System block = mapping table, record block ..etc<br />

= 1024 Blocks<br />

This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

System<br />

block<br />

977 Blocks 38 Blocks 9 Blocks<br />

3.7% 0.8%<br />

Device capacity = 977 x 128 x 1024 = 128,057,344 Bytes<br />

3


Logic<br />

Address<br />

Sector<br />

Physical<br />

Address<br />

Block<br />

Host write<br />

Logical<br />

sector 0~8<br />

<strong>Wear</strong>-leveling simple algorithm<br />

0~255 256~511<br />

… … …<br />

002 005 024 211<br />

Move sectors 9~255<br />

522<br />

… Mapping Table Block<br />

522<br />

… 221<br />

Partial data empty data full data Spare block<br />

Update Logical<br />

to Physical<br />

Mapping table<br />

4


Logic<br />

Address<br />

Sector<br />

Physical<br />

Address<br />

Block<br />

Host write<br />

sector 0~8<br />

<strong>Wear</strong>-leveling simple algorithm<br />

0~255 256~511<br />

… … …<br />

002 005 024 211<br />

Move sector 9~255<br />

522<br />

… Mapping Table Block<br />

002<br />

… 221<br />

Partial data empty data full data Spare block<br />

5


Dynamic wear wear leveling<br />

Host write data<br />

<strong>Wear</strong> leveling<br />

Static<br />

Data<br />

Dynamic<br />

Data<br />

Free<br />

Block<br />

This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

Erase Counts<br />

High<br />

Low<br />

6


<strong>Advanced</strong> wear leveling<br />

<strong>Advanced</strong> wear wear leveling (Dynamic + Static) Static)<br />

Host write data<br />

Static<br />

Data<br />

Dynamic<br />

Data<br />

Free<br />

Block<br />

This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

Erase Counts<br />

High<br />

Low<br />

7


Age Sum<br />

2500000<br />

2000000<br />

1500000<br />

1000000<br />

500000<br />

0<br />

<strong>Advanced</strong> wear leveling<br />

Test 1GB; After 500K cycle on the first 1MB<br />

Round (Cycle) Min. Block P/E Max. Block P/E Avg. Block P/E Total P/E (Sum.)<br />

100K 256 512 403 404,682<br />

200K 768 1024 806 809,343<br />

300K 1024 1280 1210 1,214,033<br />

400K 1536 1792 1613 1,618,690<br />

500K 1792 2948 2017 2,023,378<br />

0 100000 200000 300000 400000 500000 600000<br />

Round Number<br />

This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

8


<strong>Advanced</strong> wear leveling<br />

Test 1GB; After 500K cycle on the first 1MB<br />

Age<br />

2500<br />

2000<br />

1500<br />

1000<br />

500<br />

0<br />

Min Max Avg<br />

0 100000 200000 300000 400000 500000 600000<br />

Round Number<br />

This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

9


<strong>Advanced</strong> wear leveling test<br />

Round (Cycle) Min. Block<br />

P/E<br />

Age<br />

Age<br />

Max. Block<br />

P/E<br />

Avg. Block<br />

P/E<br />

Max. Diff.<br />

Range<br />

Total P/E (Sum.)<br />

10K 1027 1283 1250 256 1,262,600<br />

20K 2306 2562 2503 256 2,528,964<br />

50K 6144 6400 6254 256 6,316,793<br />

7000<br />

7000<br />

6000<br />

6000<br />

5000<br />

5000<br />

4000<br />

4000<br />

3000<br />

3000<br />

2000<br />

2000<br />

1000<br />

1000<br />

0<br />

0<br />

0 128 256 384 512 640 768 896 1024<br />

0 128 256 384 512 640 768 896 1024<br />

This document and its contents Blocks are confidential © Copyright Apacer Technology Inc.<br />

Blocks<br />

10K cycle Age<br />

10K cycle Age<br />

20K cycle Age<br />

20K cycle Age<br />

50K cycle Age<br />

50K cycle Age<br />

10


Age<br />

<strong>Advanced</strong> vs. Dynamic wear leveling<br />

12000<br />

10000<br />

8000<br />

6000<br />

4000<br />

2000<br />

Burn-in 10K cycle – 10% dynamic data , 90% static data<br />

Dynamic wear leveling<br />

0<br />

0 128 256 384 512 640 768 896 1024<br />

Blocks<br />

12000<br />

10000<br />

8000<br />

6000<br />

4000<br />

2000<br />

This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

Age<br />

0<br />

<strong>Advanced</strong> wear leveling<br />

0 128 256 384 512 640 768 896 1024<br />

Blocks<br />

11


This document and its contents are confidential © Copyright Apacer Technology Inc.<br />

12

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!