OpenCores
URL https://opencores.org/ocsvn/w11/w11/trunk

Subversion Repositories w11

[/] [w11/] [tags/] [w11a_V0.61/] [tools/] [fx2/] [src/] [dscr_gen.A51] - Rev 26

Compare with Previous | Blame | View Log

;;; -*- asm -*-
;;; $Id: dscr_gen.A51 457 2012-02-12 22:34:20Z mueller $ 
;;;
;;; Copyright 2011-2012 by Walter F.J. Mueller <W.F.J.Mueller@gsi.de>
;;; Code was forked from ixo-jtag.svn.sourceforge.net on 2011-07-17
;;;
;;;- original copyright and licence disclaimer ---------------------------------
;;;- Copyright 2005..2007 Kolja Waschk, ixo.de
;;;- Code based on USRP2 firmware (GNU Radio Project), version 3.0.2,
;;;- Copyright 2003 Free Software Foundation, Inc.
;;;- This code is part of usbjtag. usbjtag is free software;
;;;- ---------------------------------------------------------------------------
;;;
;;; This program is free software; you may redistribute and/or modify it under
;;; the terms of the GNU General Public License as published by the Free
;;; Software Foundation, either version 2, or at your option any later version.
;;;
;;; This program is distributed in the hope that it will be useful, but
;;; WITHOUT ANY WARRANTY, without even the implied warranty of MERCHANTABILITY
;;; or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
;;; for complete details.
;;; 
;;;-----------------------------------------------------------------------------
;;; USB Descriptor, common source for jtag + 0, 2, or 3 hardware fifo interface
;;; 
;;; Use C preprocessor to create an assembler source for the configurations:
;;;
;;;   Endpoint   Usage   Comment    
;;;   EP1 IN     jtag    always defined
;;;   EP2 OUT    jtag    always defined
;;;   EP4 OUT    data    defined if USE_2FIFO or USE_3FIFO
;;;   EP6 IN     data    defined if USE_2FIFO or USE_3FIFO
;;;   EP8 IN     data    defined if USE_3FIFO
;;; 
;;; Available preprocessor options
;;; 
;;;   USE_VID            USB Vendor ID
;;;   USE_PID            USB Product ID
;;; 
;;;   USE_2FIFO          if given EP4 OUT and EP6 IN created
;;;   USE_3FIFO          if given EP4 OUT, EP6 IN and EP8 IN created
;;;   USE_DID=0xhhhh     for product version (default 0x0004)
;;;   USE_MAXPOWER=nnn   for USB max current (in units of 2 mA; default 250)
;;; 
;;;   USE_NEXYS2         prefix 'nexys2_' in iProduct string
;;;   USE_NEXYS3         prefix 'nexys3_' in iProduct string
;;;   USE_AS             suffix '_as' in iProduct string
;;;   USE_IC             suffix '_ic' in iProduct string
;;; 
;;; Usage
;;;   cpp -P -x assembler-with-cpp dscr_gen.A51             > ... 
;;;   cpp -P -x assembler-with-cpp dscr_gen.A51 -DUSE_2FIFO > ...
;;;   cpp -P -x assembler-with-cpp dscr_gen.A51 -DUSE_3FIFO > ...
;;; 
;;; 
;;; Revision History:
;;;
;;; Date         Rev Version  Comment
;;; 2012-02-11   457   2.1    iVendor string now reflects firmware file name;
;;;                           iSerial string now 00000000;
;;;                           VID/PID now via USE_VID/USE_PID defines
;;; 2011-07-24   398   2.0    Convert all *.a51 to one common source
;;; 2011-07-17   395   1.1    Use USB 2.0; New string values; use 512 byte for
;;;                           all high speed endpoints
;;; 2011-07-17   395   1.0    Initial version (derived from dscr_jtag.a51)
;;;-----------------------------------------------------------------------------

#ifndef USE_DID
#define USE_DID  0x0004
#endif

#ifndef USE_MAXPOWER
#define USE_MAXPOWER  250
#endif

#ifdef  USE_3FIFO
#define NUM_EPS 5
#elif   USE_2FIFO
#define NUM_EPS 4
#else
#define NUM_EPS 2
#endif

        .module usb_descriptors

        VID              = USE_VID    ; Vendor ID  
        PID              = USE_PID    ; Product ID 
        VERSION          = USE_DID    ; Version  
        
        USB_VER          = 0x0200     ; Support USB version 2.00
        USB_ATTR         = 0x80       ; Bus powered, no remote wakeup
        FTD_ATTR         = 0x001C     ; Set USB version, use version string, enable suspend PD
        MAX_POWER        = USE_MAXPOWER

        DSCR_DEVICE      =   1        ; Descriptor type: Device
        DSCR_CONFIG      =   2        ; Descriptor type: Configuration
        DSCR_STRING      =   3        ; Descriptor type: String
        DSCR_INTRFC      =   4        ; Descriptor type: Interface
        DSCR_ENDPNT      =   5        ; Descriptor type: Endpoint
        DSCR_DEVQUAL     =   6        ; Descriptor type: Device Qualifier
        
        DSCR_DEVICE_LEN  =  18
        DSCR_CONFIG_LEN  =   9
        DSCR_INTRFC_LEN  =   9
        DSCR_ENDPNT_LEN  =   7
        DSCR_DEVQUAL_LEN =  10
        
        ET_CONTROL       =   0        ; Endpoint type: Control
        ET_ISO           =   1        ; Endpoint type: Isochronous
        ET_BULK          =   2        ; Endpoint type: Bulk
        ET_INT           =   3        ; Endpoint type: Interrupt
        
;;; --------------------------------------------------------
;;;        external ram data
;;;--------------------------------------------------------
        
        .area USBDESCSEG    (XDATA)
       
        .even      ; descriptors must be 2-byte aligned for SUDPTR{H,L} to work

        ;; The .even directive isn't really honored by the linker.  Bummer!
        ;; (There's no way to specify an alignment requirement for a given area,
        ;; hence when they're concatenated together, even doesn't work.)
        ;; 
        ;; We work around this by telling the linker to put USBDESCSEG
        ;; at absolute address 0xE100 (see LDFLAGS in Makefile).

;;; ----------------------------------------------------------------
;;; descriptors used when operating at high speed (480Mbps)
;;; ----------------------------------------------------------------
         
_high_speed_device_descr::
        .db        DSCR_DEVICE_LEN
        .db        DSCR_DEVICE
_dscr_usbver::
        .db        <USB_VER         ; Specification version (LSB)
        .db        >USB_VER         ; Specification version (MSB)
        .db        0x00             ; device class (vendor specific)
        .db        0x00             ; device subclass (vendor specific)
        .db        0x00             ; device protocol (vendor specific)
        .db        64               ; bMaxPacketSize0 for endpoint 0
_dscr_vidpidver::
        .db        <VID             ; idVendor
        .db        >VID             ; idVendor
        .db        <PID             ; idProduct
        .db        >PID             ; idProduct
        .db        <VERSION         ; bcdDevice
        .db        >VERSION         ; bcdDevice
_dscr_strorder::
        .db        SI_VENDOR        ; iManufacturer (string index)
        .db        SI_PRODUCT       ; iProduct (string index)
        .db        SI_SERIAL        ; iSerial number (string index)
        .db        1                ; bNumConfigurations
        
        .even
_high_speed_devqual_descr::
        .db        DSCR_DEVQUAL_LEN
        .db        DSCR_DEVQUAL
        .db        <USB_VER         ; bcdUSB (LSB)
        .db        >USB_VER         ; bcdUSB (MSB)
        .db        0xFF             ; bDeviceClass
        .db        0xFF             ; bDeviceSubClass
        .db        0xFF             ; bDeviceProtocol
        .db        64               ; bMaxPacketSize0
        .db        1                ; bNumConfigurations (one config at 12Mbps)
        .db        0                ; bReserved
        
        .even
_high_speed_config_descr::        
        .db        DSCR_CONFIG_LEN
        .db        DSCR_CONFIG
        .db        <(_high_speed_config_descr_end - _high_speed_config_descr)
        .db        >(_high_speed_config_descr_end - _high_speed_config_descr)
        .db        1                ; bNumInterfaces
        .db        1                ; bConfigurationValue
        .db        0                ; iConfiguration
_dscr_attrpow::
        .db        USB_ATTR         ; bmAttributes
        .db        MAX_POWER        ; bMaxPower [Unit: 2 mA]

        ;; interface descriptor
        
        .db        DSCR_INTRFC_LEN
        .db        DSCR_INTRFC
        .db        0                ; bInterfaceNumber (zero based)
        .db        0                ; bAlternateSetting
        .db        NUM_EPS          ; bNumEndpoints
        .db        0xFF             ; bInterfaceClass (vendor specific)
        .db        0xFF             ; bInterfaceSubClass (vendor specific)
        .db        0xFF             ; bInterfaceProtocol (vendor specific)
        .db        SI_PRODUCT       ; iInterface (description)

        ;; endpoint descriptor (jtag response)

        .db        DSCR_ENDPNT_LEN
        .db        DSCR_ENDPNT
        .db        0x81             ; bEndpointAddress (EP 1 IN)
        .db        ET_BULK          ; bmAttributes
        .db        <512             ; wMaxPacketSize (LSB) !! use only 64 byte
        .db        >512             ; wMaxPacketSize (MSB) !! use only 64 byte
        .db        0                ; bInterval (iso only)

        ;; endpoint descriptor (jtag request)

        .db        DSCR_ENDPNT_LEN
        .db        DSCR_ENDPNT
        .db        0x02             ; bEndpointAddress (EP 2 OUT)
        .db        ET_BULK          ; bmAttributes
        .db        <512             ; wMaxPacketSize (LSB) !! use only 64 byte
        .db        >512             ; wMaxPacketSize (MSB) !! use only 64 byte
        .db        0                ; bInterval (iso only)

#if defined(USE_2FIFO) || defined(USE_3FIFO)
        
        ;; endpoint descriptor (RXFIFO HOST->FPGA)

        .db        DSCR_ENDPNT_LEN
        .db        DSCR_ENDPNT
        .db        0x04             ; bEndpointAddress (EP 4 OUT)
        .db        ET_BULK          ; bmAttributes
        .db        <512             ; wMaxPacketSize (LSB)
        .db        >512             ; wMaxPacketSize (MSB)
        .db        0                ; bInterval (iso only)

        ;; endpoint descriptor (TXFIFO FPGA->HOST)

        .db        DSCR_ENDPNT_LEN
        .db        DSCR_ENDPNT
        .db        0x86             ; bEndpointAddress (EP 6 IN)
        .db        ET_BULK          ; bmAttributes
        .db        <512             ; wMaxPacketSize (LSB)
        .db        >512             ; wMaxPacketSize (MSB)
        .db        0                ; bInterval (iso only)

#endif

#if defined(USE_3FIFO)
        
        ;; endpoint descriptor (extra FIFO FPGA->HOST)

        .db        DSCR_ENDPNT_LEN
        .db        DSCR_ENDPNT
        .db        0x88             ; bEndpointAddress (EP 8 IN)
        .db        ET_BULK          ; bmAttributes
        .db        <512             ; wMaxPacketSize (LSB)
        .db        >512             ; wMaxPacketSize (MSB)
        .db        0                ; bInterval (iso only)

#endif

_high_speed_config_descr_end:                

;;; ----------------------------------------------------------------
;;; descriptors used when operating at full speed (12Mbps)
;;; no data fifo endpoints defined, if we are in full speed mode this will be no
;;; fun anyway. Shouldn't happen anyway, unless stone age USB hubs interfere...
;;; ----------------------------------------------------------------

        .even
_full_speed_device_descr::        
        .db        DSCR_DEVICE_LEN
        .db        DSCR_DEVICE
        .db        <USB_VER         ; Specification version (LSB)
        .db        >USB_VER         ; Specification version (MSB)
        .db        0x00             ; device class (vendor specific)
        .db        0x00             ; device subclass (vendor specific)
        .db        0x00             ; device protocol (vendor specific)
        .db        64               ; bMaxPacketSize0 for endpoint 0
        .db        <VID             ; idVendor
        .db        >VID             ; idVendor
        .db        <PID             ; idProduct
        .db        >PID             ; idProduct
        .db        <VERSION         ; bcdDevice
        .db        >VERSION         ; bcdDevice
        .db        SI_VENDOR        ; iManufacturer (string index)
        .db        SI_PRODUCT       ; iProduct (string index)
        .db        SI_SERIAL        ; iSerial number (string index)
        .db        1                ; bNumConfigurations
        
;;; describes the other speed (480Mbps)
        .even
_full_speed_devqual_descr::
        .db        DSCR_DEVQUAL_LEN
        .db        DSCR_DEVQUAL
        .db        <USB_VER         ; bcdUSB
        .db        >USB_VER         ; bcdUSB
        .db        0xFF             ; bDeviceClass
        .db        0xFF             ; bDeviceSubClass
        .db        0xFF             ; bDeviceProtocol
        .db        64               ; bMaxPacketSize0
        .db        1                ; bNumConfigurations (one config at 480Mbps)
        .db        0                ; bReserved
        
        .even
_full_speed_config_descr::        
        .db        DSCR_CONFIG_LEN
        .db        DSCR_CONFIG
        .db        <(_full_speed_config_descr_end - _full_speed_config_descr)
        .db        >(_full_speed_config_descr_end - _full_speed_config_descr)
        .db        1                ; bNumInterfaces
        .db        1                ; bConfigurationValue
        .db        0                ; iConfiguration
        .db        USB_ATTR         ; bmAttributes
        .db        MAX_POWER        ; bMaxPower [Unit: 2 mA]

        ;; interface descriptor
        
        .db        DSCR_INTRFC_LEN
        .db        DSCR_INTRFC
        .db        0                ; bInterfaceNumber (zero based)
        .db        0                ; bAlternateSetting
        .db        2                ; bNumEndpoints
        .db        0xFF             ; bInterfaceClass (vendor specific)
        .db        0xFF             ; bInterfaceSubClass (vendor specific)
        .db        0xFF             ; bInterfaceProtocol (vendor specific)
        .db        SI_PRODUCT       ; iInterface (description)

        ;; endpoint descriptor

        .db        DSCR_ENDPNT_LEN
        .db        DSCR_ENDPNT
        .db        0x81             ; bEndpointAddress (EP 1 IN)
        .db        ET_BULK          ; bmAttributes
        .db        <64              ; wMaxPacketSize (LSB)
        .db        >64              ; wMaxPacketSize (MSB)
        .db        0                ; bInterval (iso only)

        ;; endpoint descriptor

        .db        DSCR_ENDPNT_LEN
        .db        DSCR_ENDPNT
        .db        0x02             ; bEndpointAddress (EP 2 OUT)
        .db        ET_BULK          ; bmAttributes
        .db        <64              ; wMaxPacketSize (LSB)
        .db        >64              ; wMaxPacketSize (MSB)
        .db        0                ; bInterval (iso only)
        
_full_speed_config_descr_end:        
        
;;; ----------------------------------------------------------------
;;;                        string descriptors
;;; ----------------------------------------------------------------

_nstring_descriptors::
        .db        (_string_descriptors_end - _string_descriptors) / 2

_string_descriptors::
        .db        <str0, >str0
        .db        <str1, >str1
        .db        <str2, >str2
        .db        <str3, >str3
_string_descriptors_end:

        SI_NONE = 0
        ;; str0 contains the language ID's.
        .even
_str0::
str0:   .db        str0_end - str0
        .db        DSCR_STRING
        .db        0
        .db        0
        .db        <0x0409          ; magic code for US English (LSB)
        .db        >0x0409          ; magic code for US English (MSB)
str0_end:

        SI_VENDOR = 1
        .even
_str1::
str1:   .db        str1_end - str1
        .db        DSCR_STRING
        .db        'w, 0            ; 16-bit unicode
        .db        'w, 0
        .db        'w, 0
        .db        '., 0
        .db        'r, 0
        .db        'e, 0
        .db        't, 0
        .db        'r, 0
        .db        'o, 0
        .db        '1, 0
        .db        '1, 0
        .db        '., 0
        .db        'd, 0
        .db        'e, 0
str1_end:

        SI_PRODUCT = 2
        .even
_str2::
str2:   .db        str2_end - str2
        .db        DSCR_STRING
#if defined(USE_NEXYS2)
        .db        'n, 0
        .db        'e, 0
        .db        'x, 0
        .db        'y, 0
        .db        's, 0
        .db        '2, 0
        .db        '_, 0
#endif
#if defined(USE_NEXYS3)
        .db        'n, 0
        .db        'e, 0
        .db        'x, 0
        .db        'y, 0
        .db        's, 0
        .db        '3, 0
        .db        '_, 0
#endif
        .db        'j, 0
        .db        't, 0
        .db        'a, 0
        .db        'g, 0
#if defined(USE_2FIFO)
        .db        '_, 0
        .db        '2, 0
        .db        'f, 0
        .db        'i, 0
        .db        'f, 0
        .db        'o, 0
#endif
#if defined(USE_3FIFO)
        .db        '_, 0
        .db        '3, 0
        .db        'f, 0
        .db        'i, 0
        .db        'f, 0
        .db        'o, 0
#endif
#if defined(USE_AS)
        .db        '_, 0
        .db        'a, 0
        .db        's, 0
#endif
#if defined(USE_IC)
        .db        '_, 0
        .db        'i, 0
        .db        'c, 0
#endif
str2_end:

        SI_SERIAL = 3
        .even
_str3::
str3:   .db        str3_end - str3
        .db        DSCR_STRING
        .db        '0, 0
        .db        '0, 0
        .db        '0, 0
        .db        '0, 0
        .db        '0, 0
        .db        '0, 0
        .db        '0, 0
        .db        '0, 0
str3_end:

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.