]> git.djapps.eu Git - pkg/ggml/sources/llama.cpp/commitdiff
train : fix #4227 (double free in examples/train-text-from-scratch/train-text-from...
authorHongyu Ouyang <redacted>
Thu, 7 Dec 2023 10:25:22 +0000 (02:25 -0800)
committerGitHub <redacted>
Thu, 7 Dec 2023 10:25:22 +0000 (12:25 +0200)
On commit b1108 (44c117f4) xaedes added

    ggml_allocr * alloc = NULL;

    ... (many lines in between)

    if (alloc) {
        ggml_allocr_free(alloc);
    }

Which is correct, but it's easy to lose context after many lines in between.

On commit b1287 (0e76a899) xaedes made a big change. From here on, alloc is freed eagerly.

    alloc = ggml_allocr_new(...)
    ... (short lines of code)
    ggml_allocr_free(alloc)

This happens a few times, but alloc is never set to NULL, and many lines below,
we still have

    if (alloc) {
        ggml_allocr_free(alloc);
    }

which causes a double-free.

examples/train-text-from-scratch/train-text-from-scratch.cpp

index f049a3923669b16ca17b675025340220a3d987d1..f7ed63365211b4f8a3eb14811d07a98ca595996d 100644 (file)
@@ -1295,10 +1295,6 @@ int main(int argc, char ** argv) {
         opt_cb_data.last_save_iter = opt->iter;
     }
 
-    if (alloc) {
-        ggml_allocr_free(alloc);
-    }
-
     ggml_free(opt->ctx);
     free_train_state(train);
     ggml_free(model.ctx);