Skip to content
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

T4 pb 12150 #1039

Closed
wants to merge 64 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
64 commits
Select commit Hold shift + click to select a range
23f96c0
Merge pull request #1 from autowarefoundation/tier4/proposal
kenji-miyake Jan 24, 2022
a0fe549
Merge pull request #3 from autowarefoundation/tier4/proposal
kenji-miyake Jan 26, 2022
33549de
ci: add sync-upstream.yaml (#4)
kenji-miyake Jan 29, 2022
355609b
Merge pull request #5 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Feb 8, 2022
b6beeec
Merge pull request #11 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Feb 15, 2022
f371839
Merge pull request #13 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Feb 28, 2022
acf26ea
ci(sync-upstream): update settings (#19)
kenji-miyake Mar 3, 2022
f92e938
Merge pull request #17 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Mar 4, 2022
26c6541
Merge pull request #20 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Mar 18, 2022
8082bea
Merge pull request #27 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Mar 18, 2022
d065ddd
Merge pull request #29 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 4, 2022
4c1d0cb
Merge pull request #30 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 5, 2022
4a3e529
chore: sync files (#629)
awf-autoware-bot[bot] Apr 5, 2022
3dea07d
chore: sync files (#637)
awf-autoware-bot[bot] Apr 6, 2022
f037c18
fix(dummy_diag_publisher): use anon to make unique node name instead …
h-ohta Apr 6, 2022
0c2022a
Merge pull request #32 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 6, 2022
a4e7e2f
Merge branch 'tier4/main' into sync-upstream
yn-mrse Apr 8, 2022
b9fb070
Merge pull request #33 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 8, 2022
840d3e9
Merge pull request #35 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 8, 2022
3a37242
chore: sync files (#648)
awf-autoware-bot[bot] Apr 9, 2022
a827200
fix(autoware_state_panel): fix message type for /api/autoware/get/eng…
h-ohta Apr 11, 2022
cc39553
Merge pull request #36 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 11, 2022
75b9e2d
Merge pull request #37 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 18, 2022
8278cce
Merge pull request #39 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 26, 2022
e0ad67a
Merge pull request #41 from tier4/sync-upstream
tier4-autoware-public-bot[bot] Apr 26, 2022
6174d32
Merge pull request #42 from tier4/sync-upstream
tier4-autoware-public-bot[bot] May 8, 2022
65e6d7b
Merge pull request #43 from tier4/sync-upstream
tier4-autoware-public-bot[bot] May 9, 2022
9f5837f
fix(behavior_velocity): avoid insert same point on trajectory utils (…
taikitanaka3 May 9, 2022
69fc674
refactor(behavior_velocity_planner): simplify CMakeLists.txt (#855)
kenji-miyake May 9, 2022
063a95d
fix(system_monitor): fix build error on tegra platform (#869)
Sharrrrk May 9, 2022
35a1f0a
feat(ad_service_state_monitor): limit odometry buffer size (#514)
takayuki5168 May 9, 2022
82c6ad8
docs: fix 404 error caused by typo in url (#871)
Shin-kyoto May 9, 2022
a7118b6
fix(image_projection_based_fusion): set imagebuffersize (#820)
storrrrrrrrm May 9, 2022
8809673
chore(avoidance_module): fix spell check (#732)
zulfaqar-azmi-t4 May 9, 2022
cc43203
feat: isolate gtests in all packages (#693)
maxime-clem May 9, 2022
0786fa1
docs(virtual traffic light): add documentation (#245)
taikitanaka3 May 9, 2022
4f4644f
feat(surround_obstacle_checker): separate surround_obstacle_checker f…
satoshi-ota May 9, 2022
1f5ade6
feat: remove deprecated package in prediction launch (#875)
yukkysaito May 10, 2022
399c133
fix(surround_obstacle_checker): fix ego footprint polygon (#877)
satoshi-ota May 10, 2022
eca2944
fix: update nvinfer api (#863)
wep21 May 10, 2022
3e5e6db
fix(avoidance_module): ignore object instead of creating zero shift (…
zulfaqar-azmi-t4 May 10, 2022
7b81507
fix(motion_velocity_smoother): curve deceleration not working with a …
TakaHoribe May 10, 2022
6668873
test(autoware_testing): fix smoke_test (#479)
KeisukeShima May 10, 2022
31147a2
feat(rviz_plugins): add velocity limit to autoware state panel (#879)
taikitanaka3 May 11, 2022
da41a37
fix(dummy_perception_publisher): publish multiple layers of pointclou…
HiroIshida May 11, 2022
e2e557d
feat(vehicle_info_util): add max_steer_angle (#740)
takayuki5168 May 11, 2022
952510b
ci(deploy-docs): remove mdx_unimoji (#883)
shmpwk May 11, 2022
b2727f0
chore: sync files (#884)
awf-autoware-bot[bot] May 11, 2022
ae80db9
fix(lidar_centerpoint): fix google drive url to avoid 404 (#889)
h-ohta May 12, 2022
c396b9d
chore: fix typos (#886)
badai-nguyen May 12, 2022
ffb0553
feat(state_rviz_plugin): add GateMode and PathChangeApproval Button (…
h-ohta May 13, 2022
80f3f1c
feat(map_tf_generator): accelerate the 'viewer' coordinate calculatio…
IshitaTakeshi May 13, 2022
ef37953
docs(obstacle_stop_planner): update documentation (#880)
satoshi-ota May 13, 2022
9470442
docs(tier4_traffic_light_rviz_plugin): update documentation (#905)
satoshi-ota May 16, 2022
e1e81b3
fix(accel_brake_map_calibrator): rviz panel type (#895)
soblin May 16, 2022
55d807e
fix(behavior velocity planner): skipping emplace back stop reason if …
TakumiKozaka-T4 May 17, 2022
f1d2b9e
feat(behavior_path_planner): weakened noise filtering of drivable are…
takayuki5168 May 17, 2022
0621852
Merge pull request #44 from tier4/sync-upstream
tier4-autoware-public-bot[bot] May 18, 2022
db25a76
Merge branch 'tier4/main' into sync-upstream
YoheiMishina May 24, 2022
fefdd4d
Merge pull request #47 from tier4/sync-upstream
tier4-autoware-public-bot[bot] May 24, 2022
f97557e
first commit
nobuotakamasa May 25, 2022
ab73b5a
fix comment
nobuotakamasa Jun 17, 2022
cb13c5d
fix diff
nobuotakamasa Jun 19, 2022
e911915
fix comment
nobuotakamasa Jun 19, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 28 additions & 0 deletions .github/workflows/sync-upstream.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
name: sync-upstream
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please confirm your diff.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Reverted unnecessary fixes.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Mm, there is no change. 🥺

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please remove sync-upstream.yaml.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also, please confirm the pull request guidelines.


on:
schedule:
- cron: 0 0 * * *
workflow_dispatch:

jobs:
sync-upstream:
runs-on: ubuntu-latest
steps:
- name: Generate token
id: generate-token
uses: tibdex/github-app-token@v1
with:
app_id: ${{ secrets.APP_ID }}
private_key: ${{ secrets.PRIVATE_KEY }}

- name: Run sync-branches
uses: autowarefoundation/autoware-github-actions/sync-branches@v1
with:
token: ${{ steps.generate-token.outputs.token }}
base-branch: tier4/main
sync-pr-branch: sync-upstream
sync-target-repository: https://github.com/autowarefoundation/autoware.universe.git
sync-target-branch: main
pr-title: "chore: sync upstream"
auto-merge-method: merge
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@

<!-- debug -->
<arg name="debug_mode" default="false"/>

<arg name="filter_scope_minx" default="-100"/>
<arg name="filter_scope_maxx" default="100"/>
<arg name="filter_scope_miny" default="-100"/>
Expand Down
26 changes: 26 additions & 0 deletions system/system_monitor/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -62,10 +62,26 @@ else()
endif()
endif()

if(CMAKE_ECU_PLATFORM STREQUAL "adlink")
set(CMAKE_ECU_PLATFORM "adlink")
else()
set(CMAKE_ECU_PLATFORM "unknown")
endif()

message(STATUS "HOST_SYSTEM_VERSION: " ${CMAKE_HOST_SYSTEM_VERSION})
message(STATUS "SYSTEM_PROCESSOR: " ${CMAKE_SYSTEM_PROCESSOR})
message(STATUS "CPU PLATFORM: " ${CMAKE_CPU_PLATFORM})
message(STATUS "GPU PLATFORM: " ${CMAKE_GPU_PLATFORM})
message(STATUS "ECU PLATFORM: " ${CMAKE_ECU_PLATFORM})

set(ECU_MONITOR_SOURCE
src/ecu_monitor/ecu_monitor_base.cpp
src/ecu_monitor/${CMAKE_ECU_PLATFORM}_ecu_monitor.cpp
)

ament_auto_add_library(ecu_monitor_lib SHARED
${ECU_MONITOR_SOURCE}
)

set(CPU_MONITOR_SOURCE
src/cpu_monitor/cpu_monitor_base.cpp
Expand Down Expand Up @@ -129,6 +145,7 @@ find_package(Boost REQUIRED COMPONENTS
)

## Specify libraries to link a library or executable target against
target_link_libraries(ecu_monitor_lib ${Boost_LIBRARIES} ${LIBRARIES})
target_link_libraries(cpu_monitor_lib ${Boost_LIBRARIES} ${LIBRARIES})
target_link_libraries(hdd_monitor_lib ${Boost_LIBRARIES} ${LIBRARIES})
target_link_libraries(mem_monitor_lib ${LIBRARIES})
Expand Down Expand Up @@ -175,6 +192,11 @@ rclcpp_components_register_node(gpu_monitor_lib
EXECUTABLE gpu_monitor
)

rclcpp_components_register_node(ecu_monitor_lib
PLUGIN "ECUMonitor"
EXECUTABLE ecu_monitor
)

# TODO(yunus.caliskan): Port the tests to ROS2, robustify the tests.
if(BUILD_TESTING)
# ament_add_ros_isolated_gtest(test_cpu_monitor
Expand Down Expand Up @@ -293,6 +315,10 @@ if(BUILD_TESTING)

endif()

#############
## Install ##
#############

ament_auto_package(INSTALL_TO_SHARE
launch
config
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
// Copyright 2020 Tier IV, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

/**
* @file adlink_ecu_monitor.h
* @brief ECU monitor class
*/

#ifndef SYSTEM_MONITOR__ECU_MONITOR__ADLINK_ECU_MONITOR_HPP_
#define SYSTEM_MONITOR__ECU_MONITOR__ADLINK_ECU_MONITOR_HPP_

#include "system_monitor/ecu_monitor/ecu_monitor_base.hpp"

#include <string>

class ECUMonitor : public ECUMonitorBase
{
public:
/**
* @brief constructor
* @param [in] options Options associated with this node.
*/
explicit ECUMonitor(const rclcpp::NodeOptions & options);

protected:
/**
* @brief check ECU thermal throttling
* @param [out] stat diagnostic message passed directly to diagnostic publish calls
* @note NOLINT syntax is needed since diagnostic_updater asks for a non-const reference
* to pass diagnostic message updated in this function to diagnostic publish calls.
*/
void checkVoltage(
diagnostic_updater::DiagnosticStatusWrapper & stat); // NOLINT(runtime/references)
bool sensors_exists_; //!< @brief flag if sensors exists
float voltage_warn_;
float voltage_error_;
};

#endif // SYSTEM_MONITOR__ECU_MONITOR__ADLINK_ECU_MONITOR_HPP_
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
// Copyright 2020 Tier IV, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

/**
* @file ecu_monitor_base.h
* @brief ECU monitor base class
*/

#ifndef SYSTEM_MONITOR__ECU_MONITOR__ECU_MONITOR_BASE_HPP_
#define SYSTEM_MONITOR__MONITOR__ECU_MONITOR_BASE_HPP_

#include <diagnostic_updater/diagnostic_updater.hpp>

#include <climits>
#include <map>
#include <string>
#include <vector>

class ECUMonitorBase : public rclcpp::Node
{
public:
/**
* @brief Update the diagnostic state.
*/
void update();

protected:
using DiagStatus = diagnostic_msgs::msg::DiagnosticStatus;

/**
* @brief constructor
* @param [in] node_name Name of the node.
* @param [in] options Options associated with this node.
*/
ECUMonitorBase(const std::string & node_name, const rclcpp::NodeOptions & options);

diagnostic_updater::Updater updater_; //!< @brief Updater class which advertises to /diagnostics

char hostname_[HOST_NAME_MAX + 1]; //!< @brief host name
};

#endif // SYSTEM_MONITOR_ECU_MONITOR_ECU_MONITOR_BASE_HPP_
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
// Copyright 2020 Tier IV, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

/**
* @file unknown_ecu_monitor.h
* @brief Unknown ECU monitor class
*/

#ifndef SYSTEM_MONITOR_ECU_MONITOR__UNKNOWN_ECU_MONITOR_HPP_
#define SYSTEM_MONITOR__ECU_MONITOR__UNKNOWN_ECU_MONITOR_HPP_

#include "system_monitor/ecu_monitor/ecu_monitor_base.hpp"

#include <string>

class ECUMonitor : public ECUMonitorBase
{
public:
/**
* @brief constructor
* @param [in] node_name Name of the node.
* @param [in] options Options associated with this node.
*/
explicit ECUMonitor(const rclcpp::NodeOptions & options);

};

#endif // SYSTEM_MONITOR__ECU_MONITOR__UNKNOWN_ECU_MONITOR_HPP_
15 changes: 15 additions & 0 deletions system/system_monitor/launch/system_monitor.launch.py
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,16 @@ def launch_setup(context, *args, **kwargs):
gpu_monitor_config,
],
)
with open(LaunchConfiguration("ecu_monitor_config_file").perform(context), "r") as f:
ecu_monitor_config = yaml.safe_load(f)["/**"]["ros__parameters"]
ecu_monitor = ComposableNode(
package="system_monitor",
plugin="ECUMonitor",
name="ecu_monitor",
parameters=[
ecu_monitor_config,
],
)

# set container to run all required components in the same process
container = ComposableNodeContainer(
Expand All @@ -104,6 +114,7 @@ def launch_setup(context, *args, **kwargs):
package="rclcpp_components",
executable="component_container_mt",
composable_node_descriptions=[
ecu_monitor,
cpu_monitor,
hdd_monitor,
mem_monitor,
Expand Down Expand Up @@ -151,6 +162,10 @@ def generate_launch_description():
"gpu_monitor_config_file",
default_value=os.path.join(system_monitor_path, "gpu_monitor.param.yaml"),
),
DeclareLaunchArgument(
"ecu_monitor_config_file",
default_value=os.path.join(system_monitor_path, "ecu_monitor.param.yaml"),
),
OpaqueFunction(function=launch_setup),
]
)
4 changes: 4 additions & 0 deletions system/system_monitor/launch/system_monitor.launch.xml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
<arg name="ntp_monitor_config_file" default="$(find-pkg-share system_monitor)/config/ntp_monitor.param.yaml"/>
<arg name="process_monitor_config_file" default="$(find-pkg-share system_monitor)/config/process_monitor.param.yaml"/>
<arg name="gpu_monitor_config_file" default="$(find-pkg-share system_monitor)/config/gpu_monitor.param.yaml"/>
<arg name="ecu_monitor_config_file" default="$(find-pkg-share system_monitor)/config/ecu_monitor.param.yaml"/>

<group>
<node pkg="system_monitor" exec="cpu_monitor" name="cpu_monitor" output="log" respawn="true">
Expand All @@ -29,5 +30,8 @@
<node pkg="system_monitor" exec="gpu_monitor" name="gpu_monitor" output="log" respawn="true">
<param from="$(var gpu_monitor_config_file)"/>
</node>
<node pkg="system_monitor" exec="ecu_monitor" name="ecu_monitor" output="log" respawn="true">
<param from="$(var ecu_monitor_config_file)"/>
</node>
</group>
</launch>
105 changes: 105 additions & 0 deletions system/system_monitor/src/ecu_monitor/adlink_ecu_monitor.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,105 @@
// Copyright 2020 Autoware Foundation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

/**
* @file _cpu_monitor.cpp
* @brief CPU monitor class
*/

#include "system_monitor/ecu_monitor/adlink_ecu_monitor.hpp"

#include "system_monitor/system_monitor_utility.hpp"

#include <msr_reader/msr_reader.hpp>

#include <boost/algorithm/string.hpp>
#include <boost/archive/text_iarchive.hpp>
#include <boost/filesystem.hpp>
#include <boost/process.hpp>

#include <fmt/format.h>
#include <netinet/in.h>
#include <sys/socket.h>

#include <algorithm>
#include <regex>
#include <string>
#include <vector>
#include <regex>

namespace bp = boost::process;

ECUMonitor::ECUMonitor(const rclcpp::NodeOptions & options) : ECUMonitorBase("ecu_monitor", options)
{
voltage_warn_ = declare_parameter<float>("low cmos battery warn", 2.9);
voltage_error_ = declare_parameter<float>("low cmos battery error", 2.7);

updater_.add("ECU CMOS Battery Voltage", this, &ECUMonitor::checkVoltage);
gethostname(hostname_, sizeof(hostname_));
// Check if command exists
fs::path p = bp::search_path("sensors");
sensors_exists_ = (p.empty()) ? false : true;
}

static float getVoltage() {
bp::ipstream is_out;
bp::ipstream is_err;
fs::path p = bp::search_path("sensors");
bp::child c(p.string(), bp::std_out > is_out, bp::std_err > is_err);
c.wait();

if(RCUTILS_UNLIKELY(c.exit_code() != 0)) {//failed to execute sensors
return 0;
}
std::string line;
std::regex re(R"((\d+).(\d+))"); //in7: 3.06 V (min = +0.00 V, max = +4.08 V)
for(int i = 0; i < 200 && std::getline(is_out, line); i++) {
auto voltageStringPos = line.find("in7:");
if( voltageStringPos != std::string::npos) {
std::smatch match;
std::regex_search(line, match, re);
auto voltageString = match.str();
return std::stof(voltageString);
}
}
return 0;//failed to read voltage
}

void ECUMonitor::checkVoltage(diagnostic_updater::DiagnosticStatusWrapper & stat)
{
// Remember start time to measure elapsed time
const auto t_start = SystemMonitorUtility::startMeasurement();

if ( RCUTILS_UNLIKELY(!sensors_exists_) ) {
stat.summary(DiagStatus::ERROR, "sensors error");
stat.add(
"sensors", "Command 'sensors' not found, but can be installed with: 'sudo apt install lm-sensors' and 'sudo sensors-detect'");
return;
}

auto v = getVoltage();

stat.add("CMOS battey voltage", fmt::format("{}",v));
if( RCUTILS_UNLIKELY(v < voltage_warn_) ) {
stat.summary(DiagStatus::WARN, "LOW BATTERY");
} else {
stat.summary(DiagStatus::OK, "OK");
}

// Measure elapsed time since start time and report
SystemMonitorUtility::stopMeasurement(t_start, stat);
}

#include <rclcpp_components/register_node_macro.hpp>
RCLCPP_COMPONENTS_REGISTER_NODE(ECUMonitor)
Loading