commit | 33d6a8e4e1be63022a1730c4949adcc041e456b3 | [log] [tgz] |
---|---|---|
author | lcui <lcui@cigtech.com> | Tue Aug 28 12:51:38 2018 -0700 |
committer | Lin Cui <lcui@cigtech.com> | Mon Nov 26 04:36:29 2018 +0000 |
tree | 1c6d2e31c9350adf4c8e7e17d62cd6df1a4a01aa | |
parent | 8d811fdb25d643344f7a97175055fb2dc4cad69f [diff] |
VOL-184 ONU software upgrade based on OpenOMCI framework ** Implement OMCI download software procedure with two state machine: 1. Software OMCI downloading state machine 2. Activate software image state machine, which includes OMCI software download and OMCI software activation 3. Add OMCI message/frames for Start/End/DownloadSection/ActiveImage/CommitImage ** Change OMCI_CC.send to support: 1. Send OMCI messages without waiting for response (Download Section) 2. Add timeout handler to support retry max 3 times on timeout 3. Add a clock(reactor) in contructor to support automation test with robotframwork RobotFramework use global reactor to loop run all test cases. It will conflict with the reactor in VOLTHA classes. The solution is to assign a reactor when create VOLTHA classes so that they will share the same reactor and make RobotFramework works. If reactor is not assigned VOLTHA classes will use default global reactor. So it is back-compitable and won't have impact on other code ** OMCI download/activate task are exclusive True to avoid blocking by OMCI PM/Alarm STM/tasks ** Log is detailed for debug at current stage; and will improve after functions are fully verified ** Add test cases based on RobotFramework 1. Test cases for Software download 2. Mock Adapter/Mock ONU are used in the test cases ** Implement relative commands: img_dnld_request img_dnld_status img_dnld_cancel img_activate Change-Id: I1796fd694f312378facbcd441bfc15ee7c093d91
Voltha aims to provide a layer of abstraction on top of legacy and next generation access network equipment for the purpose of control and management. Its initial focus is on PON (GPON, EPON, NG PON 2), but it aims to go beyond to eventually cover other access technologies (xDSL, Docsis, G.FAST, dedicated Ethernet, fixed wireless).
Key concepts of Voltha:
Control and management in the access network space is a mess. Each access technology brings its own bag of protocols, and on top of that vendors have their own interpretation/extension of the same standards. Compounding the problem is that these vendor- and technology specific differences ooze way up into the centralized OSS systems of the service provider, creating a lot of inefficiencies.
Ideally, all vendor equipment for the same access technology should provide an identical interface for control and management. Moreover, there shall be much higher synergies across technologies. While we wait for vendors to unite, Voltha provides an increment to that direction, by confining the differences to the locality of access and hiding them from the upper layers of the OSS stack.
While we are still at the early phase of development, you can check out the BUILD.md file to see how you can build it, run it, test it, etc.
Contributions, small and large, are welcome. Minor contributions and bug fixes are always welcome in form of pull requests. For larger work, the best is to check in with the existing developers to see where help is most needed and to make sure your solution is compatible with the general philosophy of Voltha.