XlinxOptionsBlock.java 7.23 KB
Newer Older
1 2 3
/*******************************************************************************
 * Copyright (c) 2014 Elphel, Inc.
 * Copyright (c) 2006 Elphel, Inc and Excelsior, LLC.
4 5
 * This file is a part of VDT plug-in.
 * VDT plug-in is free software; you can redistribute it and/or modify
6 7 8 9
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
10
 * VDT plug-in is distributed in the hope that it will be useful,
11 12 13 14 15 16
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
Andrey Filippov's avatar
Andrey Filippov committed
17 18 19 20 21 22 23 24 25
 * 
 *  Additional permission under GNU GPL version 3 section 7:
 * If you modify this Program, or any covered work, by linking or combining it
 * with Eclipse or Eclipse plugins (or a modified version of those libraries),
 * containing parts covered by the terms of EPL/CPL, the licensors of this
 * Program grant you additional permission to convey the resulting work.
 * {Corresponding Source for a non-source form of such a combination shall
 * include the source code for the parts of Eclipse or Eclipse plugins used
 * as well as that of the covered work.}
26
 *******************************************************************************/
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159
package com.elphel.vdt.ui.options.project;


import org.eclipse.core.resources.IResource;
import org.eclipse.swt.SWT;
import org.eclipse.swt.layout.GridData;
import org.eclipse.swt.layout.GridLayout;
import org.eclipse.swt.widgets.Composite;
import org.eclipse.swt.widgets.Group;

import com.elphel.vdt.Txt;
import com.elphel.vdt.VDT;


/**
 * SWT component of Xilinx project option.
 * 
 * Created: 16.02.2006
 * @author  Lvov Konstantin
 */
public class XlinxOptionsBlock extends OptionsBlock {
        
    private ListOption deviceFamaly;
    private ListOption device;
    private ListOption devicePackage;
    private ListOption deviceSpeedGrade;
    
    private static final String[] DEVICE_FAMALY = new String[] {
                                                  "Automative Spartan2E"  // aspartan2e  
                                                , "Automative Spartan3"   // aspartan3         
                                                , "Spartan2"              // spartan2
                                                , "Spartan2E"             // spartan2e
                                                , "Spartan3"              // spartan3
                                                , "Spartan3E"             // spartan2e
                                                , "Virtex2"               // virtex2           
                                                , "Virtex2P"              // virtex2p 
                                                , "Virtex4"               // virtex4
                                                , "VirtexE"               // virtexe
                                                };
    private static final int DEFAULT_DEVICE_FAMALY = 4;

    private static final String[] DEVICE = new String[] {
                                           "xc3s50"        
                                         , "xc3s200"    
                                         , "xc3s400"    
                                         , "xc3s1000"    
                                         , "xc3s1000I"    
                                         , "xc3s1500"       
                                         , "xc3s1500I"       
                                         };
    private static final int DEFAULT_DEVICE = 3;
    
    private static final String[] DEVICE_PACKAGE = new String[] {
                                                   "fg320"        
                                                 , "fg456"    
                                                 , "fg676"       
                                                 , "ft256"       
                                                 };
    private static final int DEFAULT_DEVICE_PACKAGE = 3;

    private static final String[] DEVICE_SPEED_GRADE = new String[] {
                                                       "5"        
                                                     , "4"    
                                                     };
    private static final int DEFAULT_DEVICE_SPEED_GRADE = 1;
    
    public XlinxOptionsBlock(Composite parent, IResource resource) {
        super(resource, 4);
                
        Group panel = new Group(parent, SWT.NONE);
        GridLayout layout = new GridLayout(2, false);
        layout.numColumns = 3;
        panel.setLayout(layout);

        GridData data = new GridData(GridData.FILL_HORIZONTAL);
        panel.setLayoutData(data);
                
        panel.setText(Txt.s("Option.XlinxDevice.GroupCaption"));

        addDeviceFamaly(panel);
        addDevice(panel);
        addDevicePackage(panel);
        addDeviceSpeedGrade(panel);
        
        initializeFields();
    } // XlinxOptionsBlock()

    private void addDeviceFamaly(Composite parent) {
        createLabel(parent, Txt.s("Option.XlinxDevice.DeviceFamaly"));
        deviceFamaly = new ListOption( createCombo(parent)
                                     , VDT.OPTION_XLINX_DEVICE_FAMALY            
                                     , DEVICE_FAMALY
                                     , DEFAULT_DEVICE_FAMALY
                                     );
        addOption(deviceFamaly);
        createStab(parent);
    } // addDeviceFamaly()

    private void addDevice(Composite parent) {
        createLabel(parent, Txt.s("Option.XlinxDevice.Device"));
        device = new ListOption( createCombo(parent)
                               , VDT.OPTION_XLINX_DEVICE            
                               , DEVICE
                               , DEFAULT_DEVICE
                               );
        addOption(device);
        createStab(parent);
    } // addDevice()
    
    private void addDevicePackage(Composite parent) {
        createLabel(parent, Txt.s("Option.XlinxDevice.DevicePackage"));
        devicePackage = new ListOption( createCombo(parent)
                                      , VDT.OPTION_XLINX_DEVICE_PACKAGE            
                                      , DEVICE_PACKAGE
                                      , DEFAULT_DEVICE_PACKAGE
                                      );
        addOption(devicePackage);
        createStab(parent);
    } // addDevicePackage()

    private void addDeviceSpeedGrade(Composite parent) {
        createLabel(parent, Txt.s("Option.XlinxDevice.DeviceSpeedGrade"));
        deviceSpeedGrade = new ListOption( createCombo(parent)
                                         , VDT.OPTION_XLINX_DEVICE_SPEED_GRADE            
                                         , DEVICE_SPEED_GRADE
                                         , DEFAULT_DEVICE_SPEED_GRADE
                                         );
        addOption(deviceSpeedGrade);
        createStab(parent);
    } // addDeviceSpeedGrade()
    
    
} // class XlinxOptionsBlock