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:
Laine Stump 2012-05-04 13:19:51 -04:00
parent cca7bb1fb5
commit c99e93758d
3 changed files with 24 additions and 0 deletions

View File

@ -1333,6 +1333,7 @@ virNetlinkCommand;
virNetlinkEventAddClient;
virNetlinkEventRemoveClient;
virNetlinkEventServiceIsRunning;
virNetlinkEventServiceLocalPid;
virNetlinkEventServiceStop;
virNetlinkEventServiceStart;
virNetlinkShutdown;

View File

@ -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:
*

View File

@ -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
*/