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 KAVITHA RAMALINGAM committed Nov 15, 2024
1 parent fde27b3 commit ba55f24
Show file tree
Hide file tree
Showing 6 changed files with 61 additions and 36 deletions.
32 changes: 30 additions & 2 deletions src/sonic-framework/rebootbackend/reboot_thread.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -115,6 +115,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 @@ -161,11 +163,28 @@ void RebootThread::do_cold_reboot(swss::Select &s) {
// We shouldn't be here. Platform reboot should've killed us.
log_error_and_set_non_retry_failure("platform failed to reboot");

// Set critical state
//m_critical_interface.report_critical_state("platform failed to reboot");
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 @@ -188,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 @@ -165,6 +165,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
Expand Up @@ -53,6 +53,14 @@ void RebootBE::Start() {
s.addSelectable(&m_done);
s.addSelectable(&m_reboot_thread_finished);


if (swss::WarmStart::isWarmStart()) {
SWSS_LOG_NOTICE("Launching init thread for warm start");
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
13 changes: 13 additions & 0 deletions src/sonic-framework/rebootbackend/redis_utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -77,4 +77,17 @@ bool get_docker_app_from_key(const std::string &key,
return true;
}

void set_warm_restart_counter(swss::DBConnector &db, int count) {
swss::Table table(&db, "BOOT_INFO");
table.hset("system", "warmboot-count", std::to_string(count));
}

std::string get_warm_restart_counter(swss::DBConnector &db) {
swss::Table warmRestartTable(&db, "BOOT_INFO");
std::string counter;
warmRestartTable.hget("system", "warmboot-count", counter);
return counter;
}


} // namespace rebootbackend
9 changes: 9 additions & 0 deletions src/sonic-framework/rebootbackend/redis_utils.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,5 +36,14 @@ bool is_valid_key(const std::string &key, const std::string &separator);
bool get_docker_app_from_key(const std::string &key,
const std::string &separator, std::string &docker,
std::string &app);
// Sets the warm restart count in the database.
void set_warm_restart_counter(swss::DBConnector &db, int count);

// Returns the current warm restart count from the database. Returns an empty
// string if the warm restart count is not set, and a string representation
// of an integer otherwise.
std::string get_warm_restart_counter(swss::DBConnector &db);



} // namespace rebootbackend
34 changes: 0 additions & 34 deletions src/sonic-framework/tests/rebootbe_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,6 @@ class RebootBETestWithoutStop : public ::testing::Test {
m_rebootbeReponseChannel(&m_db, REBOOT_RESPONSE_NOTIFICATION_CHANNEL),
m_rebootbe(m_dbus_interface) {
sigterm_requested = false;
// TestUtils::clear_tables(m_db);


m_s.addSelectable(&m_rebootbeReponseChannel);
Expand All @@ -75,21 +74,6 @@ class RebootBETestWithoutStop : public ::testing::Test {
}
virtual ~RebootBETestWithoutStop() = default;

gnoi::system::RebootStatusResponse default_not_started_status() {
InitThreadStatus status;
return status.get_response();
}

gnoi::system::RebootStatusResponse default_done_status() {
InitThreadStatus status;
// We can't edit the status without it being active.
status.set_start_status();
status.set_success();
status.set_inactive();
return status.get_response();
}


void start_rebootbe() {
m_rebootbe_thread =
std::make_unique<std::thread>(&RebootBE::Start, &m_rebootbe);
Expand Down Expand Up @@ -227,26 +211,8 @@ class RebootBEAutoStartTest : public RebootBETest,
RebootBEAutoStartTest() {
//force_warm_start_state(GetParam());

/* if (GetParam()) {
EXPECT_CALL(*m_init_thread, Start())
.WillOnce(Return(swss::StatusCode::SWSS_RC_SUCCESS));
EXPECT_CALL(*m_init_thread, Join()).WillOnce(Return(true));
EXPECT_CALL(*m_init_thread, GetResponse())
.WillOnce(Return(default_running_status()))
.WillRepeatedly(Return(default_done_status()));
} else {
EXPECT_CALL(*m_init_thread, GetResponse())
.WillRepeatedly(Return(default_not_started_status()));
} */

start_rebootbe();

/* if (GetParam()) {
get_stack_unfrozen_select().notify();
std::this_thread::sleep_for(std::chrono::milliseconds(50));
get_init_done_select().notify();
} */

std::this_thread::sleep_for(std::chrono::milliseconds(50));
EXPECT_EQ(m_rebootbe.GetCurrentStatus(), RebootBE::RebManagerStatus::IDLE);
}
Expand Down

0 comments on commit ba55f24

Please sign in to comment.