[AccessD] Smokin deal on SSD

John W Colby jwcolby at gmail.com
Thu Mar 13 12:39:56 CDT 2014


The controller is doing a completely behind the scenes movement of blocks of data.  From what I have 
read it does so when there is nothing else going on.  Basically the controller looks for high wear 
level blocks which still function but need to stop being written to.  IOW, blocks that have been 
written to many times.  It then grabs a block of data from a low wear level AND apparently static - 
not written very often or for a long time - and moves that block to the high wear level block.  The 
idea is that if a block isn't updated often then it can go in an area that has already been written 
a lot (but still functions) and so drop the future writes to that high use block.

The SSD apparently keeps dynamic counts of the number of times a block of NAND has been written.  So 
you write a spreadsheet to SSD for example.  It sits there for a year, looked at but never written / 
updated.  The NAND storage location that it sits in has a use count of 1.  You have another location 
which is a small MDB.  You are writing to that daily.  Literally (from the PC's perspective) the 
same area of the "disk" is read / updated / updated / updated.  So that NAND storage location may 
get an update count of 1000 in a month.  Keep in mind that NAND blocks are somewhat small, 64K perhaps.

At any rate, the SSD controller is watching the number of times every NAND block is written to.  It 
then sees that one block has a count of 1 and another has a count of 1000.  So behind the scenes, it 
swaps those two blocks.  The spreadsheet now sits in a block written 1000 times and the database 
sits in a block that has been written once.  Since the spreadsheet is never written it doesn't 
matter that it sits in a high wear location.  The MDB however gets an unused block or NAND.  This is 
called "wear leveling".  All SSDs do this.

All behind the scenes, and all done in controller logic inside of the SSD.  The PC / OS never knows 
it is occurring.

John W. Colby

Reality is what refuses to go away
when you do not believe in it

On 3/13/2014 1:05 PM, Bill Benson wrote:
> See what you've started, now gonna get flamed cuz this is so none
> programming and for sure non-DB.
>
>> Colby" <jwcolby at gmail.com> wrote:
>> the controller itself will move that static data around to allow other
> dynamic data to "use" the areas not yet written...
>
> So is controller performing a
>
> Read(old position info, old data)/re-write(old data, new position
> info)/write (new data and new position info)
> ?
>
> Versus
>
> a read (position info)/write (data and position info)
>
> Isn't that an efficiency give-back?
>
> Do spin up drives do this too?
>
> I wonder how fast SSDS would be if they did not do this or were hardened to
> handle more writes.
>
> I also don't tend to do a lot of writes to HD, unlike storage drive. Now I
> am worried about the longevity of my NAS.
>
> I realize it is "not so simple" but how the heck, with all a PC has going
> on, can it be practical to optimize something like this? And to get it
> right (er, write?) In terms of how many disk atoms have been written to an
> "even" number of times.
>
> I've read about drives ad nauseum but I am neither a mechanical not an
> electrical engineer nor nanotechnology savvy. The stuff doesn't come to me
> readily and state of the art doesn't stay still, for long enough... and
> lack of uptake capability (gray matter).
>
> So I may not be worth your time replying -- and if you don't, I guess we
> both know why.


---
This email is free from viruses and malware because avast! Antivirus protection is active.
http://www.avast.com



More information about the AccessD mailing list