rtt: fix corner-cases of finding control block
[openocd.git] / src / target / rtt.c
index ef2c45d69588327cf881ecced0cc8e6e486fe9f9..b14c42f9196ebc302cab2ce36003f9147031b29e 100644 (file)
@@ -241,43 +241,37 @@ int target_rtt_find_control_block(struct target *target,
                target_addr_t *address, size_t size, const char *id, bool *found,
                void *user_data)
 {
+       target_addr_t address_end = *address + size;
        uint8_t buf[1024];
 
        *found = false;
 
-       size_t j = 0;
-       size_t cb_offset = 0;
+       size_t id_matched_length = 0;
        const size_t id_length = strlen(id);
 
        LOG_INFO("rtt: Searching for control block '%s'", id);
 
-       for (target_addr_t addr = 0; addr < size; addr = addr + sizeof(buf)) {
+       for (target_addr_t addr = *address; addr < address_end; addr += sizeof(buf)) {
                int ret;
 
-               const size_t buf_size = MIN(sizeof(buf), size - addr);
-               ret = target_read_buffer(target, *address + addr, buf_size, buf);
+               const size_t buf_size = MIN(sizeof(buf), address_end - addr);
+               ret = target_read_buffer(target, addr, buf_size, buf);
 
                if (ret != ERROR_OK)
                        return ret;
 
-               size_t start = 0;
-               size_t i = 0;
-
-               while (i < buf_size) {
-                       if (buf[i] != id[j]) {
-                               start++;
-                               cb_offset++;
-                               i = start;
-                               j = 0;
-
-                               continue;
+               for (size_t buf_off = 0; buf_off < buf_size; buf_off++) {
+                       if (id_matched_length > 0 &&
+                           buf[buf_off] != id[id_matched_length]) {
+                               /* Start from beginning */
+                               id_matched_length = 0;
                        }
 
-                       i++;
-                       j++;
+                       if (buf[buf_off] == id[id_matched_length])
+                               id_matched_length++;
 
-                       if (j == id_length) {
-                               *address = *address + cb_offset;
+                       if (id_matched_length == id_length) {
+                               *address = addr + buf_off + 1 - id_length;
                                *found = true;
                                return 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)