ml/backend/ggml: allocate memory with malloc when loading model (#9822)
This commit is contained in:
parent
108fe02165
commit
364629b8d6
@ -312,17 +312,19 @@ func New(r *os.File, params ml.BackendParams) (ml.Backend, error) {
|
|||||||
return fmt.Errorf("unassigned tensor: %s", t.Name)
|
return fmt.Errorf("unassigned tensor: %s", t.Name)
|
||||||
}
|
}
|
||||||
|
|
||||||
bts := make([]byte, t.Size())
|
bts := C.malloc(C.size_t(t.Size()))
|
||||||
n, err := io.ReadFull(io.NewSectionReader(sr, int64(t.Offset), int64(t.Size())), bts)
|
if bts == nil {
|
||||||
if err != nil {
|
return errors.New("failed to allocate tensor buffer")
|
||||||
return err
|
}
|
||||||
|
defer C.free(bts)
|
||||||
|
|
||||||
|
buf := unsafe.Slice((*byte)(bts), t.Size())
|
||||||
|
n, err := io.ReadFull(io.NewSectionReader(sr, int64(t.Offset), int64(t.Size())), buf)
|
||||||
|
if err != nil || n != len(buf) {
|
||||||
|
return errors.New("read failed")
|
||||||
}
|
}
|
||||||
|
|
||||||
if n != len(bts) {
|
C.ggml_backend_tensor_set(tt, bts, 0, C.size_t(t.Size()))
|
||||||
return errors.New("short read")
|
|
||||||
}
|
|
||||||
|
|
||||||
C.ggml_backend_tensor_set(tt, unsafe.Pointer(&bts[0]), 0, C.size_t(t.Size()))
|
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user