VS1000b VS1000 VS1000 - Ogg Vorbis Player IC with USB and NAND FLASH Interface Hardware Features • Low-power operation • Single input voltage: Internal voltage regulation for analog, digital, and I/O power • Operates with a single 12 MHz clock • Internal PLL clock multiplier • Power button pin, software-controlled power-off • USB Full Speed hardware • NAND FLASH interface with ECC • I/O for user interface • High-quality on-chip stereo DAC with no phase error between channels • Stereo earphone driver capable of driving a 30 Ω load • Lead-free RoHS-compliant package (Green) Firmware Features • Implements USB Mass Storage Device and Audio Device • NAND FLASH handling with error correction, block remapping, and wear levelling • Default player application in firmware – Decodes Ogg Vorbis, sound level normalization using Replay Gain – Pause / Play – Volume control – Next / Previous Song – Rewind and Fast Forward – Random Play – EarSpeaker Spatial Processing • Bass and treble controls for customized player • NAND FLASH boot for customized player • SPI FLASH boot for special applications • UART for debugging and special applications Version 1.0, 2007-09-11 Description VS1000 is a single-chip Ogg Vorbis (license-free audio codec) player. VS1000 contains a high-performance low-power DSP core VS DSP4 , NAND FLASH interface, Full Speed USB port, general purpose I/O pins, SPI, UART, as well as a highquality variable-sample-rate stereo DAC, and an earphone amplifier and a common voltage buffer. VS1000 firmware implements a default player that reads and plays files from the NAND FLASH. The player can be customized or replaced by using boot from NAND FLASH. When connected to USB, the firmware implements USB Mass Storage Device protocol or acts as an Audio Device, providing a single-chip USB headphone application. EarSpeaker spatial processing provides more natural sound in headphone listening conditions. It widens the stereo image and positions the sound sources outside the listener’s head. SPI EEPROM can be used to load code in applications that do not use NAND FLASH. 1 VLSI VS1000b y Solution VS1000 CONTENTS Contents 1 Disclaimer 4 2 Definitions 4 3 Characteristics & Specifications 4 3.1 Absolute Maximum Ratings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4 3.2 Recommended Operating Conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 3.3 Analog Characteristics of Audio Outputs . . . . . . . . . . . . . . . . . . . . . . . . . . 5 3.4 Analog Characteristics of Regulators . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 3.5 Analog Characteristics of VHIGH voltage monitor . . . . . . . . . . . . . . . . . . . . 6 3.6 Analog Characteristics of CVDD voltage monitor . . . . . . . . . . . . . . . . . . . . . 6 3.7 Analog Characteristics of USB . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 3.8 Power Consumption . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 3.9 Digital Characteristics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7 4 Packages and Pin Descriptions 8 4.1 Packages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 4.2 LQFP-48 Pin Descriptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 5 Example Schematic 11 6 VS1000 Functional Blocks 12 6.1 Regulator Section . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 6.2 Digital Section . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 6.3 Analog Section . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 Version 1.0, 2007-09-11 2 VLSI VS1000b y Solution 7 VS1000 LIST OF FIGURES Firmware Operation 15 7.1 SPI Boot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 7.2 NAND FLASH Probe . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 7.3 UART Boot/Monitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 7.4 Default Firmware Features . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 7.4.1 USB Mass Storage and Audio Device . . . . . . . . . . . . . . . . . . . . . . . 17 7.4.2 Default Player Application . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Supported Audio Codecs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 7.5.1 Supported Ogg Vorbis Formats . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 EarSpeaker Spatial Processing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20 7.5 7.6 8 VS1000 Errata 21 9 Document Version Changes 22 10 Contact Information 23 List of Figures 1 Pin Configuration, LQFP-48. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 2 VS1000 Block Diagram . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 3 EarSpeaker externalized sound sources vs. normal inside-the-head sound . . . . . . . . . 20 Version 1.0, 2007-09-11 3 VLSI VS1000b y Solution 1 VS1000 1. DISCLAIMER Disclaimer All properties and figures are subject to change. 2 Definitions B Byte, 8 bits. b Bit. Ki “Kibi” = 210 = 1024 (IEC 60027-2). Mi “Mebi” = 220 = 1048576 (IEC 60027-2). VS DSP VLSI Solution’s DSP core. W Word. In VS DSP, instruction words are 32-bit and data words are 16-bit wide. 3 Characteristics & Specifications 3.1 Absolute Maximum Ratings Parameter Regulator input voltage Analog Positive Supply Digital Positive Supply I/O Positive Supply Voltage at Any Digital Input Total Injected Current on Pins Operating Temperature Storage Temperature 1 2 Symbol VHIGH AVDD CVDD IOVDD Min -0.3 -0.3 -0.3 -0.3 -0.3 -40 -65 Max 5.25 3.6 2.7 3.6 IOVDD+0.31 ±200 2 +85 +150 Unit V V V V V mA ◦C ◦C Must not exceed 3.6 V Latch-up limit Version 1.0, 2007-09-11 4 VLSI VS1000 VS1000b3. CHARACTERISTICS & SPECIFICATIONS y Solution 3.2 Recommended Operating Conditions Parameter Operating temperature Analog and digital ground 1 Regulator input voltage2 Analog positive supply3 Digital positive supply 3 I/O positive supply3 Input clock frequency4 Internal clock frequency, USB connected Internal clock frequency, USB disconnected Master clock duty cycle Symbol AGND DGND VHIGH AVDD CVDD IOVDD XTALI CLKU CLKI Min -40 AVDD+0.3 2.75 2.2 1.8 12 48 12 40 Typ 0.0 4.0 2.8 2.3 2.8 125 50 Max +85 5.25 3.6 2.65 3.6 13 48 48 60 Unit ◦C V V V V V MHz MHz MHz % 1 Must be connected together as close the device as possible for latch-up immunity. 4.0 V is required for compliant USB level. 3 Regulator output of the device. 4 The maximum sample rate that can be played with correct speed is XTALI/256. With 12 MHz XTALI sample rates over 46875 Hz are played at 46875 Hz. 5 To be able to use USB, XTALI must be 12 MHz. 2 3.3 Analog Characteristics of Audio Outputs Unless otherwise noted: AVDD=2.8V, CVDD=2.4V, IOVDD=2.8V, TA=-40..+85◦ C, XTALI=12 MHz, Internal Clock Multiplier 3.0×. DAC tested with full-scale output sinewave, measurement bandwidth 20..20000 Hz, analog output load: LEFT to CBUF 30 Ω, RIGHT to CBUF 30 Ω. Parameter DAC Resolution Dynamic range (DAC unmuted, A-weighted, min gain) S/N ratio (full scale signal, no load) S/N ratio (full scale signal, 30 ohm load) Total harmonic distortion, max level, no load Total harmonic distortion, max level, 30 ohm load Crosstalk (L/R to R/L), 30 ohm load, without CBUF 1 Crosstalk (L/R to R/L), 30 ohm load, with CBUF Gain mismatch (L/R to R/L) Frequency response Full scale output voltage Deviation from linear phase Analog output load resistance Analog output load capacitance DC level (CBUF, LEFT, RIGHT) CBUF disconnect current (short-circuit protection) Symbol IDR SNR SNRL THD THDL XTALK1 XTALK2 GERR AERR LEVEL PH AOLR AOLC Min 75 -0.5 -0.05 450 Typ 18 96 92 90 0.01 0.1 75 54 530 0 302 1.1 130 Max 0.3 0.5 0.05 600 5 1003 1.3 200 Unit bits dB dB dB % % dB dB dB dB mVrms ◦ Ω pF V mA 1 Loaded from Left/Right pin to analog ground via 100 µF capacitors. AOLR may be lower than Typical, but distortion performance may be compromised. Also, there is a maximum current that the internal regulators can provide. 3 CBUF must have external 10 Ω + 47 nF load, LEFT and RIGHT must have external 20 Ω + 10 nF load for optimum stability and ESD tolerance. 2 Version 1.0, 2007-09-11 5 VLSI VS1000 VS1000b3. CHARACTERISTICS & SPECIFICATIONS y Solution 3.4 Analog Characteristics of Regulators Parameter IOVDD Recommended voltage setting range Voltage setting step size Default setting, reset mode 1 Default setting, active mode 2 Load regulation Line regulation from VHIGH Continuous current CVDD Recommended voltage setting range Voltage setting step size Default setting, reset mode 1 Default setting, active mode 2 Continuous current Load regulation Line regulation from VHIGH AVDD Recommended voltage setting range Voltage setting step size Default setting, reset mode 1 Default setting, active mode 2 Continuous current Load regulation Line regulation from VHIGH Symbol Min 1.7 50 Typ 60 1.8 1.8/3.63 4.0 2.0 304 1.8 35 2.6 35 48 1.8 2.2 304 2.0 2.0 46 2.5 2.7 304 1.5 2.0 Max 3.6 70 40 2.6 55 35 3.6 55 70 Unit V mV V V mV/mA mV/V mA V mV V V mA mV/mA mV/V V mV V V mA mV/mA mV/V 1 Device enters reset mode when XRESET pin is pulled low. Device enters active mode when XRESET pin is pulled high after reset mode. Regulator settings can be modified when booted from external memory (see section 7). 3 Depends on GPIO0 7 pin status in boot (see section 7). 4 Device is tested with a 30 mA load. 2 3.5 Analog Characteristics of VHIGH voltage monitor Parameter Trigger voltage Hysteresis 3.6 Min Typ 1.07×AVDD 50 Max Unit V mV Analog Characteristics of CVDD voltage monitor Parameter Trigger voltage Hysteresis Version 1.0, Symbol AMON 2007-09-11 Symbol CMON Min 1.40 Typ 1.53 2 Max Unit V mV 6 VLSI VS1000 VS1000b3. CHARACTERISTICS & SPECIFICATIONS y Solution 3.7 Analog Characteristics of USB Parameter Drive low level, 2.32 mA load Drive low level, 6.1×AVDD mA load Drive low level, 10.71×AVDD mA load Drive high level, -2.32 mA load Drive high level, -6.1×AVDD mA load Drive high level, -10.71×AVDD mA load USBP level, with 15 kΩ pull-down High-Level input voltage (single-ended) Low-Level input voltage (single-ended) Differential input common voltage, AVDD≥3.3V Differential input signal level, AVDD≥3.3V Input leakage current 3.8 Symbol Min 0.065 0.171×AVDD 0.300×AVDD AVDD-0.165 0.650×AVDD 0 2.7 0.7×AVDD -0.2 0.8 200 -2.0 Typ Max 0.102 0.270×AVDD AVDD AVDD-0.065 0.829×AVDD 0.700×AVDD 0.943×AVDD AVDD+0.3 0.3×AVDD 2.5 2.0 Power Consumption Parameter Symbol Min Typ Current Consumption of AVDD, no signal 3.4 Current Consumption of AVDD, sine test, CBUF + 30Ω load 33 Current Consumption of CVDD, sine test 3.0× clock 13 Current Consumption of USB suspend mode 1 650 Current Consumption, Reset @ 25 ◦ C 24 Example application (see Section 5) IOVDD=3.3V AVDD=2.8V CVDD=2.5V Total Power, play mode, CBUF + 30Ω load 120 Example application (see Section 5) IOVDD=2.7V AVDD=2.6V CVDD=2.2V Total Power, pause mode 10 Total Power, play mode, CBUF + 30Ω load 80 1 Max 55 25 48 Unit mA mA mA µA µA mW mW mW Requires user code support 3.9 Digital Characteristics Parameter High-Level Input Voltage Low-Level Input Voltage High-Level Output Voltage, -1.0 mA load 1 Low-Level Output Voltage, 1.0 mA load 1 XTALO high-level output voltage, -0.1 mA load XTALO low-level output voltage, 0.1 mA load Input leakage current Rise time of all output pins, load = 30 pF 1 1 Unit V V V V V V V V V V mV µA Symbol Min 0.7×IOVDD -0.2 0.7×IOVDD Typ Max IOVDD+0.3 0.3×IOVDD 0.3×IOVDD 0.7×IOVDD -1.0 0.3×IOVDD 1.0 50 Unit V V V V V V µA ns Pins GPIO0 [14:0], GPIO1 [5:0]. Version 1.0, 2007-09-11 7 VLSI VS1000b y Solution 4 4.1 VS1000 4. PACKAGES AND PIN DESCRIPTIONS Packages and Pin Descriptions Packages LPQFP-48 is lead (Pb) free and RoHS-compliant package. RoHS is a short name of Directive 2002/95/EC on the restriction of the use of certain hazardous substances in electrical and electronic equipment. 48 1 Figure 1: Pin Configuration, LQFP-48. LQFP-48 package dimensions are at http://www.vlsi.fi/ . Version 1.0, 2007-09-11 8 VLSI VS1000b y Solution 4.2 4. PACKAGES AND PIN DESCRIPTIONS LQFP-48 Pin Descriptions Pin Name XRESET NFDIO0 / GPIO0 0 NFDIO1 / GPIO0 1 NFDIO2 / GPIO0 2 NFDIO3 / GPIO0 3 DGND0 IOVDD1 TEST NFDIO4 / GPIO0 4 NFDIO5 / GPIO0 5 NFDIO6 / GPIO0 6 NFDIO7 / GPIO0 7 NFRDY / GPIO0 8 NFRD / GPIO0 9 NFCE / GPIO0 10 NFCLE / GPIO0 12 NFALE / GPIO0 13 DGND1 IOVDD2 NFWR / GPIO0 11 CS2 / GPIO0 14 XCS / GPIO1 0 SCLK / GPIO1 1 SI / GPIO1 2 SO / GPIO1 3 TX / GPIO1 4 RX / GPIO1 5 XTALI XTALO IOVDD DGND2 CVDD VHIGH AVDD USBP USBN PWRBTN AGND0 AVDD1 RIGHT AGND1 AGND2 CBUF AVDD2 RCAP AVDD3 LEFT AGND3 Version 1.0, VS1000 2007-09-11 LQFP Pin 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 Pin Type DI DIO DIO DIO DIO DGND IOPWR DI DIO DIO DIO DIO DIO DIO DIO DIO DIO DGND IOPWR DIO DIO DIO DIO DIO DIO DIO DIO AI AO IOPWR DGND CPWR PWR APWR AIO AIO AIO APWR APWR AO APWR APWR AO APWR AIO APWR AO APWR Function Active low asynchronous reset, schmitt-trigger input Nand-flash IO0 / General-purpose IO Port 0, bit 0 Nand-flash IO1 / General-purpose IO Port 0, bit 1 Nand-flash IO2 / General-purpose IO Port 0, bit 2 Nand-flash IO3 / General-purpose IO Port 0, bit 3 Core & I/O ground I/O power supply Test mode input (active high), connect to DGND Nand-flash IO4 / General-purpose IO Port 0, bit 4 Nand-flash IO5 / General-purpose IO Port 0, bit 5 Nand-flash IO6 / General-purpose IO Port 0, bit 6 Nand-flash IO7 / General-purpose IO Port 0, bit 7 Nand-flash READY / General-purpose IO Port 0, bit 8 Nand-flash RD / General-purpose IO Port 0, bit 9 Nand-flash CE / General-purpose IO Port 0, bit 10 Nand-flash CLE / General-purpose IO Port 0, bit 12 Nand-flash ALE / General-purpose IO Port 0, bit 13 Core & I/O ground I/O power supply Nand-flash WR / General-purpose IO Port 0, bit 11 General-purpose IO Port 0, bit 14 SPI XCS / General-Purpose I/O Port 1, bit 0 SPI CLK / General-Purpose I/O Port 1, bit 1 SPI MISO / General-Purpose I/O Port 1, bit 2 SPI MOSI / General-Purpose I/O Port 1, bit 3 UART TX / General-Purpose I/O Port 1, bit 4 UART RX / General-Purpose I/O Port 1, bit 5 Crystal input Crystal output I/O power supply, Regulator output Core & I/O ground Core power supply, Regulator output Power supply, Regulator input Analog power supply, Regulator output USB differential + in / out, controllable 1.5kΩ pull-up USB differential - in / out Power button for Regulator startup (and Power Key) Analog ground Analog power supply Right channel output Analog ground Analog ground Common voltage buffer for headphones Analog power supply Filtering capacitance for reference Analog power supply Left channel output Analog ground 9 VLSI VS1000b y Solution VS1000 4. PACKAGES AND PIN DESCRIPTIONS Pin types: Type DI DO DIO AI AO Version 1.0, Description Digital input, CMOS Input Pad Digital output, CMOS Input Pad Digital input/output Analog input Analog output 2007-09-11 Type AIO APWR DGND CPWR IOPWR Description Analog input/output Analog power supply pin Core or I/O ground pin Core power supply pin I/O power supply pin 10 VLSI VS1000b y Solution 5 Version 1.0, VS1000 5. EXAMPLE SCHEMATIC Example Schematic 2007-09-11 11 VLSI VS1000b y Solution 6 VS1000 6. VS1000 FUNCTIONAL BLOCKS VS1000 Functional Blocks LEFT RIGHT CBUF RCAP VHIGH PWRBTN Reference AVDD1 AVDD2 AVDD3 Stereo Earphone Driver Stereo DAC Common Voltage Driver Regulator Regulator Voltage Monitor Regulator USBP USPN XCS/GPIO1[0] SCLK/GPIO1[1] SI/GPIO1[2] SO/GPIO1[3] USB Serial Data/ Control Interface CVDD X RAM X ROM VSDSP4 processor UART Y RAM XTALO XTALI Clock Y ROM NAND Flash Interface/ General IO I RAM Control/ GPIO0[8...14] AVDD <1.6V reset RX/GPIO1[5] TX/GPIO1[4] Data/ GPIO0[0...7] IOVDD I ROM TEST XRESET IOVDD1 IOVDD2 Figure 2: VS1000 Block Diagram 6.1 Regulator Section The VHIGH pin in the regulator section is used as a common main power supply for voltage regulation. This input is connected to three internal regulators, which are activated when the PWRBTN pin is set high for about one millisecond, so that AVDD starts to rise and reaches about 1.5 V. After the PWRBTN has given this initial start current, the regulators reach their default voltages even if the PWRBTN is released. VHIGH must be sufficiently (about 0.3 V) above the highest regulated power (normally AVDD) so that regulation can be properly performed. The PWRBTN state can also be read by software, so it can be used as one of the user interface buttons. A power-on reset monitors the core voltage and asserts reset if CVDD drops below the CMON level. It is also possible to force a reset by keeping PWRBTN pressed for longer than approximately 5.6 seconds. A watchdog counter and the XRESET pin can also generate a reset for the device. Resets do not cause the regulators to shut down, but they restore the default regulator voltages. After boot the firmware and user software can change the voltages. Return to power-off is possible only with active software control (VSDSP writes the regulator shutdown bit), or when VHIGH voltage is removed for a sufficiently long time. In the default firmware player the power button has to be pressed for 2 seconds to make the software powerdown the system and turn the regulators off. Version 1.0, 2007-09-11 12 VLSI VS1000b y Solution 6.2 VS1000 6. VS1000 FUNCTIONAL BLOCKS Digital Section Two of the regulators provide power supply for the digital section. IOVDD is used for the level-shifters of the digital I/O and crystal oscillator. The IOVDD regulator output must be connected to IOVDD1 and IOVDD2 input pins, because they are not connected internally. Proper bypass capacitors should also be used. The firmware uses GPIO0 7 to select I/O voltage level. After reset the I/O voltage is 1.8 V. If GPIO0 7 has a pull-down resistor, 1.8 V I/O voltage is used. If GPIO0 7 has a pull-up resistor, 3.3 V I/O voltage is used. All other digital is powered from core voltage (CVDD). The core voltage is internally connected, and the CVDD pin should have a proper bypass capacitors. Clock The crystal amplifier uses a crystal connected to XTALI and XTALO. An external logic-level input clock can also be used. When VS1000 is used with USB, 12 MHz input clock must be used. An internal phase-locked loop (PLL) generates the internal clock by multiplying the input clock by 1.0×, 1.5×, . . . , 4.0×. When USB is connected, the clock is 4.0×12 MHz = 48 MHz. When the player is active, the clock will be automatically changed according to the requirements of the song being played. XRESET disables the clock buffer and puts the digital section into powerdown mode. VSDSP4 VSDSP4 is VLSI Solution’s proprietary digital signal processor with a 32-bit instruction word, two 16-bit data buses, and both 16-bit and 32/40-bit arithmetic. IROM, XROM, and YROM contain the firmware, including the default player application. Most of the instruction RAM and some of the X and Y data RAM’s can be used to customize and extend the functionality of the player. UART An asynchronous serial port is used for debugging and special applications. The default speed is 115200 bps. RX and TX pins can also be used for general-purpose I/O when the UART is not required. SPI A synchronous serial port peripheral is used for SPIEEPROM boot, and can be used to access other SPI peripherals (for example LCD or SED) by using another chip select. The SPI is only used for boot if the XCS pin has a high level after reset (pull-up resistor attached). These pins can also be used for general-purpose I/O when the SPI is not required. The default player uses SI and SO for LED outputs. Version 1.0, 2007-09-11 13 VLSI VS1000b y Solution VS1000 6. VS1000 FUNCTIONAL BLOCKS NAND FLASH Interface The NAND FLASH peripheral calculates a simple error-correcting code (ECC), and automates some of the communication with a NAND FLASH chip. The firmware uses the peripheral to access both small-page (512+16 B pages) and large-page (2048+64 B pages) NAND FLASH chips. The first sector in the FLASH tells the firmware how it should be accessed. The NAND FLASH interface pins can also be used as general-purpose I/O. The default firmware uses GPIO0 [4:0] for keys, and GPIO0 [7:6] for other purposes. Pull-up and pull-down resistors must be used for these connections so that the data transfer to and from the NAND FLASH isn’t disturbed when keys are pressed. USB The USB peripheral handles USB 1.1 Full Speed harware protocol. Low speed communication is not supported, but is correctly ignored. The USBP pin has a software-controllable 1.5kΩ pull-up. A control endpoint (1 IN and 1 OUT) and upto 6 other endpoints (3 IN and 3 OUT) can be used simultaneously. Bulk, interrupt, and isochronous transfer modes are selectable for each endpoint. USB receive from USB host to device (OUT) uses a 2 KiB buffer, thus allowing very high transfer speeds. USB transmit from device to USB host (IN) also uses a 2 KiB buffer and allows all IN endpoints to be ready to transmit simultaneously. Double-buffering is also possible, but not usually required. The firmware uses the USB peripheral to implement both USB Mass Storage Device and USB Audio Device. Which device is activated depends on the state of GPIO0 6 when the USB connection is detected. If GPIO0 6 has a pull-up resistor, VS1000 appears as an USB Audio Device. If GPIO0 6 has a pull-down resistor, VS1000 appears as an USB Mass Storage Device. 6.3 Analog Section The third regulator provides power for the analog section. The analog section consists of digital to analog converters and earphone driver. This includes a buffered common voltage generator (CBUF, around 1.2 V) that can be used as a virtual ground for headphones. The AVDD regulator output pin must be connected to AVDD1..AVDD3 pins with proper bypass capacitors, because they are not connected internally. The USB pins use the internal AVDD voltage, and the firmware configures AVDD to 3.6 V when USB is attached. Low AVDD voltage can be monitored by software. Currently the firmware does not take advantage of this feature. CBUF contains a short-circuit protection. It disconnects the CBUF driver if pin is shorted to ground. In practise this only happens with external power regulation, because there is a limit to how much power the internal regulators can provide. Version 1.0, 2007-09-11 14 VLSI VS1000b y Solution 7 VS1000 7. FIRMWARE OPERATION Firmware Operation The firmware uses the following pins (see the example schematics in Section 5): Pin PWRBTN GPIO0 0 GPIO0 1 GPIO0 2 GPIO0 3 GPIO0 4 GPIO0 6 GPIO0 7 NFCE XCS SI SO USBN USBP Description High level starts regulator, is also read as the Power button Key. external 1 MΩ pull-down resistor, Key 1 connects a 100 kΩ pull-up resistor external 1 MΩ pull-down resistor, Key 2 connects a 100 kΩ pull-up resistor external 1 MΩ pull-down resistor, Key 3 connects a 100 kΩ pull-up resistor external 1 MΩ pull-down resistor, Key 4 connects a 100 kΩ pull-up resistor external 1 MΩ pull-down resistor, Key 5 connects a 100 kΩ pull-up resistor external pull-down resistor for USB Mass Storage Device, pull-up for USB Audio Device external pull-down resistor for 1.8 V I/O voltage, pull-up resistor for 3.3 V I/O voltage external pull-up resistor for normal operation, pull-down to use RAM disk for UMS Device external pull-up to enable SPI EEPROM boot Power LED control during firmware operation Feature LED control during firmware operation external 1 MΩ pull-up external 1 MΩ pull-up Boot order: Stage Power on Reset UART Boot SPI EEPROM Boot NAND FLASH probed Default firmware 7.1 Description Power button (PWRBTN) pressed when VHIGH has enough voltage Power-on reset, XRESET, or watchdog reset causes software restart Almost immediately after power-on UART can be used to enter emulator mode. If XCS is high, SPI Boot is tried. If NFCE is high, NAND FLASH is checked. The firmware in ROM takes control. SPI Boot The first boot method is SPI EEPROM. If GPIO1 0 is low after reset, SPI boot is skipped. If GPIO1 0 is high, it is assumed to have a pull-up resistor and SPI boot is tried. First the first four bytes of the SPI EEPROM are read using 16-bit address. If the bytes are “VLSI”, a 16-bit EEPROM is assumed and the boot continues. If the last 3 bytes are read as “VLS”, a 24-bit EEPROM is assumed and boot continues in 24-bit mode. Both 16-bit and 24-bit EEPROM should have the “VLSI” string starting at address 0, and the rest of the boot data starting at address 4. If no identifier is found, SPI EEPROM boot is skipped. Boot records are read from EEPROM until an execute record is reached. Unknown records are skipped using the data length field. Byte 0 1,2 3, 4 5.. Version 1.0, Description type 0=I-mem 1=X-mem 2=Y-mem 3=execute data len lo, hi – data length in bytes address lo, hi – record address data* 2007-09-11 15 VLSI VS1000b y Solution 7.2 VS1000 7. FIRMWARE OPERATION NAND FLASH Probe If NAND FLASH chip select (NFCE) is high, a NAND FLASH is assumed to be present and the first sector is read. The access methods (nandTypes 0..5) are tried in order to find the “VLSI” identification. If the first bytes are “VLSI”, a valid boot sector is assumed. This sector gives the necessary information about the NAND FLASH so that it can be accessed in the right way. Byte 0,1,2,3 4,5 6 7 8,9 10,11 12,13,14,15 16...511 NandType 0 1 2 3 4 5 Value 0x56 0x4c 0x53 0x49 0x00 0x03 0x08 0x13 0x00 0x46 0x00 0x01 0x42 0x6f 0x4f 0x74 Description ’V’ ’L’ ’S’ ’I’ – Identification nandType (0x0003 = large-page with 3-byte block address) blockSizeBits (28 ∗ 512 = 128 KiB per block) flashSizeBits (219 ∗ 512 = 256 MiB flash) nandWaitNs – NAND FLASH access time in ns number of extra blocks for boot (example: 0x0001) ’B’ ’o’ ’O’ ’t’ – Optional boot ident code Description 512+16 B small-page flash with 2-byte block address (<= 32 MB) 2048+64 B large-page flash with 2-byte block address (<= 128 MB) 512+16 B small-page flash with 3-byte block address (> 32 MB <= 8 GB) 2048+64 B large-page flash with 3-byte block address (> 128 MB <= 32 GB) 512+16 B small-page flash with 4-byte block address (> 8 GB) 2048+64 B large-page flash with 4-byte block address (> 32 GB) If bytes 12-15 contain “BoOt”, the value in bytes 10 and 11 determines how many sectors are read from NANDflash. Value 1 means two 512-byte sectors are read, value 0 means only the first block is needed. After the data is read into memory, the boot records in this data are processed, transferring code and data sections into the right places in memory and possibly executed. If an unknown boot record is encountered, the booting is stopped and control returns to the firmware code. Word 0 1 2 3.. Description type 0x8000=I-mem 0x8001=X-mem 0x8002=Y-mem 0x8003=execute data length in words -1 – 0 = 1 word, 1 = 2 words, etc. address – record address data Note: In VS1000a you can not have Y-memory records. Note: In VS1000b you need one filler word after each Y-memory record. If NFCE is low during boot, or an uninitialized NAND FLASH is connected, the NAND FLASH type is set to 0xffff, and a RAM disk is initialized when USB is attached. In this mode you can drop a boot file named VS1000 B.RUN into the disk and it will be run when the USB is disconnected. This way you can easily program a player that has an uninitialized NAND FLASH or SPI EEPROM. 7.3 UART Boot/Monitor When byte 0xef is sent to RX at 115200 bps, the firmware enters monitor mode and communicates with vs3emu. Memory contents can be displayed, executables can be loaded and run, or the firmware code can be restarted or continued. The UART is also a convenient way to program the NAND FLASH boot sector(s) or the SPI EEPROM. Version 1.0, 2007-09-11 16 VLSI VS1000b y Solution 7.4 7.4.1 VS1000 7. FIRMWARE OPERATION Default Firmware Features USB Mass Storage and Audio Device When USB cable insertion is detected by the firmware, playing of the current file is stopped and USB handling code is started. The internal clock is configured to 4.0× 12 MHz = 48 MHz, the analog power is configured to 3.6 V, the USB peripheral is initialized, and the USB pull-up resistor is enabled. If GPIO0 6 has a pull-up resistor, VS1000 appears as an USB Audio Device. If GPIO0 6 has a pull-down resistor, VS1000 appears as an USB Mass Storage Device. If during power-on the NAND FLASH contained a valid boot sector, the NAND FLASH disk will be used with the mass storage device. The NAND FLASH disk requires a filesystem-level formatting before it can be used. If NFCE had a pull-down instead of pull-up, or if a valid boot sector was not found, a RAM disk is used instead. The RAM disk is preformatted and can be used immediately, but it does not retain its contents between USB detachment and insertion. The RAM disk is only intended for loading software through USB. You can copy a file VS1000 B.RUN to RAM disk and it will be automatically run when you disconnect the USB cable. This mechanism can be used to program the NAND FLASH boot sector (perhaps containing custom boot code), and also for programming a SPI EEPROM in case NAND FLASH is not used in the application. 7.4.2 Default Player Application When the USB cable is detached, the contents of the disk is checked. If the disk seems to contain a FAT16 or FAT32 filesystem, a cleanup of unused sectors is performed. The cleanup makes the disk perform faster the next time something is written on it. If a full disk has been formatted or emptied, this cleanup can take considerable time, even 30 seconds or more. After the cleanup is finished the player starts to play files. Note: normally Windows formats smaller than about 16 MB disks as FAT12. The player has only partial support for FAT12 disks: no cleanup is performed, subdirectories are not allowed, and files are assumed not to be fragmented. If disks as small as or smaller than this are required, it is possible to format them as FAT16 with the following command. format e: /A:512 /FS:FAT The default player application only decodes Ogg Vorbis files, but it can be extended to allow some simple codecs, like a WAV decoder. In addition to the power button, 5 keys are connected to GPIO0 [4:0] so that they connect a 100 kΩ pull-up to the I/O when the button is pressed, and 1 MΩ pull-downs keep the lines low otherwise. The resistors are needed because these lines are also used for NAND FLASH communication. The keys are read approximately 16 times per second. The key control can be changed by replacing the default key mapping table. The default user interface uses six buttons. Button POWER KEY1 KEY2 KEY3 KEY4 KEY5 Version 1.0, Short Press < 1 second Power On, Pause / Play Volume Down Volume Up Previous Next EarSpeaker 2007-09-11 Long Press >= 1 second Power off (pressed for 2 seconds) Volume Down Volume Up Rewind Fast Forward Random On / Off 17 VLSI VS1000b y Solution VS1000 7. FIRMWARE OPERATION Power Button A press of the power button turns on the system. After boot the power LED (the LED connected to SI) is turned on. After the startup a short press of the power button toggles between pause and play modes. In pause mode the power LED flashes. When the power button is pressed for 2 seconds, the system powers down. Volume Buttons Volume can be turned up or down with 0.5 dB steps using the volume buttons. A short press changes the volume by 0.5 dB, a long press will change the volume by approximately 8 dB every second. Previous / Next Buttons A song can be changed using the previous and next buttons. A short press of the previous button will restart the song if it has been played for at least 5 seconds, and go to the previous song otherwise. A short press of the next button goes to the next song. A long press of previous or next will rewind and fast forward the song, respectively. Feature Button The sixth button controls two features: the EarSpeaker spatial processing and the random play function. A long press of the feature button toggles the random play function. When random play becomes activated, a new song is automatically randomly selected. When random play mode is active, the feature LED (the LED connected to SO) will light up. A short press of the feature button will select between four EarSpeaker modes: off, minimal, normal, and extreme. Version 1.0, 2007-09-11 18 VLSI VS1000b y Solution 7.5 7.5.1 VS1000 7. FIRMWARE OPERATION Supported Audio Codecs Supported Ogg Vorbis Formats Parameter Channels Window size Sample rate Bit rate Min 1 64 Max 2 4096 48000 500 Unit samples Hz kbit/s Maximum window size for an Ogg Vorbis file is 8192, however only window sizes upto 4096 are in active use with sample rates not exceeding 48 kHz. With USB (12 MHz clock) sample rates above 46875 Hz are played back at 46875 Hz. There are no sample rate restrictions for lower sample rates: non-standard sample rates can be played back without a performance penalty. Only floor 1 is supported. No known current encoder uses floor 0. All one- and two-channel Ogg Vorbis files within the restrictions above should be playable with this decoder. Ogg Vorbis decoding supports Replay Gain technology. If the decoder finds a Replay Gain tag in the song header, the tag is parsed and the player software uses it to adjust the sound level. For a song without any Replay Gain tag, a default of -6 dB is used. For more details about Replay Gain, see http://en.wikipedia.org/wiki/Replay Gain and http://www.replaygain.org/. Version 1.0, 2007-09-11 19 VLSI VS1000b y Solution 7.6 VS1000 7. FIRMWARE OPERATION EarSpeaker Spatial Processing While listening to headphones the sound has a tendency to be localized inside the head. The sound field becomes flat and lacking a sensation of dimensions. This is an unnatural, awkward and sometimes even disturbing situation. This phenomenon is often referred in literature as ‘lateralization’, meaning ’in-the-head’ localization. Long-term listening to lateralized sound may lead to listening fatigue. All real-life sound sources are external, leaving traces of the acoustic wavefront that arrives to the ear drums. From these traces, the auditory system in the brain is able to judge the distance and angle of each sound source. In loudspeaker listening the sound is external and these traces are available. In headphone listening these traces are missing or ambiguous. The EarSpeaker processing makes listening via headphones more like listening to the same music from real loudspeakers or live. Once EarSpeaker processing is activated, the instruments are moved from inside to the outside of the head, making it easier to separate different instruments (see figure 3). The listening experience becomes more natural and pleasant, and the stereo image is sharper as the instruments are widely in front of the listener instead of being inside the head. Figure 3: EarSpeaker externalized sound sources vs. normal inside-the-head sound Note that EarSpeaker differs from any common spatial processing effects, such as echo, reverb, or bass boost. EarSpeaker accurately simulates the human auditory model and real listening environment acoustics. Thus it does not change the tonal character of the music by introducing artificial effects. EarSpeaker processing can be parameterized to a few different modes, each simulating a little different type of an acoustical situation and suiting different personal preferences as well as different types of recording. • Off: Best option when listening through loudspeakers or if the audio to be played contains binaural preprocessing • Minimal: Listening to normal musical scores with headphones, very subtle • Normal: Listening to normal musical scores with headphones, moves sound source further than minimal • Extreme: Old or ’dry’ recordings, or if the audio to be played is artificial Version 1.0, 2007-09-11 20 VLSI VS1000b y Solution 8 VS1000 8. VS1000 ERRATA VS1000 Errata This chapter describes the known problems with different VS1000 revisions. Most of the problems are correctable with user code that is loaded to IRAM. VS1000A Errata • • • • • • • • You can not have initialized Y data with NAND FLASH or Ramdisk boot. EarSpeaker initialization problem with other channel. Analog drivers are enabled too soon, causing a small click in headphones. Intermediate results are saturated in Vorbis windowing with full-scale sine sweep. If Flash does not contain a file system, user interface (including power off) can not be used. Ramdisk boot from VS1000 A.RUN only allows upto 512-byte programs directly. Volume is uninitialized with USB Audio Device if USB is already attached when power is turned on. In most cases Replay Gain fails if other tags are present. VS1000B Changes • • • • • • • • • • • NAND FLASH and Ramdisk boot can have initialized Y data. EarSpeaker initialization fixed, EarSpeaker optimized from 12 MHz to 10 MHz (at 44.1 kHz). Small power-on click removed. User interface works even if there is no filesystem. (You can turn the power off.) NAND FLASH boot handles larger than 512-byte programs without a chain-loader routine (upto 8176 bytes). Ramdisk boot (VS1000 B.RUN) handles larger than 512-byte programs (upto 8192 bytes). When attached to USB, LED is flashed when there is read/write activity. LED is turned off when the file system has been flushed. Volume is always initialized, USB Audio Device can be powered on while attached to USB (powered from VBUS). USB Suspend + Resume are implemented (but need user tuning). Vorbis: Now uses adaptive accuracy for windowing, implements fast play mode, and has better synchronization after non-fatal errors. Replay gain has been fixed. Player: Fast play mode is used for better-sounding fast forward. Fast forward speeds up when the ff button is kept pressed. Player uses the suspend routine to implement low-power pause mode. Timeout turns the unit off after being 5 minutes in pause mode. The default maximum clock in player mode is 3.5×. Some new IRAM hooks: KeyEventHandler, MassStorage, USBSuspend, InitUSBDescriptors. VS1000C Changes • Has the same firmware as version B. VS1000B/C Errata • NAND FLASH and Ramdisk boot needs one filler word after every Y data record. Version 1.0, 2007-09-11 21 VLSI VS1000b y Solution 9 VS1000 9. DOCUMENT VERSION CHANGES Document Version Changes This chapter describes the most important changes to this document. Version 1.0 for VS1000B/C, 2007-09-11 • Production version. • Maximum and operational limits updated. Version 0.4 for VS1000B/C, 2007-09-06 • Release for VS1000B / VS1000C. • Added VS1000 errata: Chapter 8. Version 0.3, 2007-05-09 • Updated example schematic in Chapter 5. Version 0.2, 2007-01-25 • Minor changes. Version 0.1, 2006-11-22 • First pre-release version. Version 1.0, 2007-09-11 22 VLSI Solution VS1000b y 10 VS1000 10. CONTACT INFORMATION Contact Information VLSI Solution Oy Entrance G, 2nd floor Hermiankatu 8 FIN-33720 Tampere FINLAND Fax: +358-3-3140-8288 Phone: +358-3-3140-8200 Email: [email protected] URL: http://www.vlsi.fi/ Version 1.0, 2007-09-11 23