Added display of hosts in the topology viewer and fixed a glitch in the host provider.
diff --git a/apps/tvue/src/main/java/org/onlab/onos/tvue/TopologyResource.java b/apps/tvue/src/main/java/org/onlab/onos/tvue/TopologyResource.java
index 4c9b581..992bbb3 100644
--- a/apps/tvue/src/main/java/org/onlab/onos/tvue/TopologyResource.java
+++ b/apps/tvue/src/main/java/org/onlab/onos/tvue/TopologyResource.java
@@ -5,6 +5,7 @@
 import com.fasterxml.jackson.databind.node.ObjectNode;
 import org.onlab.onos.net.ConnectPoint;
 import org.onlab.onos.net.ElementId;
+import org.onlab.onos.net.Host;
 import org.onlab.onos.net.Link;
 import org.onlab.onos.net.Path;
 import org.onlab.onos.net.device.DeviceService;
@@ -26,6 +27,7 @@
 import java.util.Set;
 
 import static org.onlab.onos.net.DeviceId.deviceId;
+import static org.onlab.onos.net.PortNumber.portNumber;
 
 /**
  * Topology viewer resource.
@@ -67,13 +69,10 @@
 
         // Merge the exterior and interior vertexes and inject host links as
         // the exterior edges.
-//        Iterator<Host> hosts = hostService.getHosts();
-//        while (hosts.hasNext()) {
-//            Host host = hosts.next();
-//            vertexesNode.add(json(mapper, host.id().ip().toString(), 3, true));
-//            edgesNode.add(json(mapper, 1, host.ip().toString(),
-//                               host.location().elementId().uri()));
-//        }
+        for (Host host : hostService.getHosts()) {
+            vertexesNode.add(json(mapper, host.id(), 3, true));
+            edgesNode.add(json(mapper, 1, host.location(), new ConnectPoint(host.id(), portNumber(-1))));
+        }
 
         // Now put the vertexes and edges into a root node and ship them off
         ObjectNode rootNode = mapper.createObjectNode();
diff --git a/core/trivial/src/main/java/org/onlab/onos/net/trivial/topology/impl/DefaultTopologyProvider.java b/core/trivial/src/main/java/org/onlab/onos/net/trivial/topology/impl/DefaultTopologyProvider.java
index 6b0e036..b6efba9 100644
--- a/core/trivial/src/main/java/org/onlab/onos/net/trivial/topology/impl/DefaultTopologyProvider.java
+++ b/core/trivial/src/main/java/org/onlab/onos/net/trivial/topology/impl/DefaultTopologyProvider.java
@@ -46,7 +46,8 @@
     private static final int MAX_BATCH_MS = 200;
     private static final int MAX_THREADS = 8;
 
-    // FIXME: Replace with a system-wide timer instance
+    // FIXME: Replace with a system-wide timer instance;
+    // TODO: Convert to use HashedWheelTimer or produce a variant of that; then decide which we want to adopt
     private static final Timer TIMER = new Timer();
 
     private final Logger log = getLogger(getClass());
diff --git a/providers/of/host/src/main/java/org/onlab/onos/provider/of/host/impl/OpenFlowHostProvider.java b/providers/of/host/src/main/java/org/onlab/onos/provider/of/host/impl/OpenFlowHostProvider.java
index 3f87be5..6c6a239 100644
--- a/providers/of/host/src/main/java/org/onlab/onos/provider/of/host/impl/OpenFlowHostProvider.java
+++ b/providers/of/host/src/main/java/org/onlab/onos/provider/of/host/impl/OpenFlowHostProvider.java
@@ -1,17 +1,14 @@
 package org.onlab.onos.provider.of.host.impl;
 
-import java.util.Set;
-
 import org.apache.felix.scr.annotations.Activate;
 import org.apache.felix.scr.annotations.Component;
 import org.apache.felix.scr.annotations.Deactivate;
 import org.apache.felix.scr.annotations.Reference;
 import org.apache.felix.scr.annotations.ReferenceCardinality;
-import org.onlab.onos.net.DeviceId;
+import org.onlab.onos.net.ConnectPoint;
 import org.onlab.onos.net.Host;
 import org.onlab.onos.net.HostId;
 import org.onlab.onos.net.HostLocation;
-import org.onlab.onos.net.PortNumber;
 import org.onlab.onos.net.host.DefaultHostDescription;
 import org.onlab.onos.net.host.HostDescription;
 import org.onlab.onos.net.host.HostProvider;
@@ -19,6 +16,8 @@
 import org.onlab.onos.net.host.HostProviderService;
 import org.onlab.onos.net.provider.AbstractProvider;
 import org.onlab.onos.net.provider.ProviderId;
+import org.onlab.onos.net.topology.Topology;
+import org.onlab.onos.net.topology.TopologyService;
 import org.onlab.onos.of.controller.Dpid;
 import org.onlab.onos.of.controller.OpenFlowController;
 import org.onlab.onos.of.controller.OpenFlowPacketContext;
@@ -29,8 +28,11 @@
 import org.onlab.packet.VLANID;
 import org.slf4j.Logger;
 
-import com.google.common.collect.Sets;
+import java.util.Set;
 
+import static com.google.common.collect.Sets.newHashSet;
+import static org.onlab.onos.net.DeviceId.deviceId;
+import static org.onlab.onos.net.PortNumber.portNumber;
 import static org.slf4j.LoggerFactory.getLogger;
 
 /**
@@ -48,6 +50,9 @@
     @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
     protected OpenFlowController controller;
 
+    @Reference(cardinality = ReferenceCardinality.MANDATORY_UNARY)
+    protected TopologyService topologyService;
+
     private HostProviderService providerService;
 
     private final InternalHostProvider listener = new InternalHostProvider();
@@ -87,25 +92,32 @@
         public void handlePacket(OpenFlowPacketContext pktCtx) {
             Ethernet eth = pktCtx.parsed();
 
-            // potentially a new or moved host
+            // Potentially a new or moved host
             if (eth.getEtherType() == Ethernet.TYPE_ARP) {
                 VLANID vlan = VLANID.vlanId(eth.getVlanID());
-                HostId hid = HostId.hostId(
-                        eth.getSourceMAC(), vlan);
-                HostLocation hloc = new HostLocation(
-                        DeviceId.deviceId(Dpid.uri(pktCtx.dpid())),
-                        PortNumber.portNumber(pktCtx.inPort()),
-                        System.currentTimeMillis());
+                ConnectPoint heardOn = new ConnectPoint(deviceId(Dpid.uri(pktCtx.dpid())),
+                                                        portNumber(pktCtx.inPort()));
+
+                // If this is not an edge port, bail out.
+                Topology topology = topologyService.currentTopology();
+                if (topologyService.isInfrastructure(topology, heardOn)) {
+                    return;
+                }
+
+                HostLocation hloc = new HostLocation(deviceId(Dpid.uri(pktCtx.dpid())),
+                                                     portNumber(pktCtx.inPort()),
+                                                     System.currentTimeMillis());
+
+                HostId hid = HostId.hostId(eth.getSourceMAC(), vlan);
                 ARP arp = (ARP) eth.getPayload();
-                Set<IPAddress> ips = Sets.newHashSet(IPAddress.valueOf(arp.getSenderProtocolAddress()));
-                HostDescription hdescr = new DefaultHostDescription(
-                        eth.getSourceMAC(),
-                        vlan,
-                        hloc,
-                        ips);
+                Set<IPAddress> ips = newHashSet(IPAddress.valueOf(arp.getSenderProtocolAddress()));
+                HostDescription hdescr =
+                        new DefaultHostDescription(eth.getSourceMAC(), vlan, hloc, ips);
                 providerService.hostDetected(hid, hdescr);
 
             }
+
+            // TODO: Use DHCP packets as well later...
         }
 
     }