diff options
| author | 2024-06-28 16:16:57 +0000 | |
|---|---|---|
| committer | 2024-06-28 16:16:57 +0000 | |
| commit | 5feaf065a91fea2d8c9ac9af2648903d3bca98cf (patch) | |
| tree | 4bae247fbd3201d2d292a2b10d51bc2e474c85eb /libs/binder/RpcServer.cpp | |
| parent | 8992347d0d258106bed530f0f8bd622c7efeede0 (diff) | |
| parent | 3632e944a21a77c2530822e63fe1d68436191dfe (diff) | |
Merge "RpcServer: let system allocate vsock ports" into main am: aa30575a7c am: 3632e944a2
Original change: https://android-review.googlesource.com/c/platform/frameworks/native/+/3136053
Change-Id: Ief240c3d75b8d321582f2a5e5c3fdabcf9855f0a
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
Diffstat (limited to 'libs/binder/RpcServer.cpp')
| -rw-r--r-- | libs/binder/RpcServer.cpp | 19 |
1 files changed, 17 insertions, 2 deletions
diff --git a/libs/binder/RpcServer.cpp b/libs/binder/RpcServer.cpp index d9e926a9d5..b8742af1f9 100644 --- a/libs/binder/RpcServer.cpp +++ b/libs/binder/RpcServer.cpp @@ -71,8 +71,23 @@ status_t RpcServer::setupUnixDomainServer(const char* path) { return setupSocketServer(UnixSocketAddress(path)); } -status_t RpcServer::setupVsockServer(unsigned int bindCid, unsigned int port) { - return setupSocketServer(VsockSocketAddress(bindCid, port)); +status_t RpcServer::setupVsockServer(unsigned bindCid, unsigned port, unsigned* assignedPort) { + auto status = setupSocketServer(VsockSocketAddress(bindCid, port)); + if (status != OK) return status; + + if (assignedPort == nullptr) return OK; + sockaddr_vm addr; + socklen_t len = sizeof(addr); + if (0 != getsockname(mServer.fd.get(), reinterpret_cast<sockaddr*>(&addr), &len)) { + status = -errno; + ALOGE("setupVsockServer: Failed to getsockname: %s", strerror(-status)); + return status; + } + + LOG_ALWAYS_FATAL_IF(len != sizeof(addr), "Wrong socket type: len %zu vs len %zu", + static_cast<size_t>(len), sizeof(addr)); + *assignedPort = addr.svm_port; + return OK; } status_t RpcServer::setupInetServer(const char* address, unsigned int port, |