Skip to content

Commit

Permalink
gNOI Warm Reboot - rebootbackend changes
Browse files Browse the repository at this point in the history
  • Loading branch information
rkavitha-hcl authored and Bibhuprasad Singh committed Jan 6, 2025
1 parent 47fc0f1 commit b2d84c8
Show file tree
Hide file tree
Showing 5 changed files with 38 additions and 73 deletions.
72 changes: 0 additions & 72 deletions src/sonic-framework/rebootbackend/gnoi_reboot_dbus.h

This file was deleted.

29 changes: 29 additions & 0 deletions src/sonic-framework/rebootbackend/reboot_thread.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -117,6 +117,8 @@ void RebootThread::do_reboot(void) {

if (m_request.method() == RebootMethod::COLD) {
do_cold_reboot(s);
} else if (m_request.method() == RebootMethod::WARM) {
do_warm_reboot(s);
} else {
// This shouldn't be possible. Reference check_start_preconditions()
SWSS_LOG_ERROR("Received unrecognized method type = %s",
Expand Down Expand Up @@ -166,6 +168,24 @@ void RebootThread::do_cold_reboot(swss::Select &s) {
return;
}

void RebootThread::do_warm_reboot(swss::Select &s) {
SWSS_LOG_ENTER();
SWSS_LOG_NOTICE("Sending warm reboot request to platform");
if (send_dbus_reboot_request() == Progress::EXIT_EARLY) {
return;
}

// Wait for warm reboot. If we return, reboot failed.
if (wait_for_platform_reboot(s) == Progress::EXIT_EARLY) {
return;
}

// We shouldn't be here. Platform reboot should've killed us.
log_error_and_set_non_retry_failure("failed to warm reboot");

return;
}

void RebootThread::reboot_thread(void) {
SWSS_LOG_ENTER();

Expand All @@ -187,6 +207,15 @@ bool RebootThread::check_start_preconditions(const RebootRequest &request,
request.method() != RebootMethod::WARM) {
response.json_string = "RebootThread: Start rx'd unsupported method";
response.status = swss::StatusCode::SWSS_RC_INVALID_PARAM;
} else if (request.method() == RebootMethod::WARM) {
if (m_status.get_last_reboot_status() ==
RebootStatus_Status::RebootStatus_Status_STATUS_FAILURE) {
// If the last reboot failed with a non-retriable failure, don't retry.
// But, we will allow a cold boot to recover.
response.json_string =
"RebootThread: last WARM reboot failed with non-retriable failure";
response.status = swss::StatusCode::SWSS_RC_FAILED_PRECONDITION;
}
} else if (request.delay() != 0) {
response.json_string = "RebootThread: delayed start not supported";
response.status = swss::StatusCode::SWSS_RC_INVALID_PARAM;
Expand Down
1 change: 1 addition & 0 deletions src/sonic-framework/rebootbackend/reboot_thread.h
Original file line number Diff line number Diff line change
Expand Up @@ -161,6 +161,7 @@ class RebootThread {
void do_reboot(void);
Progress send_dbus_reboot_request();
void do_cold_reboot(swss::Select &s);
void do_warm_reboot(swss::Select &s);

// Inner loop select handler to wait for platform reboot.
// wait for timeout
Expand Down
8 changes: 8 additions & 0 deletions src/sonic-framework/rebootbackend/rebootbe.cpp
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#include "rebootbe.h"

#include <google/protobuf/util/json_util.h>
#include <unistd.h>

Expand All @@ -13,6 +14,7 @@
#include "reboot_interfaces.h"
#include "select.h"
#include "status_code_util.h"
#include "warm_restart.h"

namespace rebootbackend {

Expand Down Expand Up @@ -46,6 +48,12 @@ void RebootBE::Start() {
s.addSelectable(&m_Done);
s.addSelectable(&m_RebootThreadFinished);

if (swss::WarmStart::isWarmStart()) {
SetCurrentStatus(RebManagerStatus::WARM_INIT_WAIT);
} else {
SWSS_LOG_NOTICE("Warm restart not enabled");
}

SWSS_LOG_NOTICE("RebootBE entering operational loop");
while (true) {
swss::Selectable *sel;
Expand Down
1 change: 0 additions & 1 deletion src/sonic-framework/tests/rebootbe_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -201,7 +201,6 @@ class RebootBEAutoStartTest : public RebootBETest,
public ::testing::WithParamInterface<bool> {
protected:
RebootBEAutoStartTest() {

start_rebootbe();

std::this_thread::sleep_for(std::chrono::milliseconds(50));
Expand Down

0 comments on commit b2d84c8

Please sign in to comment.