On Sun, Jan 17, 2021, at 12:56 PM, Eric Biggers wrote: > On Sun, Jan 17, 2021 at 09:20:32AM -0500, Colin Walters wrote: > > Anything blocking a release? > > Not really. Ok, cool. > It would be annoying for all library functions to dynamically allocate > an extended error structure on failure, because callers will forget to > free it. So that's not a very good solution either. All my C code today uses __attribute__((cleanup(func)). Old blog entry of mine on it: https://blog.verbum.org/2012/05/09/__attribute__-cleanup-or-how-i-came-to-love-c-again/ systemd also uses it extensively today. (Has this actually come up for use in the Linux kernel? It's hard to do a web search for, I don't see it mentioned in https://www.kernel.org/doc/Documentation/process/coding-style.rst surprisingly - though I guess a lot of "hot paths" would still want `goto out` for speed and control). libfsverity would also benefit from this IMO. Of course since 2012 Rust appeared and I try to write new code in it where I can, but __attribute__((cleanup)) is the single best thing from C++ available in C and still feels like "native C". > Couldn't you allocate a per-thread variable (e.g. with > pthread_setspecific()) that contains a pointer to your context or > message buffer or whatever you need, and use it from the error > callback function? Yeah, a per-thread variable is better than a global mutex for this indeed. I'll try reworking my code. > Anyway, I can't change the API because it is stable now, and other > people are already using libfsverity. True, but we could add new APIs? There aren't that many. But I dunno, I don't feel very strongly about this, I can live with a pthread variable. If we decide to do that let's just add a note to the docs recommending that (for callers that want to do something other than print to stderr). That said of course this whole discussion about errno and strings parallels the kernel side: https://lwn.net/Articles/374794/ https://lwn.net/Articles/532771/ and I guess no progress has been made on that? We just live with extracting more information about errors like EIO or EPERM out-of-band from kernel subsystems (e.g. audit log for SELinux, etc.). > It sounds like you're interested in using the in-kernel signature > verification support. Can you elaborate on why you want to use it (as > opposed to e.g. doing the signature verification in userspace), and > what security properties you are aiming to achieve with it, and how > you would be achieving them? Keep in mind that userspace still needs > to verify which files have fs-verity enabled. This is a much longer discussion probably best done as a separate thread. But broadly speaking I'm looking at using fsverity as parts of systems that look more like "traditional Linux" than e.g. Android. The security properties will be weaker, but I think that's an inherent part of shipping a system where the user owns the computer and maintaining support for the vast array of systems management tooling out there. I am hopeful that we can strengthen it over time while still providing some useful security properties. OK more specific answers: just to start, I really, really like the "files are *truly* read-only even to root" aspect of fs-verity. This alone avoids whole classes of accidental system damage and can mitigate some types of exploit chains (I gave the example of the runc exploit in the Fedora thread on IMA). Another example (I didn't fully dig into this but just some thoughts) is that since dm-crypt doesn't provide integrity, fs-verity-on-dm-crypt can help mitigate some offline attacks as well as online attacks in "encrypted virtualization" (https://lwn.net/Articles/841549/) scenarios. To answer your specific question, one idea I'd like to pursue is patching systemd to require the target of `ExecStart=` be verity signed. And more generally (this leads into IMA-policy like flows) require any privileged (CAP_SYS_ADMIN) binaries be verity signed. Now related to this...I see you have some recent patches to allow userspace to extract the signature from a verity file. That sounds very useful because it will avoid the need for out of band signature data for e.g. `/usr/bin/bash` right? Although hmm, I guess today one could store signatures in an xattr? (Thanks for all your work on fsverity btw!)