1# -*- mode:python -*- 2 3# Copyright (c) 2015 ARM Limited 4# All rights reserved. 5# 6# The license below extends only to copyright in the software and shall 7# not be construed as granting a license to any other intellectual 8# property including but not limited to intellectual property relating 9# to a hardware implementation of the functionality of the software 10# licensed hereunder. You may use the software subject to the license 11# terms below provided that you ensure that this notice is replicated 12# unmodified and in its entirety in all distributions of the software, 13# modified or unmodified, in source code or in binary form. 14# 15# Copyright (c) 2006 The Regents of The University of Michigan 16# All rights reserved. 17# 18# Redistribution and use in source and binary forms, with or without 19# modification, are permitted provided that the following conditions are 20# met: redistributions of source code must retain the above copyright 21# notice, this list of conditions and the following disclaimer; 22# redistributions in binary form must reproduce the above copyright 23# notice, this list of conditions and the following disclaimer in the 24# documentation and/or other materials provided with the distribution; 25# neither the name of the copyright holders nor the names of its 26# contributors may be used to endorse or promote products derived from 27# this software without specific prior written permission. 28# 29# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 30# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 31# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 32# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 33# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 34# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 35# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 36# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 37# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 38# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 39# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 40# 41# Authors: Steve Reinhardt 42# Gabe Black 43# Andreas Sandberg 44 45Import('*') 46 47SimObject('Ethernet.py') 48 49# Basic Ethernet infrastructure 50Source('etherbus.cc') 51Source('etherswitch.cc') 52Source('etherdevice.cc') 53Source('etherdump.cc') 54Source('etherint.cc') 55Source('etherlink.cc') 56Source('etherpkt.cc') 57Source('ethertap.cc') 58 59Source('pktfifo.cc') 60 61DebugFlag('Ethernet') 62DebugFlag('EthernetCksum') 63DebugFlag('EthernetDMA') 64DebugFlag('EthernetData') 65DebugFlag('EthernetDesc') 66DebugFlag('EthernetEEPROM') 67DebugFlag('EthernetIntr') 68DebugFlag('EthernetPIO') 69DebugFlag('EthernetSM') 70 71# Dist gem5 72Source('dist_iface.cc') 73Source('dist_etherlink.cc') 74Source('tcp_iface.cc') 75 76DebugFlag('DistEthernet') 77DebugFlag('DistEthernetPkt') 78DebugFlag('DistEthernetCmd') 79 80# Ethernet controllers 81Source('i8254xGBe.cc') 82Source('ns_gige.cc') 83Source('sinic.cc') 84 85 86 87CompoundFlag('EthernetAll', [ 'Ethernet', 'EthernetPIO', 'EthernetDMA', 88 'EthernetData' , 'EthernetDesc', 'EthernetIntr', 'EthernetSM', 89 'EthernetCksum', 'EthernetEEPROM' ]) 90 91CompoundFlag('EthernetNoData', [ 'Ethernet', 'EthernetPIO', 'EthernetDesc', 92 'EthernetIntr', 'EthernetSM', 'EthernetCksum' ]) 93