Skip to content

Commit

Permalink
irmin-pack: Remove transfer_append_exn from GC code
Browse files Browse the repository at this point in the history
  • Loading branch information
Ngoguey42 committed Oct 6, 2022
1 parent 5085a39 commit ecc77f0
Showing 1 changed file with 6 additions and 37 deletions.
43 changes: 6 additions & 37 deletions src/irmin-pack/unix/gc.ml
Original file line number Diff line number Diff line change
Expand Up @@ -21,23 +21,13 @@ include Gc_intf
module Worker = struct
module Payload = Control_file.Latest_payload

let buffer_size = 8192

exception Pack_error = Errors.Pack_error

module type S = sig
module Args : Args

val run_and_output_result : generation:int -> string -> Args.key -> int63

val transfer_append_exn :
dispatcher:Args.Dispatcher.t ->
append_exn:(string -> unit) ->
off:int63 ->
len:int63 ->
bytes ->
unit

type gc_output = (int63, Args.Errs.t) result [@@deriving irmin]
end

Expand Down Expand Up @@ -67,25 +57,6 @@ module Worker = struct

let string_of_key = Irmin.Type.to_string key_t

let transfer_append_exn ~dispatcher ~append_exn ~(off : int63)
~(len : int63) buffer =
let read_exn = Dispatcher.read_in_prefix_and_suffix_exn dispatcher in
let buffer_size = Bytes.length buffer |> Int63.of_int in
let rec aux off len_remaining =
let open Int63.Syntax in
let min a b = if a < b then a else b in
let len = min buffer_size len_remaining in
let len' = Int63.to_int len in
read_exn ~off ~len:len' buffer;
let () =
if len = buffer_size then append_exn (Bytes.to_string buffer)
else append_exn (Bytes.sub_string buffer 0 len')
in
let len_remaining = len_remaining - len in
if len_remaining > Int63.zero then aux (off + len) len_remaining
in
aux off len

(** [iter_from_node_key node_key _ _ ~f] calls [f] with the key of the node
and iterates over its children.
Expand Down Expand Up @@ -245,12 +216,11 @@ module Worker = struct

(* Step 5. Transfer to the new prefix, flush and close. *)
[%log.debug "GC: transfering to the new prefix"];
let buffer = Bytes.create buffer_size in
(* Step 5.1. Transfer all. *)
let append_exn = Ao.append_exn prefix in
let f ~off ~len =
let len = Int63.of_int len in
transfer_append_exn ~dispatcher ~append_exn ~off ~len buffer
Dispatcher.read_bytes_exn dispatcher ~f:append_exn ~off ~len
in
let () = Mapping_file.iter_exn mapping f in
Ao.flush prefix |> Errs.raise_if_error
Expand Down Expand Up @@ -280,7 +250,6 @@ module Worker = struct

(* Step 6. Create the new suffix and prepare 2 functions for read and write
operations. *)
let buffer = Bytes.create buffer_size in
[%log.debug "GC: creating new suffix"];
let suffix = create_new_suffix ~root ~generation in
Errors.finalise_exn (fun _outcome ->
Expand All @@ -289,7 +258,6 @@ module Worker = struct
|> Errs.log_if_error "GC: Close suffix")
@@ fun () ->
let append_exn = Ao.append_exn suffix in
let transfer_exn = transfer_append_exn ~dispatcher ~append_exn buffer in

(* Step 7. Transfer to the next suffix. *)
[%log.debug "GC: transfering to the new suffix"];
Expand All @@ -309,7 +277,9 @@ module Worker = struct
"GC: transfer_loop iteration %d, offset %a, length %a"
(num_iterations - i + 1)
Int63.pp off Int63.pp len];
let () = transfer_exn ~off ~len in
let () =
Dispatcher.read_bytes_exn dispatcher ~f:append_exn ~off ~len
in
(* Check how many bytes are left, [4096*5] is selected because it is roughly the
number of bytes that requires a read from the block device on ext4 *)
if Int63.to_int len < 4096 * 5 then end_offset
Expand Down Expand Up @@ -446,13 +416,12 @@ module Make (Args : Args) = struct
Ao.close new_suffix
|> Errs.log_if_error "GC: Close suffix after copy latest newies")
@@ fun () ->
let buffer = Bytes.create 8192 in
let append_exn = Ao.append_exn new_suffix in
let flush_and_raise () = Ao.flush new_suffix |> Errs.raise_if_error in
let* () =
Errs.catch (fun () ->
Worker.transfer_append_exn ~dispatcher:t.dispatcher ~append_exn
~off:new_suffix_end_offset ~len:remaining buffer;
Dispatcher.read_bytes_exn t.dispatcher ~f:append_exn
~off:new_suffix_end_offset ~len:remaining;
flush_and_raise ())
in
Ok old_suffix_end_offset
Expand Down

0 comments on commit ecc77f0

Please sign in to comment.