mirror of
https://github.com/ziglang/zig.git
synced 2026-02-12 20:37:54 +00:00
Revert "Fix C include files not being in whole cache (#11365)"
This reverts commit a430630002bf02162ccbf8d3eb10fd73e490cefd. Wait a minute, I'm sorry, I need to revert this. The whole premise of this change is broken because the point of the hash is that it tells whether the same compilation has been done before. This requires items to be added to the hash in the same sequence every time. This means that introducing a lock is fundamentally broken because the order needs to be the same in future runs of the compiler, and not decided by threads racing against each other. The proper solution to this is to, in whole cache mode, append the hash inputs to some data structure, and then after the compilation is complete, do some kind of sorting on the hash inputs so that they will be the same order every time, then apply them in sequence. No lock on the Cache object is needed for this scheme.
This commit is contained in:
parent
a430630002
commit
06310e3d4e
@ -690,7 +690,7 @@ pub const Manifest = struct {
|
||||
while (true) {
|
||||
switch (it.next() orelse return) {
|
||||
.target, .target_must_resolve => return,
|
||||
.prereq => |file_path| try self.addFilePost(file_path),
|
||||
.prereq => |bytes| try self.addFilePost(bytes),
|
||||
else => |err| {
|
||||
try err.printError(error_buf.writer());
|
||||
log.err("failed parsing {s}: {s}", .{ dep_file_basename, error_buf.items });
|
||||
|
||||
@ -44,7 +44,6 @@ bin_file: *link.File,
|
||||
c_object_table: std.AutoArrayHashMapUnmanaged(*CObject, void) = .{},
|
||||
/// This is a pointer to a local variable inside `update()`.
|
||||
whole_cache_manifest: ?*Cache.Manifest = null,
|
||||
whole_cache_manifest_mutex: std.Thread.Mutex = .{},
|
||||
|
||||
link_error_flags: link.File.ErrorFlags = .{},
|
||||
|
||||
@ -1963,8 +1962,8 @@ pub fn update(comp: *Compilation) !void {
|
||||
// We are about to obtain this lock, so here we give other processes a chance first.
|
||||
comp.bin_file.releaseLock();
|
||||
|
||||
man = comp.cache_parent.obtain();
|
||||
comp.whole_cache_manifest = &man;
|
||||
man = comp.cache_parent.obtain();
|
||||
try comp.addNonIncrementalStuffToCacheManifest(&man);
|
||||
|
||||
const is_hit = man.hit() catch |err| {
|
||||
@ -3353,8 +3352,6 @@ pub fn cImport(comp: *Compilation, c_src: []const u8) !CImportResult {
|
||||
const dep_basename = std.fs.path.basename(out_dep_path);
|
||||
try man.addDepFilePost(zig_cache_tmp_dir, dep_basename);
|
||||
if (comp.whole_cache_manifest) |whole_cache_manifest| {
|
||||
comp.whole_cache_manifest_mutex.lock();
|
||||
defer comp.whole_cache_manifest_mutex.unlock();
|
||||
try whole_cache_manifest.addDepFilePost(zig_cache_tmp_dir, dep_basename);
|
||||
}
|
||||
|
||||
@ -3696,11 +3693,6 @@ fn updateCObject(comp: *Compilation, c_object: *CObject, c_obj_prog_node: *std.P
|
||||
const dep_basename = std.fs.path.basename(dep_file_path);
|
||||
// Add the files depended on to the cache system.
|
||||
try man.addDepFilePost(zig_cache_tmp_dir, dep_basename);
|
||||
if (comp.whole_cache_manifest) |whole_cache_manifest| {
|
||||
comp.whole_cache_manifest_mutex.lock();
|
||||
defer comp.whole_cache_manifest_mutex.unlock();
|
||||
try whole_cache_manifest.addDepFilePost(zig_cache_tmp_dir, dep_basename);
|
||||
}
|
||||
// Just to save disk space, we delete the file because it is never needed again.
|
||||
zig_cache_tmp_dir.deleteFile(dep_basename) catch |err| {
|
||||
log.warn("failed to delete '{s}': {s}", .{ dep_file_path, @errorName(err) });
|
||||
|
||||
@ -3855,8 +3855,6 @@ pub fn semaFile(mod: *Module, file: *File) SemaError!void {
|
||||
});
|
||||
errdefer gpa.free(resolved_path);
|
||||
|
||||
mod.comp.whole_cache_manifest_mutex.lock();
|
||||
defer mod.comp.whole_cache_manifest_mutex.unlock();
|
||||
try man.addFilePostContents(resolved_path, source.bytes, source.stat);
|
||||
}
|
||||
} else {
|
||||
@ -4338,8 +4336,6 @@ pub fn embedFile(mod: *Module, cur_file: *File, rel_file_path: []const u8) !*Emb
|
||||
if (mod.comp.whole_cache_manifest) |man| {
|
||||
const copied_resolved_path = try gpa.dupe(u8, resolved_path);
|
||||
errdefer gpa.free(copied_resolved_path);
|
||||
mod.comp.whole_cache_manifest_mutex.lock();
|
||||
defer mod.comp.whole_cache_manifest_mutex.unlock();
|
||||
try man.addFilePostContents(copied_resolved_path, bytes, stat);
|
||||
}
|
||||
|
||||
|
||||
@ -455,11 +455,10 @@ export fn stage2_fetch_file(
|
||||
const comp = @intToPtr(*Compilation, stage1.userdata);
|
||||
const file_path = path_ptr[0..path_len];
|
||||
const max_file_size = std.math.maxInt(u32);
|
||||
const contents = if (comp.whole_cache_manifest) |man| blk: {
|
||||
comp.whole_cache_manifest_mutex.lock();
|
||||
defer comp.whole_cache_manifest_mutex.unlock();
|
||||
break :blk man.addFilePostFetch(file_path, max_file_size) catch return null;
|
||||
} else std.fs.cwd().readFileAlloc(comp.gpa, file_path, max_file_size) catch return null;
|
||||
const contents = if (comp.whole_cache_manifest) |man|
|
||||
man.addFilePostFetch(file_path, max_file_size) catch return null
|
||||
else
|
||||
std.fs.cwd().readFileAlloc(comp.gpa, file_path, max_file_size) catch return null;
|
||||
result_len.* = contents.len;
|
||||
// TODO https://github.com/ziglang/zig/issues/3328#issuecomment-716749475
|
||||
if (contents.len == 0) return @intToPtr(?[*]const u8, 0x1);
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user