Initial import of Microsemi Driver
Change-Id: I431d5f2c18e0b66a84c36273c3d9f0b84f223841
Added in BUCK files for building driver
Change-Id: I70681327f5b89f67e904c45d5974ab393652d51f
Corrected some syntax errors
Change-Id: I11150cc499c212005f80619e3900e747f1c23d96
Updated pom file to clean build
Change-Id: I6613ddc9e6802aa882e716cf04df210249870835
Added in utility functions for EA1000 Init
Change-Id: I51ffe0cf0daf9ffcea0e2479ee9982fcd1755440
Added YMS code to Microsemi Driver
Change-Id: I6f2a14e454c6909bf9e9f6025321c74c98c13c72
Updated driver to work with YMS and YCH
Change-Id: If7dbe3cd5bd1b6f902d09d6b2dc3895605d70f70
Implemented IetfSystemManager as a service and call on YMS as a service
Change-Id: If1c5e8482b1f53f578a3b0b770accd50024111cf
Moved YMS calls over in to Yang Service implementation
Change-Id: I044aad06f1ef7452bc48e88987787a683666cd72
improved unit test for IetfSystemManager
Change-Id: I48fbf831e7e5ca0e1ef3de8288e56da1b5ebb7a4
Major changes to IetfSystemManager to work in live system
Change-Id: I6e3aa118ba422151f314b9a666860d90905c9929
Added in retry mechanism for DeviceDescription to wait for YCH
Change-Id: If8e0f2c2f315ffd6db15627a11382a00217dd262
Added in implementation of MseaSaFiltering and unit tests
Change-Id: I34bf888e0e732bd4664d1fb8ef5abb679b1506fe
Updated driver with unit tests for MseaSaFiltering
Change-Id: I7ea2407a546622ff55d1ab21610c45697546d632
Modified removeFlowRules of Ea1000FlowRuleProgrammable
Change-Id: Ibb4a555f61887a8e6e42af588bb42f7b70f58efb
Added in manager for MseaUniEvc service with unit tests
Change-Id: Idc5853f46051548973f52a0659f7f88982ff960c
Implemented getFlowEntries() for EVCs from EA1000
Change-Id: Ie85dadfa7760f0b30a9bdf6ccd09cca9f097fff9
Added in translation of FlowRules in to EVC on EA1000
Change-Id: Icfb65171c3300c96b3ca4e18cbd327f0ed2190be
Added in handling of FlowRule deletion including complex ceVlanMaps
Change-Id: I7fd0bb0ef04d1b40e4b7d6a6db7f7ee662329780
Updated Service entries for new onos-yang-tools
Change-Id: I44e655202f3a45073e1e16f83737caed6e01afa8
Revert "Updated Service entries for new onos-yang-tools"
This reverts commit 642b550ef1de12ed59bad2eaa3a2da414d2e5e59.
Improved timeout mechanism for YANG model loading
Change-Id: If744ecd206372e822edf2b736c83226321a12256
Minor edits of EVC creation
Change-Id: Ib0a4763deaf6dce37625ba77f5095b39cd98272d
Added in CustomEvc and supporting classes
Change-Id: Iad60eb1bcd48d2aec55b894b2d419b51852c3b2f
Created CeVlanUtils to resolve loading problem
Change-Id: I0d63931ad2c5ad2725861ebc7dccc4d5fe7b9298
Modified startup check
Change-Id: I6e6bcfa7e615044cb08fe7ee2f8a6c8b89aabb21
Modified handlin of flow rules
Change-Id: I965a79c23298866122aeb94c6d9d584aafee3bd5
Fixed problem with ceVlanMap
Change-Id: If1458c35d0b95b5b25b6636f098292f9e91c06c6
Minor Pom edits
Change-Id: I5cefb18674aa04b1f50bd7e2306260c1c3ad3814
Commented out extension references in YANG files to avoid onos-yang-tools problems
Change-Id: I32fdb34c4f476f495fe28e75d0f410aaf14e2ec1
Corrected error in removing 0 in CeVlanMapUtils
Change-Id: I8cd1fd02788b81c2613364d5639ef6e090057f80
Changes in YMS to accomodate EA1000 driver
Change-Id: I6ae2b9bd2be49eae8d4ad2f929dfe3214c514550
diff --git a/drivers/microsemi/ea1000yang/src/main/yang/msea-sa-filtering.yang b/drivers/microsemi/ea1000yang/src/main/yang/msea-sa-filtering.yang
new file mode 100644
index 0000000..72534a9
--- /dev/null
+++ b/drivers/microsemi/ea1000yang/src/main/yang/msea-sa-filtering.yang
@@ -0,0 +1,149 @@
+module msea-sa-filtering {
+
+ /*** NAMESPACE / PREFIX DEFINITION ***/
+
+ namespace "http://www.microsemi.com/microsemi-edge-assure/msea-sa-filtering";
+ prefix "msea-saf";
+
+ import ietf-inet-types {
+ prefix inet;
+ revision-date 2013-07-15;
+ }
+
+ import msea-types {
+ prefix msea;
+ revision-date 2016-02-29;
+ }
+
+ /*** META INFORMATION ***/
+
+ organization
+ "Microsemi Inc., FTD Division";
+
+ contact
+ "Web URL: http://www.microsemi.com/
+ E-mail: info@microsemi.com
+ Postal: Microsemi Corporation Corporate Headquarters
+ One Enterprise Aliso Viejo,
+ CA 92656
+ U.S.A.
+ Phone: +1 949 380 6100
+ Fax: +1 949 215-4996";
+
+ description
+ "This YANG module add Source Address Filtering for IPv4 packets to
+ the Optics(eth0) port (only) of the Edge Assure device.
+
+ Copyright 2016 Microsemi Inc.
+ All rights reserved.";
+
+ revision "2016-04-12" {
+ description
+ "Initial version - Sean Condon, Microsemi";
+ }
+
+
+ container source-ipaddress-filtering {
+ presence "Supports IPv4 Source Address Filtering";
+
+ container interface-eth0 {
+
+ leaf filter-admin-state {
+ type enumeration {
+ enum inactive {
+ description "Source address filtering is inactive";
+ }
+ enum whitelist {
+ description "Only IPv4 packets from the source
+ address ranges are allowed in to the device on the
+ Optics(eth0) port. All non IPv4 packets are not
+ filtered by this whitelist";
+ }
+ enum blacklist {
+ description "All IPv4 packets from the source
+ address ranges are blocked from entering the device
+ on the Optics(eth0) port. All other packets are not
+ filtered by this blacklist";
+ }
+ }
+ default inactive;
+ description "This attribute sets the address range to be used as
+ either a whitelist or a blacklist of IPv4 packets.
+ When activating the filter the user should be careful not to
+ block or exclude the management IP address of the manager";
+ }
+
+ list source-address-range {
+ key range-id;
+ max-elements 10;
+ unique ipv4-address-prefix;
+ unique name;
+
+ leaf range-id {
+ type uint8 {
+ range "1..10";
+ }
+ }
+
+ leaf name {
+ type string{
+ length "1..45";
+ }
+ description "An optional name for the filter range";
+ }
+
+ leaf ipv4-address-prefix {
+ type string {
+ pattern
+ '(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.){3}'
+ + '([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
+ + '/(([1-9])|(1[0-9])|(2[0-7]))';
+ }
+
+ mandatory true;
+// msea:not-changeable;
+
+ description
+ "The ipv4-address-prefix type represents an IPv4 address prefix
+ in CIDR notation format. e.g. a.b.c.d/n
+
+ It consists of an address part and a mask length part.
+ The address part is only used up to the number of bits
+ specified in the length (1-27, given after the slash).
+
+ For example the value 10.10.159.211/20 will mean an
+ effective range from 10.10.144.0 - 10.10.159.255 and
+ a count of 2^12 = 4096. The last 12 bits (32-20=12)
+ of the address is ignored because it is not within the
+ mask length.";
+ }
+
+
+ container effective-address-range {
+ config false;
+
+ leaf start-of-range {
+ type inet:ipv4-address-no-zone;
+ description "The calculated start of the address range";
+ }
+
+ leaf end-of-range {
+ type inet:ipv4-address-no-zone;
+ description "The calculated end of the address range";
+ }
+
+ leaf count {
+ type uint32;
+ description "The number of IPv4 addresses that match the filter";
+ }
+
+ description "The effective start and end addresses calculated
+ from the ipv4-address-prefix";
+ }
+
+ description "A set of address ranges to be either blacklisted or
+ whitelisted on ingress to the eth0(Optics) port of the device";
+ }
+ }
+ }
+}
\ No newline at end of file