BSDL Files Library for JTAG

The only free public library that contains thousands of BSDL (Boundary Scan Description Language) models to use with BScan/JTAG tools

BSDL model: LM3S301 latest version

--//*****************************************************************************
--//
--// lm3s301_rc2_lqfp_v1p0.bsdl - Boundary Scan Description Language (BSDL) file
--//                for the Texas Instruments LM3S301 Stellaris microcontroller.
--//
--// Version 1.0    - 01/18/2010 - Initial Release of BSDL entity
--//                - LM3S301, Revision C2, 48-pin LQFP
--//
--//
--// Copyright (c) 2010 Texas Instruments, Inc.  All rights reserved.
--//
--// Software License Agreement
--//
--// Texas Instruments, Inc. (TI) is supplying this software for use solely and
--// exclusively on TI's Stellaris Family of microcontroller products.
--//
--// The software is owned by TI and/or its suppliers, and is protected under
--// applicable copyright laws.  All rights are reserved.  Any use in violation
--// of the foregoing restrictions may subject the user to criminal sanctions
--// under applicable laws, as well as to civil liability for the breach of the
--// terms and conditions of this license.
--//
--// THIS SOFTWARE IS PROVIDED "AS IS".  NO WARRANTIES, WHETHER EXPRESS, IMPLIED
--// OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
--// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
--// LMI SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR
--// CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
--//
--//*****************************************************************************


entity LM3S301 is generic (PHYSICAL_PIN_MAP : string := "LQFP_48");


port  ( ADC0:           linkage bit;
        ADC1:           linkage bit;
        ADC2:           linkage bit;
        GND:            linkage bit_vector(0 to 3);
        LDO:            linkage bit;
        OSC0:           linkage bit;
        OSC1:           linkage bit;
        PA0_U0Rx:       inout   bit;
        PA1_U0Tx:       inout   bit;
        PA2_SSIClk:     inout   bit;
        PA3_SSIFss:     inout   bit;
        PA4_SSIRx:      inout   bit;
        PA5_SSITx:      inout   bit;
        PB0_CCP0:       inout   bit;
        PB1:            inout   bit;
        PB2:            inout   bit;
        PB3:            inout   bit;
        PB4:            inout   bit;
        PB5:            inout   bit;
        PB6:            inout   bit;
        PC4:            inout   bit;
        PC5_C1o:        inout   bit;
        PC6:            inout   bit;
        PC7:            inout   bit;
        PD0_PWM0:       inout   bit;
        PD1_PWM1:       inout   bit;
        PD2:            inout   bit;
        PD3:            inout   bit;
        PD4:            inout   bit;
        PD5_CCP2:       inout   bit;
        PD6_Fault:      inout   bit;
        PD7_C0o:        inout   bit;
        PE0:            inout   bit;
        PE1:            inout   bit;
        PE2:            inout   bit;
        RST:            in      bit;
        TCK:            in      bit;
        TDI:            in      bit;
        TDO:            out     bit;
        TMS:            in      bit;
        TRST:           in      bit;
        VDD:            linkage bit_vector(0 to 3)
);


    use STD_1149_1_1994.all;   -- Get Std 1149.1-1994 attributes and definitions


    attribute COMPONENT_CONFORMANCE of LM3S301 : entity is "STD_1149_1_1993";


    attribute PIN_MAP               of LM3S301 : entity is PHYSICAL_PIN_MAP;


    constant LQFP_48: PIN_MAP_STRING := 
        "ADC0:             1, " &
        "ADC1:             2, " &
        "ADC2:             3, " &
        "PE2:              4, " &
        "RST:              5, " &
        "LDO:              6, " &
        "OSC0:             9, " &
        "OSC1:            10, " &
        "PC7:             11, " &
        "PC6:             12, " &
        "PC5_C1o:         13, " &
        "PC4:             14, " &
        "PA0_U0Rx:        17, " &
        "PA1_U0Tx:        18, " &
        "PA2_SSIClk:      19, " &
        "PA3_SSIFss:      20, " &
        "PA4_SSIRx:       21, " &
        "PA5_SSITx:       22, " &
        "PD0_PWM0:        25, " &
        "PD1_PWM1:        26, " &
        "PD2:             27, " &
        "PD3:             28, " &
        "PB0_CCP0:        29, " &
        "PB1:             30, " &
        "PB2:             33, " &
        "PB3:             34, " &
        "PE0:             35, " &
        "PE1:             36, " &
        "TDO:             37, " &
        "TDI:             38, " &
        "TMS:             39, " &
        "TCK:             40, " &
        "TRST:            41, " &
        "PB6:             42, " &
        "PB5:             43, " &
        "PB4:             44, " &
        "PD4:             45, " &
        "PD5_CCP2:        46, " &
        "PD6_Fault:       47, " &
        "PD7_C0o:         48, " &
        "GND:           (  8,  16,  24,  31 ), " &
        "VDD:           (  7,  15,  23,  32 ) " ;


    attribute TAP_SCAN_RESET of TRST  : signal is true;
    attribute TAP_SCAN_CLOCK of TCK   : signal is (10.0e6, BOTH);
    attribute TAP_SCAN_MODE  of TMS   : signal is true;
    attribute TAP_SCAN_IN    of TDI   : signal is true;
    attribute TAP_SCAN_OUT   of TDO   : signal is true; 


    attribute INSTRUCTION_LENGTH of LM3S301 : entity is 4;


    attribute INSTRUCTION_OPCODE of LM3S301 : entity is 
        "EXTEST (0000),"  &
        "INTEST (0001),"  &
        "SAMPLE (0010),"  &
        "BYPASS (0011),"  &
        "BYPASS (0100),"  &
        "BYPASS (0101),"  &
        "BYPASS (0110),"  &
        "BYPASS (0111),"  &
        "ABORT  (1000),"  &
        "BYPASS (1001),"  &
        "DPACC  (1010),"  &
        "APACC  (1011),"  &
        "BYPASS (1100),"  &
        "BYPASS (1101),"  &
        "IDCODE (1110),"  &
        "BYPASS (1111)";


    attribute INSTRUCTION_CAPTURE of LM3S301 : entity is "0001";


    attribute IDCODE_REGISTER     of LM3S301 : entity is
        "0010" &                    -- Version (Third Revision)
        "1011101000000000" &        -- Part number (ARM Cortex M3)
        "01000111011" &             -- Manufacturer Identity (ARM)
        "1";                        -- Mandatory LSB
                                    -- IDCODE = 2BA00477


    attribute INSTRUCTION_PRIVATE of LM3S301 : entity is
        "ABORT, DPACC, APACC";      -- ARM Debug Access Port Instructions


    attribute BOUNDARY_LENGTH     of LM3S301 : entity is 85;


    attribute BOUNDARY_REGISTER   of LM3S301 : entity is 
        --  num   cell  port            function  safe  [ ccell  disval  rslt ]
        --  ---   ----  --------------  --------  ----    ------ ------ ------ 
        "     0  (BC_1, *,              CONTROL,   1 ),                         " &
        "     1  (BC_1, PE1,            OUTPUT3,   X  ,      0,     1,     Z ), " &
        "     2  (BC_1, PE1,            INPUT,     X ),                         " &
        "     3  (BC_1, *,              CONTROL,   1 ),                         " &
        "     4  (BC_1, PE0,            OUTPUT3,   X  ,      3,     1,     Z ), " &
        "     5  (BC_1, PE0,            INPUT,     X ),                         " &
        "     6  (BC_1, *,              CONTROL,   1 ),                         " &
        "     7  (BC_1, PB3,            OUTPUT3,   X  ,      6,     1,     Z ), " &
        "     8  (BC_1, PB3,            INPUT,     X ),                         " &
        "     9  (BC_1, *,              CONTROL,   1 ),                         " &
        "    10  (BC_1, PB2,            OUTPUT3,   X  ,      9,     1,     Z ), " &
        "    11  (BC_1, PB2,            INPUT,     X ),                         " &
        "    12  (BC_1, *,              CONTROL,   1 ),                         " &
        "    13  (BC_1, PB1,            OUTPUT3,   X  ,     12,     1,     Z ), " &
        "    14  (BC_1, PB1,            INPUT,     X ),                         " &
        "    15  (BC_1, *,              CONTROL,   1 ),                         " &
        "    16  (BC_1, PB0_CCP0,       OUTPUT3,   X  ,     15,     1,     Z ), " &
        "    17  (BC_1, PB0_CCP0,       INPUT,     X ),                         " &
        "    18  (BC_1, *,              CONTROL,   1 ),                         " &
        "    19  (BC_1, PD3,            OUTPUT3,   X  ,     18,     1,     Z ), " &
        "    20  (BC_1, PD3,            INPUT,     X ),                         " &
        "    21  (BC_1, *,              CONTROL,   1 ),                         " &
        "    22  (BC_1, PD2,            OUTPUT3,   X  ,     21,     1,     Z ), " &
        "    23  (BC_1, PD2,            INPUT,     X ),                         " &
        "    24  (BC_1, *,              CONTROL,   1 ),                         " &
        "    25  (BC_1, PD1_PWM1,       OUTPUT3,   X  ,     24,     1,     Z ), " &
        "    26  (BC_1, PD1_PWM1,       INPUT,     X ),                         " &
        "    27  (BC_1, *,              CONTROL,   1 ),                         " &
        "    28  (BC_1, PD0_PWM0,       OUTPUT3,   X  ,     27,     1,     Z ), " &
        "    29  (BC_1, PD0_PWM0,       INPUT,     X ),                         " &
        "    30  (BC_1, *,              CONTROL,   1 ),                         " &
        "    31  (BC_1, PA5_SSITx,      OUTPUT3,   X  ,     30,     1,     Z ), " &
        "    32  (BC_1, PA5_SSITx,      INPUT,     X ),                         " &
        "    33  (BC_1, *,              CONTROL,   1 ),                         " &
        "    34  (BC_1, PA4_SSIRx,      OUTPUT3,   X  ,     33,     1,     Z ), " &
        "    35  (BC_1, PA4_SSIRx,      INPUT,     X ),                         " &
        "    36  (BC_1, *,              CONTROL,   1 ),                         " &
        "    37  (BC_1, PA3_SSIFss,     OUTPUT3,   X  ,     36,     1,     Z ), " &
        "    38  (BC_1, PA3_SSIFss,     INPUT,     X ),                         " &
        "    39  (BC_1, *,              CONTROL,   1 ),                         " &
        "    40  (BC_1, PA2_SSIClk,     OUTPUT3,   X  ,     39,     1,     Z ), " &
        "    41  (BC_1, PA2_SSIClk,     INPUT,     X ),                         " &
        "    42  (BC_1, *,              CONTROL,   1 ),                         " &
        "    43  (BC_1, PA1_U0Tx,       OUTPUT3,   X  ,     42,     1,     Z ), " &
        "    44  (BC_1, PA1_U0Tx,       INPUT,     X ),                         " &
        "    45  (BC_1, *,              CONTROL,   1 ),                         " &
        "    46  (BC_1, PA0_U0Rx,       OUTPUT3,   X  ,     45,     1,     Z ), " &
        "    47  (BC_1, PA0_U0Rx,       INPUT,     X ),                         " &
        "    48  (BC_1, *,              CONTROL,   1 ),                         " &
        "    49  (BC_1, PC4,            OUTPUT3,   X  ,     48,     1,     Z ), " &
        "    50  (BC_1, PC4,            INPUT,     X ),                         " &
        "    51  (BC_1, *,              CONTROL,   1 ),                         " &
        "    52  (BC_1, PC5_C1o,        OUTPUT3,   X  ,     51,     1,     Z ), " &
        "    53  (BC_1, PC5_C1o,        INPUT,     X ),                         " &
        "    54  (BC_1, *,              CONTROL,   1 ),                         " &
        "    55  (BC_1, PC6,            OUTPUT3,   X  ,     54,     1,     Z ), " &
        "    56  (BC_1, PC6,            INPUT,     X ),                         " &
        "    57  (BC_1, *,              CONTROL,   1 ),                         " &
        "    58  (BC_1, PC7,            OUTPUT3,   X  ,     57,     1,     Z ), " &
        "    59  (BC_1, PC7,            INPUT,     X ),                         " &
        "    60  (BC_4, RST,            CLOCK,     X ),                         " &
        "    61  (BC_1, *,              CONTROL,   1 ),                         " &
        "    62  (BC_1, PE2,            OUTPUT3,   X  ,     61,     1,     Z ), " &
        "    63  (BC_1, PE2,            INPUT,     X ),                         " &
        "    64  (BC_1, *,              CONTROL,   1 ),                         " &
        "    65  (BC_1, PD7_C0o,        OUTPUT3,   X  ,     64,     1,     Z ), " &
        "    66  (BC_1, PD7_C0o,        INPUT,     X ),                         " &
        "    67  (BC_1, *,              CONTROL,   1 ),                         " &
        "    68  (BC_1, PD6_Fault,      OUTPUT3,   X  ,     67,     1,     Z ), " &
        "    69  (BC_1, PD6_Fault,      INPUT,     X ),                         " &
        "    70  (BC_1, *,              CONTROL,   1 ),                         " &
        "    71  (BC_1, PD5_CCP2,       OUTPUT3,   X  ,     70,     1,     Z ), " &
        "    72  (BC_1, PD5_CCP2,       INPUT,     X ),                         " &
        "    73  (BC_1, *,              CONTROL,   1 ),                         " &
        "    74  (BC_1, PD4,            OUTPUT3,   X  ,     73,     1,     Z ), " &
        "    75  (BC_1, PD4,            INPUT,     X ),                         " &
        "    76  (BC_1, *,              CONTROL,   1 ),                         " &
        "    77  (BC_1, PB4,            OUTPUT3,   X  ,     76,     1,     Z ), " &
        "    78  (BC_1, PB4,            INPUT,     X ),                         " &
        "    79  (BC_1, *,              CONTROL,   1 ),                         " &
        "    80  (BC_1, PB5,            OUTPUT3,   X  ,     79,     1,     Z ), " &
        "    81  (BC_1, PB5,            INPUT,     X ),                         " &
        "    82  (BC_1, *,              CONTROL,   1 ),                         " &
        "    83  (BC_1, PB6,            OUTPUT3,   X  ,     82,     1,     Z ), " &
        "    84  (BC_1, PB6,            INPUT,     X )                          " ;


end LM3S301;