blob: 8e0aba8a070218afda537b84eabee7e749d9767b [file] [log] [blame]
Shad Ansari01b0e652018-04-05 21:02:53 +00001/*
Girish Gowdraa707e7c2019-11-07 11:36:13 +05302 * Copyright 2018-present Open Networking Foundation
Shad Ansari01b0e652018-04-05 21:02:53 +00003
Girish Gowdraa707e7c2019-11-07 11:36:13 +05304 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
Shad Ansari01b0e652018-04-05 21:02:53 +00007
Girish Gowdraa707e7c2019-11-07 11:36:13 +05308 * http://www.apache.org/licenses/LICENSE-2.0
Shad Ansari01b0e652018-04-05 21:02:53 +00009
Girish Gowdraa707e7c2019-11-07 11:36:13 +053010 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
Shad Ansari01b0e652018-04-05 21:02:53 +000017#include <iostream>
Craig Lutgen88a22ad2018-10-04 12:30:46 -050018#include <unistd.h>
Shad Ansari01b0e652018-04-05 21:02:53 +000019
Shad Ansari01b0e652018-04-05 21:02:53 +000020#include "server.h"
Shad Ansarib7b0ced2018-05-11 21:53:32 +000021#include "core.h"
Humera Kouser6143c9e2020-06-17 22:37:31 +053022#include "src/core_data.h"
Shad Ansari01b0e652018-04-05 21:02:53 +000023
Humera Kouser5ac56612019-07-25 20:23:01 -040024using namespace std;
25
26/*
27* This function displays openolt version, BAL version, openolt build date
28* and other VCS params like VCS url, VCS ref, commit date and exits.
29*
30* @param argc : number of arguments
31* @param argv : vector of arguments
32*/
33void display_version_info(int argc, char *argv[]) {
34
35 string version = "";
36 string bal_version = "";
37 string label_vcs_url = "";
38 string label_vcs_ref = "";
39 string label_build_date = "";
40 string label_commit_date = "";
41
42 #ifdef VERSION
43 version = VERSION;
44 #endif
45
46 #ifdef BAL_VER
47 bal_version = BAL_VER;
48 #endif
49
50 #ifdef LABEL_VCS_URL
51 label_vcs_url = LABEL_VCS_URL;
52 #endif
53
54 #ifdef LABEL_VCS_REF
55 label_vcs_ref = LABEL_VCS_REF;
56 #endif
57
58 #ifdef LABEL_BUILD_DATE
59 label_build_date = LABEL_BUILD_DATE;
60 #endif
61
62 #ifdef LABEL_COMMIT_DATE
63 label_commit_date = LABEL_COMMIT_DATE;
64 #endif
65
66 for (int i = 1; i < argc; ++i) {
67 if(strcmp(argv[i], "--version") == 0 || (strcmp(argv[i], "-v") == 0)) {
Girish Gowdrab0337eb2022-03-25 16:44:21 -070068 cout << "OpenOLT agent: " << version << "\n";
69 cout << "BAL version: " << bal_version << "\n";
70 cout << "Label VCS Url: " << label_vcs_url << "\n";
71 cout << "Label VCS Ref: " << label_vcs_ref << "\n";
72 cout << "Label build date: " << label_build_date << "\n";
73 cout << "Label commit date: " << label_commit_date << "\n";
Humera Kouser5ac56612019-07-25 20:23:01 -040074 exit(0);
75 }
76 }
77}
78
Shad Ansari01b0e652018-04-05 21:02:53 +000079int main(int argc, char** argv) {
80
Humera Kouser5ac56612019-07-25 20:23:01 -040081 display_version_info(argc, argv);
82
Girish Gowdrab0337eb2022-03-25 16:44:21 -070083#ifdef DYNAMIC_PON_TRX_SUPPORT
84 auto sfp = ponTrx.read_sfp_presence_data();
85 if (sfp.size() == 0) {
86 perror("sfp presence map could not be read\n");
87 return 2;
88 }
89 for (const auto& it : sfp) {
90 bool res = ponTrx.read_eeprom_data_for_sfp(it);
91 if (!res) {
92 cerr << "eeprom data for sfp could not be read: " << it << endl;
93 return 2;
94 }
95 }
96 for (const auto &it : sfp) {
97 bool res = ponTrx.decode_eeprom_data(it);
98 if (!res) {
99 cerr << "eeprom data for sfp could not be decoded: " << it << endl;
100 return 2;
101 }
102 }
103#endif
Shad Ansari627b5782018-08-13 22:49:32 +0000104 Status status = Enable_(argc, argv);
Shad Ansari01b0e652018-04-05 21:02:53 +0000105 if (!status.ok()) {
Girish Gowdrab0337eb2022-03-25 16:44:21 -0700106 cout << "ERROR: Enable_ failed - "
Shad Ansari01b0e652018-04-05 21:02:53 +0000107 << status.error_code() << ": " << status.error_message()
Girish Gowdrab0337eb2022-03-25 16:44:21 -0700108 << endl;
Shad Ansari01b0e652018-04-05 21:02:53 +0000109 return 1;
110 }
111
Orhan Kupusoglu1fd77072021-03-23 08:13:25 -0700112 // Wait for successful activation before allowing VOLTHA to connect.
Craig Lutgen88a22ad2018-10-04 12:30:46 -0500113 // This is necessary to allow the device topology to be dynamically
114 // queried from driver after initialization and activation is complete.
115 int maxTrials = 300;
116 while (!state.is_activated()) {
117 sleep(1);
118 if (--maxTrials == 0) {
Girish Gowdrab0337eb2022-03-25 16:44:21 -0700119 cout << "ERROR: OLT/PON Activation failed" << endl;
Craig Lutgen88a22ad2018-10-04 12:30:46 -0500120 return 1;
121 }
122 }
123
Amit Ghoshfcad4d32019-11-13 10:24:55 +0000124 status = ProbeDeviceCapabilities_();
125 if (!status.ok()) {
Girish Gowdrab0337eb2022-03-25 16:44:21 -0700126 cout << "ERROR: Could not find the OLT Device capabilities" << endl;
Amit Ghoshfcad4d32019-11-13 10:24:55 +0000127 return 1;
128 }
129
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000130 sleep(2);
Orhan Kupusoglu1fd77072021-03-23 08:13:25 -0700131 // Enable all PON interfaces.
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000132 for (int i = 0; i < NumPonIf_(); i++) {
133 status = EnablePonIf_(i);
134 if (!status.ok()) {
135 // raise alarm to report error in enabling PON
Elia Battiston869a5de2022-02-08 11:40:58 +0100136 pushOltOperInd(i, "pon", "down", 0 /*Speed will be ignored in the adapter for PONs*/ );
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000137 }
138 else
Elia Battiston869a5de2022-02-08 11:40:58 +0100139 pushOltOperInd(i, "pon", "up", 0 /*Speed will be ignored in the adapter for PONs*/);
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000140 }
141 sleep(2);
142 // Enable all NNI interfaces.
143#if 0
144 for (int i = 0; i < NumNniIf_(); i++) {
145 status = EnableUplinkIf_(i);
146 if (!status.ok()) {
147 // raise alarm to report error in enabling PON
148 pushOltOperInd(i, "nni", "down");
149 }
150 else
151 pushOltOperInd(i, "nni", "up");
152 }
153#endif
154 //only for nni-65536 mapping to intf_id 0
Elia Battiston869a5de2022-02-08 11:40:58 +0100155 uint32_t nni_speed = GetNniSpeed_(0);
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000156 status = SetStateUplinkIf_(0, true);
157 if (!status.ok()) {
158 // raise alarm to report error in enabling NNI
Elia Battiston869a5de2022-02-08 11:40:58 +0100159 pushOltOperInd(0, "nni", "down", nni_speed);
Thiyagarajan Subramani89fffc02019-05-13 21:33:20 +0000160 }
Elia Battiston869a5de2022-02-08 11:40:58 +0100161 else{
162 pushOltOperInd(0, "nni", "up", nni_speed);
163 }
Humera Kouser6143c9e2020-06-17 22:37:31 +0530164
165 for (int i = 1; i < argc; ++i) {
166 if(strcmp(argv[i-1], "--interface") == 0 || (strcmp(argv[i-1], "--intf") == 0)) {
167 grpc_server_interface_name = argv[i];
168 break;
169 }
170 }
Orhan Kupusoglu1fd77072021-03-23 08:13:25 -0700171
172 if (!RunServer(argc, argv)) {
Girish Gowdrab0337eb2022-03-25 16:44:21 -0700173 cerr << "FATAL: gRPC server creation failed\n";
Orhan Kupusoglu1fd77072021-03-23 08:13:25 -0700174 return 2;
175 }
Shad Ansari01b0e652018-04-05 21:02:53 +0000176
Shad Ansari627b5782018-08-13 22:49:32 +0000177 return 0;
Shad Ansari01b0e652018-04-05 21:02:53 +0000178}