<p>lynxis lazus <strong>submitted</strong> this change.</p><p><a href="https://gerrit.osmocom.org/c/libosmocore/+/19141">View Change</a></p><div style="white-space:pre-wrap">Approvals:
  Jenkins Builder: Verified
  laforge: Looks good to me, approved

</div><pre style="font-family: monospace,monospace; white-space: pre-wrap;">socket.h: introduce osmo_sockaddr to hold v4 and v6 endpoints<br><br>When dealing with IPv4 and IPv6 address, the struct sockaddr<br>allows to hold IPv4 and IPv6.<br>However even when struct sockaddr is being used, a cast to the<br>IPv4 or IPv6 family must happen. To work around this additional code,<br>use a union for the most common types.<br><br>Change-Id: If80172373735193401af872b18e1ff00c93880e7<br>---<br>M include/osmocom/core/socket.h<br>1 file changed, 11 insertions(+), 2 deletions(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;"><span>diff --git a/include/osmocom/core/socket.h b/include/osmocom/core/socket.h</span><br><span>index 129612c..9cb8d6b 100644</span><br><span>--- a/include/osmocom/core/socket.h</span><br><span>+++ b/include/osmocom/core/socket.h</span><br><span>@@ -2,6 +2,7 @@</span><br><span>  *  Osmocom socket convenience functions. */</span><br><span> </span><br><span> #pragma once</span><br><span style="color: hsl(120, 100%, 40%);">+#if (!EMBEDDED)</span><br><span> </span><br><span> /*! \defgroup socket Socket convenience functions</span><br><span>  *  @{</span><br><span>@@ -11,17 +12,24 @@</span><br><span> #include <stdbool.h></span><br><span> #include <stddef.h></span><br><span> </span><br><span style="color: hsl(0, 100%, 40%);">-#if (!EMBEDDED)</span><br><span> #include <arpa/inet.h></span><br><span> </span><br><span> /*! maximum length of a socket name ("r=1.2.3.4:123<->l=5.6.7.8:987") */</span><br><span> #define OSMO_SOCK_NAME_MAXLEN (2 + INET6_ADDRSTRLEN + 1 + 5 + 3 + 2 + INET6_ADDRSTRLEN + 1 + 5 + 1)</span><br><span style="color: hsl(0, 100%, 40%);">-#endif</span><br><span> </span><br><span> struct sockaddr_in;</span><br><span> struct sockaddr;</span><br><span> struct osmo_fd;</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+struct osmo_sockaddr {</span><br><span style="color: hsl(120, 100%, 40%);">+        union {</span><br><span style="color: hsl(120, 100%, 40%);">+               struct sockaddr sa;</span><br><span style="color: hsl(120, 100%, 40%);">+           struct sockaddr_storage sas;</span><br><span style="color: hsl(120, 100%, 40%);">+          struct sockaddr_in sin;</span><br><span style="color: hsl(120, 100%, 40%);">+               struct sockaddr_in6 sin6;</span><br><span style="color: hsl(120, 100%, 40%);">+     } u;</span><br><span style="color: hsl(120, 100%, 40%);">+};</span><br><span style="color: hsl(120, 100%, 40%);">+</span><br><span> /* flags for osmo_sock_init. */</span><br><span> /*! connect the socket to a remote peer */</span><br><span> #define OSMO_SOCK_F_CONNECT      (1 << 0)</span><br><span>@@ -92,4 +100,5 @@</span><br><span> </span><br><span> int osmo_sock_local_ip(char *local_ip, const char *remote_ip);</span><br><span> </span><br><span style="color: hsl(120, 100%, 40%);">+#endif /* (!EMBEDDED) */</span><br><span> /*! @} */</span><br><span></span><br></pre><p>To view, visit <a href="https://gerrit.osmocom.org/c/libosmocore/+/19141">change 19141</a>. To unsubscribe, or for help writing mail filters, visit <a href="https://gerrit.osmocom.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.osmocom.org/c/libosmocore/+/19141"/><meta itemprop="name" content="View Change"/></div></div>

<div style="display:none"> Gerrit-Project: libosmocore </div>
<div style="display:none"> Gerrit-Branch: master </div>
<div style="display:none"> Gerrit-Change-Id: If80172373735193401af872b18e1ff00c93880e7 </div>
<div style="display:none"> Gerrit-Change-Number: 19141 </div>
<div style="display:none"> Gerrit-PatchSet: 10 </div>
<div style="display:none"> Gerrit-Owner: lynxis lazus <lynxis@fe80.eu> </div>
<div style="display:none"> Gerrit-Reviewer: Jenkins Builder </div>
<div style="display:none"> Gerrit-Reviewer: laforge <laforge@osmocom.org> </div>
<div style="display:none"> Gerrit-Reviewer: lynxis lazus <lynxis@fe80.eu> </div>
<div style="display:none"> Gerrit-CC: pespin <pespin@sysmocom.de> </div>
<div style="display:none"> Gerrit-MessageType: merged </div>