Skip to content

Commit

Permalink
Address known limitation in service/client by using a 'std::map' to s…
Browse files Browse the repository at this point in the history
…tore the sample pointers (ros2#105)
  • Loading branch information
mossmaurice committed Jan 3, 2024
1 parent 4936431 commit 70c8c86
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 14 deletions.
14 changes: 12 additions & 2 deletions rmw_iceoryx_cpp/src/rmw_request.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -175,15 +175,25 @@ rmw_take_request(
}

// Hold the loaned request till we send the response in 'rmw_send_response'
iceoryx_server_abstraction->request_payload_ = iceoryx_request_payload;
auto result =
iceoryx_server_abstraction->request_payload_map_.insert(
{request_header->request_id.
sequence_number, iceoryx_request_payload});

if (result.second == false) {
*taken = false;
RMW_SET_ERROR_MSG("rmw_take_request: Could not store the sample pointer in the map!");
ret = RMW_RET_ERROR;
return;
}

*taken = true;
ret = RMW_RET_OK;
})
.or_else(
[&](auto &) {
*taken = false;
RMW_SET_ERROR_MSG("rmw_take_request error!");
RMW_SET_ERROR_MSG("rmw_take_request: Taking the sample failed!");
ret = RMW_RET_ERROR;
});

Expand Down
12 changes: 7 additions & 5 deletions rmw_iceoryx_cpp/src/rmw_response.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -147,14 +147,14 @@ rmw_send_response(

rmw_ret_t ret = RMW_RET_ERROR;

if (!iceoryx_server_abstraction->request_payload_) {
if (iceoryx_server_abstraction->request_payload_map_.empty()) {
RMW_SET_ERROR_MSG("'rmw_take_request' needs to be called before 'rmw_send_response'!");
ret = RMW_RET_ERROR;
return ret;
}

auto * iceoryx_request_header = iox::popo::RequestHeader::fromPayload(
iceoryx_server_abstraction->request_payload_);
iceoryx_server_abstraction->request_payload_map_[request_header->sequence_number]);

iceoryx_server->loan(
iceoryx_request_header, iceoryx_server_abstraction->response_size_,
Expand Down Expand Up @@ -186,9 +186,11 @@ rmw_send_response(
ret = RMW_RET_ERROR;
});

// Release the hold request
iceoryx_server->releaseRequest(iceoryx_server_abstraction->request_payload_);
iceoryx_server_abstraction->request_payload_ = nullptr;
// Release the hold request and delete the entry from the map
iceoryx_server->releaseRequest(
iceoryx_server_abstraction->request_payload_map_[request_header->
sequence_number]);
iceoryx_server_abstraction->request_payload_map_.erase(request_header->sequence_number);

return ret;
}
Expand Down
17 changes: 10 additions & 7 deletions rmw_iceoryx_cpp/src/types/iceoryx_server.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,8 @@

#include "rmw_iceoryx_cpp/iceoryx_type_info_introspection.hpp"

#include <map>

struct IceoryxServer
{
IceoryxServer(
Expand All @@ -31,17 +33,18 @@ struct IceoryxServer
iceoryx_server_(iceoryx_server),
is_fixed_size_(rmw_iceoryx_cpp::iceoryx_is_fixed_size(type_supports)),
response_size_(rmw_iceoryx_cpp::iceoryx_get_response_size(type_supports))
{}
{
}

rosidl_service_type_support_t type_supports_;
iox::popo::UntypedServer * const iceoryx_server_;
bool is_fixed_size_;
size_t response_size_;
/// @todo The request payload pointer could also be added to 'rmw_request_id_t' if accepeted in
/// ros2/rmw. For now, the limitation exists to always call 'rmw_take_request' followed by
/// 'rmw_send_response' and not call e.g. 2x times 'rmw_take_request' and then
/// 2x 'rmw_send_response'
const void * request_payload_{nullptr};
/// @brief The map stores the sequence numbers together with the corresponding
/// sample pointer pointing to the shared memory. This is due to the fact that
/// 'rmw_request_id_t' misses a place to store the sample pointer, which is not
/// typical with DDS implementations.
std::map<int64_t, const void *> request_payload_map_;
};

#endif // TYPES__ICEORYX_SERVER_HPP_
#endif // TYPES__ICEORYX_SERVER_HPP_

0 comments on commit 70c8c86

Please sign in to comment.