Difference between revisions of "Rigol VS5202D"

From sigrok
Jump to navigation Jump to search
Line 13: Line 13:


'''CPU'''
'''CPU'''
 
* [http://www.analog.com/static/imported-files/data_sheets/ADSP-BF531_BF532_BF533.pdf Analog Devices ADSP-BF531] Blackfin CPU
* [http://www.skhynix.com/products/consumer/view.jsp?info.ramKind=01&info.serialNo=HY57V281620FTP&posMap=EOL Hynix HY57V281620FTP] 16MB DRAM
* [http://www.spansion.com/Products/Parallel-Flash/Pages/Spansion%20GL.aspx Spansion S29GL032A] 4MB flash


'''Analog acquisition'''
'''Analog acquisition'''

Revision as of 22:17, 3 January 2013

File:Rigol VS5202D Full.jpg
Rigol VS5000 series

The Rigol VS5202D is a 2 channel analog and 16 channel digital, 200 MHz, USB-based oscilloscope/logic analyzer.

The device is discontinued by Rigol, but you can find the basic specs e.g. here. Maybe some more info by comparing with the DS1000 programming manual.

See Rigol VS5202D/Info for some more details (such as lsusb -vvv output) on the device.

More information will come in due time.

Hardware

CPU

Analog acquisition

Logic acquisition

Ethernet interface

USB interface

Protocol

Work in progress.

The Rigol communication protocol only uses the USB control and bulk transfer. Control is for sending setup and request smaller amounts of data. Bulk transfers is returned by the Rigol box with setup and image data.

All control transfers interesting for us has request type set to 0xc0. The request field in the control packets is what tells us which command is actually sent.

All descriptions below should have both request type and request set to proper values, obvious from the headlines what it should be.


Packet types

This information is completely reverse engineered by hand.

Read answer (request = 0x00)

Commands ending with a question mark ('?' ASCII 0x3f) returns answer in two control transfers.

First control transfer is to query the size of the data to be returned. That is done by value set to 0. One byte of data is returned in the data field by this operation which is the size of the string the Rigol box wants to return.

Second control transfer has value set to 1. The buffer, allocated to the size just read, is also sent along the command to be filled with the data. The returned data is an ASCII string.

Write command (request = 0x01)

Commands from the PC program to the Rigol box is sent as text strings. Which commands that are available are listed in the Programming Guide from Rigol.

Each character is sent in a control message with the value set to the ASCII character to be sent. Each ASCII string is terminated with a carriage return (0x0d, '\r'), which terminates the transmission.

Request waveform data (Request = 0x04)

When waveform data is requested to be retrived a control message is sent. The index field of the setup data is a bitmask on which channels to be requested. It is encoded as bit 0 meaning Channel 1, bit 1 meaning Channel 2, bit 2 meaning Logic Channel 0, bit 3 meaning Logic Channel 1 etc.

The 4 byte data field of the control packet sent back as an ack contains number of bytes to be returned by bulk messages. It is encoded LSB first.

After that a series of bulk transfers occurs, with up to 4096 bytes in each transfer, until number of bytes given before is transferred.

Unknown control packet (Request = 0x05)

This control transfer is unknown, but it occurs when stop ha been pressed and streaming of big bulk blocks is terminated. All encoding in the control transfers are as described by request 0x04 above. The index field is always zero. Seems like some kind of 'flush buffers' command.

Request 780 byte data (Request = 0x06)

After this control transfer a bulk transfers occurs with 780 bytes of data. What each byte means is still to be determined, but will occur in a separate description.

Request 260 byte data (Request = 0x0c)

After this control transfer a bulk transfers occurs with 260 bytes of data. What each byte means is still to be determined, but will occur in a separate description.

Request 396 byte data (Request = 0x0d)

After this control transfer a bulk transfers occurs with 396 bytes of data. What each byte means is still to be determined, but will occur in a separate description.


Transfer sequences

Turn-on sequence

  1. *IDN?
  2. :INFO:FPGA?
  3. :STOP
  4. Request 780 bytes bulk
  5. Request 260 bytes bulk
  6. Request 396 bytes bulk

Turn-off sequence

Nothing special.

Start reading waveform data

2 analgoue channels.

  1. :CLEARUSB
  2. :RUN
  3. Request 780 bytes bulk
  4. Request 260 bytes bulk
  5. Request 396 bytes bulk
  6. Request 780 bytes bulk
  7. Request 780 bytes bulk (waiting for something?)
  8. Request waveform data.
  9. The data is started get transferred using bulk transfer.

Stop reading waveform data

2 analogue channels.

  1. :STOP
  2. :CLEARUSB
  3. Request waveform data, which returns with size 0.
  4. Unknown transfer, which returns with 8192 bytes of data.
  5. The 8192 byte of data is bulked up.
  6. :INFO:EUQP?
  7. Request 780 bytes bulk

Command sequences

  1. Command
  2. Request 780 bytes bulk
  3. Request 260 bytes bulk
  4. Request 396 bytes bulk


Data blocks

260 bytes block

Address Description
0 Logic analyzer off/on
1 Logic analyzer available
2 Logic analyzer channel 0 off/on
3 Logic analyzer channel 1 off/on
4 Logic analyzer channel 2 off/on
5 Logic analyzer channel 3 off/on
6 Logic analyzer channel 4 off/on
7 Logic analyzer channel 5 off/on
8 Logic analyzer channel 6 off/on
9 Logic analyzer channel 7 off/on
10 Logic analyzer channel 8 off/on
11 Logic analyzer channel 9 off/on
12 Logic analyzer channel 10 off/on
13 Logic analyzer channel 11 off/on
14 Logic analyzer channel 12 off/on
15 Logic analyzer channel 13 off/on
16 Logic analyzer channel 14 off/on
17 Logic analyzer channel 15 off/on

396 bytes block

No information.

780 bytes block

Address Description
8 Analogue 1; OFF = 0, ON chan1 = 1, ON chan2 = 2 (bitmask?)\\
12 Analogue 1; OFF = 0, ON = 1
32 Coupling chan1; DC = 0, AC = 1, GND = 2
44 Bandwidth Limit chan1; OFF = 0, ON = 1
46 Invert chan1; OFF = 0, ON = 1
90 Analogue 2; OFF = 0, ON = 1
108 Coupling chan2; DC = 0, AC = 1, GND = 2
120 Bandwidth Limit chan2; OFF = 0, ON = 1
122 Invert chan1; OFF = 0, ON = 1
448 Acquire type; Normal = 0, Average = 1, Peak = 2
456 Acquire average; 2 = 1, 4 = 2, 8 = 3, 16 = 4, 32 = 5, 64 = 6, 128 = 7, 256 = 8
520 Trigger mode; Edge = 0, Pulse = 1, Slope = 2, Video = 3, Alternate = ?, Pattern = 5, Duration = 6


The image information bulk transfer