mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-25 10:03:49 +03:00
util: function to get local nl_pid used by netlink event socket
This value will be needed to set the src_pid when sending netlink messages to lldpad. It is part of the solution to: https://bugzilla.redhat.com/show_bug.cgi?id=816465 Note that libnl's port generation algorithm guarantees that the nl_socket_get_local_port() will always be > 0 (since it is "getpid() + (n << 22>" where n is always < 1024), so it is okay to cast the uint32_t to int (thus allowing us to use -1 as an error sentinel).
This commit is contained in:
parent
cca7bb1fb5
commit
c99e93758d
@ -1333,6 +1333,7 @@ virNetlinkCommand;
|
||||
virNetlinkEventAddClient;
|
||||
virNetlinkEventRemoveClient;
|
||||
virNetlinkEventServiceIsRunning;
|
||||
virNetlinkEventServiceLocalPid;
|
||||
virNetlinkEventServiceStop;
|
||||
virNetlinkEventServiceStart;
|
||||
virNetlinkShutdown;
|
||||
|
@ -378,6 +378,24 @@ virNetlinkEventServiceIsRunning(void)
|
||||
return server != NULL;
|
||||
}
|
||||
|
||||
/**
|
||||
* virNetlinkEventServiceLocalPid:
|
||||
*
|
||||
* Returns the nl_pid value that was used to bind() the netlink socket
|
||||
* used by the netlink event service, or -1 on error (netlink
|
||||
* guarantees that this value will always be > 0).
|
||||
*/
|
||||
int virNetlinkEventServiceLocalPid(void)
|
||||
{
|
||||
if (!(server && server->netlinknh)) {
|
||||
netlinkError(VIR_ERR_INTERNAL_ERROR, "%s",
|
||||
_("netlink event service not running"));
|
||||
return -1;
|
||||
}
|
||||
return (int)nl_socket_get_local_port(server->netlinknh);
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* virNetlinkEventServiceStart:
|
||||
*
|
||||
|
@ -61,6 +61,11 @@ int virNetlinkEventServiceStart(void);
|
||||
*/
|
||||
bool virNetlinkEventServiceIsRunning(void);
|
||||
|
||||
/**
|
||||
* virNetlinkEventServiceLocalPid: returns nl_pid used to bind() netlink socket
|
||||
*/
|
||||
int virNetlinkEventServiceLocalPid(void);
|
||||
|
||||
/**
|
||||
* virNetlinkEventAddClient: register a callback for handling of netlink messages
|
||||
*/
|
||||
|
Loading…
x
Reference in New Issue
Block a user