1    /*
     2     *  Copyright (c) 2011 by Texas Instruments and others.
     3     *  All rights reserved. This program and the accompanying materials
     4     *  are made available under the terms of the Eclipse Public License v1.0
     5     *  which accompanies this distribution, and is available at
     6     *  http://www.eclipse.org/legal/epl-v10.html
     7     *
     8     *  Contributors:
     9     *      Texas Instruments - initial implementation
    10     *
    11     * */
    12    
    13    /*
    14     *  ======== Platform.xdc ========
    15     */
    16    
    17    package ti.platforms.simDucati;
    18    
    19    /*!
    20     *  ======== Platform ========
    21     *  Simulation-based Platform support for TI Arm (470x) platforms
    22     *
    23     *  This module implements xdc.platform.IPlatform and defines configuration
    24     *  parameters that correspond to this platform's Cpu's, Board's, etc.
    25     *
    26     *  The configuration parameters are initialized in this package's
    27     *  configuration script (package.cfg) and "bound" to the TCOM object
    28     *  model.  Once they are part of the model, these parameters are
    29     *  queried by a program's configuration script.
    30     *
    31     *  This particular platform has a single Cpu, and therefore, only
    32     *  declares a single CPU configuration object.  Multi-CPU platforms
    33     *  would declare multiple Cpu configuration parameters (one per
    34     *  platform CPU).
    35     */
    36    metaonly module Platform inherits xdc.platform.IPlatform
    37    {
    38        /*!
    39         *  ======== BOARD ========
    40         *  This platform's board attributes
    41         */
    42        readonly config xdc.platform.IPlatform.Board BOARD = {
    43            id:             "0",
    44            boardName:      "simDucati",
    45            boardFamily:    "simDucati",
    46            boardRevision:  null
    47        };
    48    
    49        /*!
    50         *  ======== CPU ========
    51         *  The CPU simulated by this platform.
    52         *
    53         *  The device simulated is determined by the platform instance name
    54         *  or if this does not name a ti.catalog.arm module, then we
    55         *  we simulate a TMS470.
    56         */
    57        readonly config xdc.platform.IExeContext.Cpu CPU = {        
    58            id:             "0",
    59            clockRate:      200.0,
    60            catalogName:    "ti.catalog.arm.nda",
    61            deviceName:     "Ducati",
    62            revision:       "1.0",
    63        };
    64    
    65    instance:
    66    
    67        /*!
    68         *  ======== externalMemoryMap ========
    69         *  Memory regions as defined in the Ducati Functional Specification
    70         */
    71    
    72        override readonly config xdc.platform.IPlatform.Memory
    73            externalMemoryMap[string] = [
    74    
    75                ["EXT_RAM", {
    76                    comment: "External RAM",
    77                    name: "EXT_RAM",
    78                    base: 0x80000000, 
    79                    len:  0x20000000
    80                }],
    81    
    82            ];
    83    
    84        override config string codeMemory = "EXT_RAM";
    85        override config string dataMemory = "EXT_RAM";
    86        override config string stackMemory = "EXT_RAM";
    87    };
    88    /*
    89     *  @(#) ti.platforms.simDucati; 1, 0, 1, 0,125; 4-26-2011 10:56:10; /db/ztree/library/trees/platform/platform-m16x/src/
    90     */
    91