mirror of
https://github.com/ollama/ollama.git
synced 2025-05-11 18:36:41 +02:00
server: do not attempt to parse offset file as gguf
This logic was causing issues for me when importing a gguf that had some padding at the end of the file. The valid gguf would be read, but then it would try to read the offset as a different gguf file. This does not seem right.
This commit is contained in:
parent
e7019c9455
commit
04950140ec
1 changed files with 27 additions and 33 deletions
|
@ -497,43 +497,37 @@ func ggufLayers(digest string, fn func(resp api.ProgressResponse)) ([]*layerGGML
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var offset int64
|
f, n, err := ggml.Decode(blob, 0)
|
||||||
for offset < stat.Size() {
|
if err != nil {
|
||||||
f, n, err := ggml.Decode(blob, 0)
|
return nil, err
|
||||||
if errors.Is(err, io.EOF) {
|
}
|
||||||
break
|
|
||||||
} else if err != nil {
|
mediatype := "application/vnd.ollama.image.model"
|
||||||
|
if f.KV().Kind() == "adapter" {
|
||||||
|
mediatype = "application/vnd.ollama.image.adapter"
|
||||||
|
} else if _, ok := f.KV()[fmt.Sprintf("%s.vision.block_count", f.KV().Architecture())]; ok || f.KV().Kind() == "projector" {
|
||||||
|
mediatype = "application/vnd.ollama.image.projector"
|
||||||
|
}
|
||||||
|
|
||||||
|
var layer Layer
|
||||||
|
if digest != "" && n == stat.Size() {
|
||||||
|
layer, err = NewLayerFromLayer(digest, mediatype, blob.Name())
|
||||||
|
if err != nil {
|
||||||
|
slog.Debug("could not create new layer from layer", "error", err)
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
mediatype := "application/vnd.ollama.image.model"
|
|
||||||
if f.KV().Kind() == "adapter" {
|
|
||||||
mediatype = "application/vnd.ollama.image.adapter"
|
|
||||||
} else if _, ok := f.KV()[fmt.Sprintf("%s.vision.block_count", f.KV().Architecture())]; ok || f.KV().Kind() == "projector" {
|
|
||||||
mediatype = "application/vnd.ollama.image.projector"
|
|
||||||
}
|
|
||||||
|
|
||||||
var layer Layer
|
|
||||||
if digest != "" && n == stat.Size() && offset == 0 {
|
|
||||||
layer, err = NewLayerFromLayer(digest, mediatype, blob.Name())
|
|
||||||
if err != nil {
|
|
||||||
slog.Debug("could not create new layer from layer", "error", err)
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fallback to creating layer from file copy (either NewLayerFromLayer failed, or digest empty/n != stat.Size())
|
|
||||||
if layer.Digest == "" {
|
|
||||||
layer, err = NewLayer(io.NewSectionReader(blob, offset, n), mediatype)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
layers = append(layers, &layerGGML{layer, f})
|
|
||||||
offset = n
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Fallback to creating layer from file copy (either NewLayerFromLayer failed, or digest empty/n != stat.Size())
|
||||||
|
if layer.Digest == "" {
|
||||||
|
layer, err = NewLayer(io.NewSectionReader(blob, 0, n), mediatype)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
layers = append(layers, &layerGGML{layer, f})
|
||||||
|
|
||||||
return detectChatTemplate(layers)
|
return detectChatTemplate(layers)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue