DSPIC30F3013-30I/SO Microchip Technology, DSPIC30F3013-30I/SO Datasheet - Page 5

IC DSPIC MCU/DSP 24K 28SOIC

DSPIC30F3013-30I/SO

Manufacturer Part Number
DSPIC30F3013-30I/SO
Description
IC DSPIC MCU/DSP 24K 28SOIC
Manufacturer
Microchip Technology
Series
dsPIC™ 30Fr

Specifications of DSPIC30F3013-30I/SO

Program Memory Type
FLASH
Program Memory Size
24KB (8K x 24)
Package / Case
28-SOIC (7.5mm Width)
Core Processor
dsPIC
Core Size
16-Bit
Speed
30 MIPs
Connectivity
I²C, SPI, UART/USART
Peripherals
Brown-out Detect/Reset, POR, PWM, WDT
Number Of I /o
20
Eeprom Size
1K x 8
Ram Size
2K x 8
Voltage - Supply (vcc/vdd)
2.5 V ~ 5.5 V
Data Converters
A/D 10x12b
Oscillator Type
Internal
Operating Temperature
-40°C ~ 85°C
Product
DSCs
Data Bus Width
16 bit
Processor Series
DSPIC30F
Core
dsPIC
Maximum Clock Frequency
30 MHz
Number Of Programmable I/os
30
Data Ram Size
2 KB
Maximum Operating Temperature
+ 85 C
Mounting Style
SMD/SMT
3rd Party Development Tools
52713-733, 52714-737, 53276-922, EWDSPIC
Development Tools By Supplier
PG164130, DV164035, DV244005, DV164005, PG164120, ICE4000, DM240002, DM300018, DM330011
Minimum Operating Temperature
- 40 C
Lead Free Status / RoHS Status
Lead free / RoHS Compliant
For Use With
XLT28SO-1 - SOCKET TRANSITION 28SOIC 300MILDV164005 - KIT ICD2 SIMPLE SUIT W/USB CABLE
Lead Free Status / Rohs Status
Lead free / RoHS Compliant
Other names
DSPIC30F301330ISO

Available stocks

Company
Part Number
Manufacturer
Quantity
Price
Part Number:
DSPIC30F3013-30I/SO
Manufacturer:
NSC
Quantity:
340
Part Number:
DSPIC30F3013-30I/SO
Manufacturer:
PIC
Quantity:
20 000
3. Module: PSV Operations
TABLE 3:
EXAMPLE 2:
© 2010 Microchip Technology Inc.
ADDC
SUBB
SUBBR
CPB
RLC
RRC
ADD (Accumulator-based)
LAC
Note 1:
.include “p30fxxxx.inc”
.......
MOV.B #0x00, W0
MOV.B WREG, PSVPAG
BSET
....
MOV
ADD
ADDC
When one of the operands of instructions shown in
Table 3 is fetched from program memory using
Program Space Visibility (PSV), the STATUS
Register, SR and/or the results may be corrupted.
Work arounds
Work around 1: For Assembly Language
Source Code
To work around the erratum in the MPLAB ASM30
assembler, the application may perform a PSV
access to move the source operand from program
memory to RAM or a W register before performing
the operations listed in Table 3. Example 3
demonstrates the work around for Example 2.
2:
3:
4:
CORCON, #PSV
#0x8200, W1
W3, [W1++], W5 ;This instruction
W4, [W1++], W6 ;Carry flag and
Refer to the “dsPIC30F/33F Programmer’s Reference Manual” (DS70157) for details on the dsPIC30F
instruction set.
The errata only affects these instructions when a PSV access is performed to fetch one of the source
operands in the instruction. A PSV access is performed when the Effective Address of the source operand
is greater than 0x8000 and the PSV bit (CORCON<2>) is set to ‘1’. In the examples shown, the data
access from program memory is obtained via the W1 register.
SR<1:0> bits represent Sticky Zero and Carry Status bits, respectively.
SR<15:10> bits represent Accumulator Overflow and Saturation Status bits.
Instruction
AFFECTED INSTRUCTIONS
INCORRECT RESULTS
(1)
;Load PSVPAG register
;Enable PSV
;Set up W1 for
;indirect PSV access
;from 0x000200
;works ok
;W6 gets
;corrupted here!
ADDC
SUBB.b W0, [++W1], W3 ;
SUBBR.b W0, [++W1], W3 ;
CPB
RLC
RRC
ADD
LAC
Examples of Incorrect Operation
[W1], W4 ;
[W1], W2 ;
[W1++], A ;
[W1], A ;
W0, [W1++], W2 ;
W0, [W1++], W4 ;
EXAMPLE 3:
.include “p30fxxxx.inc”
.......
MOV.B #0x00, w0
MOV.B WREG, PSVPAG
BSET
....
MOV
ADD
MOV
ADDC
These instructions are identified in Table 3.
Example 2 demonstrates one scenario in which
this occurs.
Also, always use Work around 2 if the C compiler
is used to generate code for dsPIC30F3012/3013
devices.
Work around 2: For C Language Source Code
For applications using C language, MPLAB C30
versions 1.20.04 or higher provide the following
command-line switch that implements a work
around for the erratum.
-merrata=psv
Refer to the “readme.txt” file in the MPLAB C30
v1.20.04 toolsuite for further details.
Affected Silicon Revisions
B0
X
CORCON, #PSV
#0x8200, W1
W3, [W1++], W5 ;This instruction
[W1++], W2
W4, W2, W6
(2)
dsPIC30F3012/3013
B1
X
SR<1:0> bits
SR<1:0> bits
SR<1:0> bits
SR<1:0> bits
SR<1:0> bits
SR<1:0> bits
SR<1:0> bits
SR<15:10> bits
CORRECT RESULTS
Data Corruption IN
;Load PSVPAG register
;Enable PSV
;Set up W1 for
;indirect PSV access
;from 0x000200
;works ok
;Load W2 with data
;from program memory
;Carry flag and W4
;results are ok!
(3)
(3)
(3)
(3)
(3)
(3)
(3)
, Result in W2
, Result in W3
, Result in W3
, Result in W4
, Result in W2
(4)
DS80448D-page 5

Related parts for DSPIC30F3013-30I/SO