[Libguestfs] [PATCH nbdkit] server: Pass the export name through filter .open calls.
Eric Blake
eblake at redhat.com
Wed Jul 22 11:17:50 UTC 2020
On 7/22/20 3:53 AM, Richard W.M. Jones wrote:
> On Tue, Jul 21, 2020 at 07:41:21PM -0500, Eric Blake wrote:
>> On 7/21/20 3:47 PM, Richard W.M. Jones wrote:
>>> +++ b/server/plugins.c
>>> @@ -278,12 +278,30 @@ plugin_preconnect (struct backend *b, int readonly)
>>> }
>>> static void *
>>> -plugin_open (struct backend *b, int readonly)
>>> +plugin_open (struct backend *b, int readonly, const char *exportname)
>>> {
>>> + GET_CONN;
>>> struct backend_plugin *p = container_of (b, struct backend_plugin, backend);
>>> assert (p->plugin.open != NULL);
>>> + /* Save the exportname since the lifetime of the string passed in
>>> + * here is likely to be brief. In addition this provides a place
>>> + * for nbdkit_export_name to retrieve it if called from the plugin.
>>> + *
>>> + * In API V3 we propose to pass the exportname as an extra parameter
>>> + * to the (new) plugin.open and deprecate nbdkit_export_name for V3
>>> + * users. Even then we will still need to save it in the handle
>>> + * because of the lifetime issue.
>>> + */
>>> + if (conn->exportname == NULL) {
>>
>> Can't we assert(!conn->exportname) at this point? After all, we
>> only ever call .open at most once per connection.
>
> I don't think so - backend_reopen will call plugin_open a second time.
> As a test I added assert (conn->exportname == NULL) before this line
> and it crashed in tests/test-retry.sh.
Fair enough.
>>> + if (conn->exportname_from_set_meta_context &&
>>> + strcmp (conn->exportname_from_set_meta_context, exportname) != 0) {
>>> + debug ("newstyle negotiation: NBD_OPT_SET_META_CONTEXT export name \"%s\" ≠ final client exportname \"%s\", so discarding the previous context",
>>
>> Long line, and I don't know if we use UTF-8 in other debug messages
>> or should stick to straight ascii. Compilation may have a glitch if
>> compiled under a different locale than the end binary runs in, but
>> these days, it's uncommon to find someone running in a single-byte
>> locale instead of UTF-8.
>
> I thought we might be using ‘’ quotes (as we do in libguestfs) but I
> see that we don't. I think we should use Unicode characters more
> where they are appropriate, but I'll break up this long line. I also
> added a comment.
I see you used Unicode quoting when refactoring the nbd plugin recently,
but yeah, I agree we haven't been using it much yet. I'm not opposed to
Unicode in C strings, but just pointing out that it can reduce the set
of platforms where things work out of the box (although these days,
since we require working gcc or clang for __attribute__((cleanup)), not
using Unicode is unlikely). Switching existing code to use nicer
quoting would be a separate cleanup series.
>
>>> @@ -148,7 +166,7 @@ ext2_prepare (struct nbdkit_next_ops *next_ops, void *nxdata, void *handle,
>>> struct ext2_inode inode;
>>> int64_t r;
>>> CLEANUP_FREE char *name = NULL;
>>> - const char *fname = file ?: nbdkit_export_name ();
>>> + const char *fname = file ?: h->exportname;
>>
>> Hmm - we already pass the same 'readonly' state to filter's
>> .prepare, but not to backend_prepare(), which has to reconstruct it.
>> Would it be easier to also change the signature of backend_prepare()
>> to take both the original readonly and exportname passed to
>> backend_open(), rather than making the filter have to save it off in
>> the filter? It looks like protocol-handshake.c is the only caller,
>> and still has everything in scope at the time.
>
> Possibly, although this would be a seperate change.
As I replied in a later mail, no, it would not be easier.
--
Eric Blake, Principal Software Engineer
Red Hat, Inc. +1-919-301-3226
Virtualization: qemu.org | libvirt.org
More information about the Libguestfs
mailing list