-
Notifications
You must be signed in to change notification settings - Fork 543
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fixes for Windows #439
base: foxy-devel
Are you sure you want to change the base?
Fixes for Windows #439
Conversation
* Replace uint with unsigned int * Export symbols by defining KARTO_DYNAMIC * Don't set compiler flags that don't exist on MSVC
Undef NO_ERROR from windows headers
Use Sleep instead of sleep in Windows
target_link_libraries(async_slam_toolbox toolbox_common kartoSlamToolbox ${Boost_LIBRARIES}) | ||
add_executable(async_slam_toolbox_node src/slam_toolbox_async_node.cpp) | ||
if(MSVC) | ||
target_compile_options(async_slam_toolbox_node PRIVATE "/F 40000000") |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not familiar with this /F 40000000
, can you explain me this?
@@ -29,6 +29,9 @@ int main(int argc, char ** argv) | |||
auto temp_node = std::make_shared<rclcpp::Node>("slam_toolbox"); | |||
temp_node->declare_parameter("stack_size_to_use"); | |||
if (temp_node->get_parameter("stack_size_to_use", stack_size)) { | |||
#ifdef _WIN32 | |||
RCLCPP_WARN(temp_node->get_logger(), "Can't dynamically change stack size on Windows. Node using stack size 40000000"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there another API to change the stack size then? This is kind of an important element for serialization / deserialization of large maps
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
From my research, I wasn't able to find a way to dynamically change the stack size of the program at runtime on Windows. However, I was able to find a way to change the stack size when a thread is created here.
Do you think it would be possible to utilize this functionality instead? Or, instead of serializing and deserializing maps on the stack, is it possible to use dynamic memory, just for Windows?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It uses boost serialization, so that's totally out of our control where that memory is located for serialization.
So are you suggesting we serialize/deserialize in another thread that in instantiation we set the max size on? That would need some testing on your end to validate, but I could approve that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Instead of putting only the serialization/deserialization on a separate thread, it might be easier to just put the entire node in a separate thread. Do you think that would be fine too?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would not like to do that, that would add an extra thread for everyone for all of run-time, versus only an extra thread on serialization/deserialization processes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see, that makes sense! Would I just have to modify SlamToolbox::serializePoseGraphCallback
and SlamToolbox::loadSerializedPoseGraph
? Are there any other functions that do the serialization and deserialization?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yup, that's right
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do you have any large serialized maps I can use for testing? In the README, I saw a mention about a map from Circuit Launch. Would it be possible to give me access to that or another map?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
None that I can share publicly
Same with the Nav2 PR: needs a |
Basic Info
Description of contribution in a few bullet points
Description of documentation updates required from your changes
N/A
Future work that may be required in bullet points
None, I think it all works on Windows