commit | 70806029dde40320545f79ff9cfbe68900f634ff | [log] [tgz] |
---|---|---|
author | Charles Chan <rascov@gmail.com> | Mon Jun 18 14:42:17 2018 -0700 |
committer | Charles Chan <charles@opennetworking.org> | Wed Jun 20 23:18:05 2018 +0000 |
tree | c2e3f6d7e338453655e45f0c24c9d0b0c73cf5fc | |
parent | 314b1f75fb1ac48f3bf39233287db466b172daa7 [diff] |
Fix ConcurrentModificationException Change-Id: Ie4c3a56312156ded1cbc2fd8a0e4da822ff57205
diff --git a/apps/segmentrouting/app/src/main/java/org/onosproject/segmentrouting/config/DeviceConfiguration.java b/apps/segmentrouting/app/src/main/java/org/onosproject/segmentrouting/config/DeviceConfiguration.java index 626109a..704db9a 100644 --- a/apps/segmentrouting/app/src/main/java/org/onosproject/segmentrouting/config/DeviceConfiguration.java +++ b/apps/segmentrouting/app/src/main/java/org/onosproject/segmentrouting/config/DeviceConfiguration.java
@@ -463,9 +463,12 @@ */ public Set<IpPrefix> getSubnets(DeviceId deviceId) { SegmentRouterInfo srinfo = deviceConfigMap.get(deviceId); - if (srinfo != null) { + if (srinfo != null && srinfo.subnets != null) { + // Note: ImmutableSet.Builder.addAll calls the iterator of parameter internally, + // which is not protected by SynchronizedCollection mutex. ImmutableSet.Builder<IpPrefix> builder = ImmutableSet.builder(); - return builder.addAll(srinfo.subnets.values()).build(); + srinfo.subnets.forEach((k, v) -> builder.add(v)); + return builder.build(); } return null; }