NOR: trim range in flash_driver_protect()
authorDavid Brownell <dbrownell@users.sourceforge.net>
Thu, 4 Mar 2010 05:01:16 +0000 (21:01 -0800)
committerDavid Brownell <dbrownell@users.sourceforge.net>
Thu, 4 Mar 2010 05:01:16 +0000 (21:01 -0800)
When the beginning or end of the specified range of sectors
already has the requested protection status, don't ask the
flash driver to change those sectors.

This will among other things turn command sequences like
this into the NOPs one would expect:

flash protect_check 0
flash info 0
... reports everything as unprotected ...
flash protect 0 0 1 off

That speeds things up (by whatever work was just avoided).

Also, with Stellaris (which can't unprotect flash at  page level)
this can eliminate some undesirable/false error reports.  (And
finishes fixing a bug currently listed in our bug database...)

Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
src/flash/nor/core.c

index fc020a8a815c5ed4bc585ff098573197498197cc..767006d27e10003190b7cf4b1a4df20661c76126 100644 (file)
@@ -54,6 +54,63 @@ int flash_driver_erase(struct flash_bank *bank, int first, int last)
 int flash_driver_protect(struct flash_bank *bank, int set, int first, int last)
 {
        int retval;
+       bool updated = false;
+
+       /* NOTE: "first == last" means protect just that sector */
+
+       /* callers may not supply illegal parameters ... */
+       if (first < 0 || first > last || last >= bank->num_sectors)
+               return ERROR_FAIL;
+
+       /* force "set" to 0/1 */
+       set = !!set;
+
+       /*
+        * Filter out what trivial nonsense we can, so drivers don't have to.
+        *
+        * Don't tell drivers to change to the current state...  it's needless,
+        * and reducing the amount of work to be done (potentially to nothing)
+        * speeds at least some things up.
+        */
+scan:
+       for (int i = first; i < last; i++) {
+               struct flash_sector *sector = bank->sectors + i;
+
+               /* Only filter requests to protect the already-protected, or
+                * to unprotect the already-unprotected.  Changing from the
+                * unknown state (-1) to a known one is unwise but allowed;
+                * protection status is best checked first.
+                */
+               if (sector->is_protected != set)
+                       continue;
+
+               /* Shrink this range of sectors from the start; don't overrun
+                * the end.  Also shrink from the end; don't overun the start.
+                *
+                * REVISIT we could handle discontiguous regions by issuing
+                * more than one driver request.  How much would that matter?
+                */
+               if (i == first) {
+                       updated = true;
+                       first++;
+               } else if (i == last) {
+                       updated = true;
+                       last--;
+               }
+       }
+
+       /* updating the range affects the tests in the scan loop above; so
+        * re-scan, to make sure we didn't miss anything.
+        */
+       if (updated) {
+               updated = false;
+               goto scan;
+       }
+
+       /* Single sector, already protected?  Nothing to do! */
+       if (first == last)
+               return ERROR_OK;
+
 
        retval = bank->driver->protect(bank, set, first, last);
        if (retval != ERROR_OK)

Linking to existing account procedure

If you already have an account and want to add another login method you MUST first sign in with your existing account and then change URL to read https://review.openocd.org/login/?link to get to this page again but this time it'll work for linking. Thank you.

SSH host keys fingerprints

1024 SHA256:YKx8b7u5ZWdcbp7/4AeXNaqElP49m6QrwfXaqQGJAOk gerrit-code-review@openocd.zylin.com (DSA)
384 SHA256:jHIbSQa4REvwCFG4cq5LBlBLxmxSqelQPem/EXIrxjk gerrit-code-review@openocd.org (ECDSA)
521 SHA256:UAOPYkU9Fjtcao0Ul/Rrlnj/OsQvt+pgdYSZ4jOYdgs gerrit-code-review@openocd.org (ECDSA)
256 SHA256:A13M5QlnozFOvTllybRZH6vm7iSt0XLxbA48yfc2yfY gerrit-code-review@openocd.org (ECDSA)
256 SHA256:spYMBqEYoAOtK7yZBrcwE8ZpYt6b68Cfh9yEVetvbXg gerrit-code-review@openocd.org (ED25519)
+--[ED25519 256]--+
|=..              |
|+o..   .         |
|*.o   . .        |
|+B . . .         |
|Bo. = o S        |
|Oo.+ + =         |
|oB=.* = . o      |
| =+=.+   + E     |
|. .=o   . o      |
+----[SHA256]-----+
2048 SHA256:0Onrb7/PHjpo6iVZ7xQX2riKN83FJ3KGU0TvI0TaFG4 gerrit-code-review@openocd.zylin.com (RSA)