diff options
Diffstat (limited to 'src/devices/pic/xml_data/18F8585.xml')
-rw-r--r-- | src/devices/pic/xml_data/18F8585.xml | 312 |
1 files changed, 312 insertions, 0 deletions
diff --git a/src/devices/pic/xml_data/18F8585.xml b/src/devices/pic/xml_data/18F8585.xml new file mode 100644 index 0000000..08367ab --- /dev/null +++ b/src/devices/pic/xml_data/18F8585.xml @@ -0,0 +1,312 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!--************************************************************************--> +<!--* Copyright (C) 2005-2007 Nicolas Hadacek <hadacek@kde.org> *--> +<!--* *--> +<!--* This program is free software; you can redistribute it and/or modify *--> +<!--* it under the terms of the GNU General Public License as published by *--> +<!--* the Free Software Foundation; either version 2 of the License, or *--> +<!--* (at your option) any later version. *--> +<!--************************************************************************--> +<device name="18F8585" document="010321" status="IP" memory_technology="FLASH" self_write="yes" architecture="18F" id="0x0A40" > + +<!--* Operating characteristics ********************************************--> + <frequency_range name="industrial" > + <frequency start="0" end="40" vdd_min="4.2" vdd_max="5.5" /> + <frequency start="0" end="25" vdd_min="4.2" vdd_max="5.5" mode="not microcontroller" /> + </frequency_range> + <frequency_range name="industrial" special="low_power" > + <frequency start="0" end="4" vdd_min="2" vdd_max="5.5" /> + <frequency start="4" end="40" vdd_min="2" vdd_max="5.5" vdd_min_end="4.2" /> + <frequency start="4" end="25" vdd_min="2" vdd_max="5.5" vdd_min_end="4.2" mode="not microcontroller" /> + </frequency_range> + <frequency_range name="extended" > + <frequency start="0" end="25" vdd_min="4.2" vdd_max="5.5" /> + </frequency_range> + + <voltages name="vpp" min="9" max="13.25" nominal="13" /> + <voltages name="vdd_prog" min="4.5" max="5.5" nominal="5" /> + <voltages name="vdd_prog_write" min="2" max="5.5" nominal="5" /> + +<!--* Memory ***************************************************************--> + <memory name="code" start="0x000000" end="0x00BFFF" word_write_align="4" word_erase_align="32" /> + <memory name="user_ids" start="0x200000" end="0x200007" rmask="0x0F" /> + <memory name="device_id" start="0x3FFFFE" end="0x3FFFFF" /> + <memory name="config" start="0x300000" end="0x30000D" /> + <memory name="eeprom" start="0x000000" end="0x0003FF" hexfile_offset="0xF00000" /> + <memory name="debug_vector" start="0x200028" end="0x200037" /> + +<!--* Configuration bits ***************************************************--> + <config offset="0x0" name="CONFIG1L" wmask="0xFF" bvalue="0x00" /> + + <config offset="0x1" name="CONFIG1H" wmask="0xFF" bvalue="0x2F" > + <mask name="FOSC" value="0x0F" > + <value value="0x00" name="LP" cname="_OSC_LP" /> + <value value="0x01" name="XT" cname="_OSC_XT" /> + <value value="0x02" name="HS" cname="_OSC_HS" /> + <value value="0x03" name="EXTRC_CLKOUT" cname="_OSC_RC" /> + <value value="0x04" name="EC_CLKOUT" cname="_OSC_EC" /> + <value value="0x05" name="EC_IO" cname="_OSC_ECIO" /> + <value value="0x06" name="H4" cname="_OSC_HSPLL" /> + <value value="0x07" name="EXTRC_IO" cname="_OSC_RCIO" /> + <value value="default" name="invalid" /> + <value value="0x0C" name="E4_IO" cname="_OSC_ECIOPLL" /> + <value value="0x0D" name="E4S_IO" cname="_OSC_ECIOSWPLL" /> + <value value="0x0E" name="H4S" cname="_OSC_HSSWPLL" /> + <value value="0x0F" name="EXTRC_IO" cname="_OSC_RCIO" /> + </mask> + <mask name="OSCSEN" value="0x20" > + <value value="0x00" name="On" cname="_OSCS_ON" /> + <value value="0x20" name="Off" cname="_OSCS_OFF" /> + </mask> + </config> + + <config offset="0x2" name="CONFIG2L" wmask="0xFF" bvalue="0x0F" > + <mask name="PWRTE" value="0x01" > + <value value="0x00" name="On" cname="_PWRT_ON" /> + <value value="0x01" name="Off" cname="_PWRT_OFF" /> + </mask> + <mask name="BODEN" value="0x02" > + <value value="0x00" name="Off" cname="_BOR_OFF" /> + <value value="0x02" name="On" cname="_BOR_ON" /> + </mask> + <mask name="BORV" value="0x0C" > + <value value="0x00" name="4.5" cname="_BORV_45" /> + <value value="0x04" name="4.2" cname="_BORV_42" /> + <value value="0x08" name="2.7" cname="_BORV_27" /> + <value value="0x0C" name="2.0" cname="_BORV_20" /> + </mask> + </config> + + <config offset="0x3" name="CONFIG2H" wmask="0xFF" bvalue="0x1F" > + <mask name="WDT" value="0x01" > + <value value="0x00" name="Off" cname="_WDT_OFF" /> + <value value="0x01" name="On" cname="_WDT_ON" /> + </mask> + <mask name="WDTPS" value="0x1E" > + <value value="0x00" name="1:1" cname="_WDTPS_1" /> + <value value="0x02" name="1:2" cname="_WDTPS_2" /> + <value value="0x04" name="1:4" cname="_WDTPS_4" /> + <value value="0x06" name="1:8" cname="_WDTPS_8" /> + <value value="0x08" name="1:16" cname="_WDTPS_16" /> + <value value="0x0A" name="1:32" cname="_WDTPS_32" /> + <value value="0x0C" name="1:64" cname="_WDTPS_64" /> + <value value="0x0E" name="1:128" cname="_WDTPS_128" /> + <value value="0x10" name="1:256" cname="_WDTPS_256" /> + <value value="0x12" name="1:512" cname="_WDTPS_512" /> + <value value="0x14" name="1:1024" cname="_WDTPS_1024" /> + <value value="0x16" name="1:2048" cname="_WDTPS_2048" /> + <value value="0x18" name="1:4096" cname="_WDTPS_4096" /> + <value value="0x1A" name="1:8192" cname="_WDTPS_8192" /> + <value value="0x1C" name="1:16384" cname="_WDTPS_16384" /> + <value value="0x1E" name="1:32768" cname="_WDTPS_32768" /> + </mask> + </config> + + <config offset="0x4" name="CONFIG3L" wmask="0xFF" bvalue="0x83" > + <mask name="PM" value="0x03" > + <value value="0x00" name="Extended microcontroller" cname="_MODE_EM" /> + <value value="0x01" name="Microprocessor with boot" cname="_MODE_MPB" /> + <value value="0x02" name="Microprocessor" cname="_MODE_MP" /> + <value value="0x03" name="Microcontroller" cname="_MODE_MC" /> + </mask> + <mask name="WAIT" value="0x80" > + <value value="0x00" name="On" cname="_WAIT_ON" /> + <value value="0x80" name="Off" cname="_WAIT_OFF" /> + </mask> + </config> + + <config offset="0x5" name="CONFIG3H" wmask="0xFF" bvalue="0x83" cmask="0x02" > + <mask name="CCP2MX" value="0x01" > + <value value="0x00" name="RE7" cname="_CCP2MX_OFF" /> + <value value="0x01" name="RC1" cname="_CCP2MX_ON" /> + </mask> + <mask name="ECCPMX" value="0x02" > + <value value="0x00" name="RH7-RH6" cname="_ECCPMX_PORTH" /> + <value value="0x02" name="RE6-RE5" cname="_ECCPMX_PORTE" /> + </mask> + <mask name="MCLRE" value="0x80" > + <value value="0x00" name="Internal" cname="_MCLRE_OFF" /> + <value value="0x80" name="External" cname="_MCLRE_ON" /> + </mask> + </config> + + <config offset="0x6" name="CONFIG4L" wmask="0xFF" bvalue="0x85" > + <mask name="STVREN" value="0x01" > + <value value="0x00" name="Off" cname="_STVR_OFF" /> + <value value="0x01" name="On" cname="_STVR_ON" /> + </mask> + <mask name="LVP" value="0x04" > + <value value="0x00" name="Off" cname="_LVP_OFF" /> + <value value="0x04" name="On" cname="_LVP_ON" /> + </mask> + <mask name="DEBUG" value="0x80" > + <value value="0x00" name="On" cname="_DEBUG_ON" /> + <value value="0x80" name="Off" cname="_DEBUG_OFF" /> + </mask> + </config> + + <config offset="0x7" name="CONFIG4H" wmask="0xFF" bvalue="0x00" /> + + <config offset="0x8" name="CONFIG5L" wmask="0xFF" bvalue="0x07" > + <mask name="CP_0" value="0x01" > + <value value="0x00" name="0800:3FFF" cname="_CP0_ON" /> + <value value="0x01" name="Off" cname="_CP0_OFF" /> + </mask> + <mask name="CP_1" value="0x02" > + <value value="0x00" name="4000:7FFF" cname="_CP1_ON" /> + <value value="0x02" name="Off" cname="_CP1_OFF" /> + </mask> + <mask name="CP_2" value="0x04" > + <value value="0x00" name="8000:BFFF" cname="_CP2_ON" /> + <value value="0x04" name="Off" cname="_CP2_OFF" /> + </mask> + </config> + + <config offset="0x9" name="CONFIG5H" wmask="0xFF" bvalue="0xC0" > + <mask name="CPB" value="0x40" > + <value value="0x00" name="0000:07FF" cname="_CPB_ON" /> + <value value="0x40" name="Off" cname="_CPB_OFF" /> + </mask> + <mask name="CPD" value="0x80" > + <value value="0x00" name="All" cname="_CPD_ON" /> + <value value="0x80" name="Off" cname="_CPD_OFF" /> + </mask> + </config> + + <config offset="0xA" name="CONFIG6L" wmask="0xFF" bvalue="0x07" > + <mask name="WRT_0" value="0x01" > + <value value="0x00" name="0800:3FFF" cname="_WRT0_ON" /> + <value value="0x01" name="Off" cname="_WRT0_OFF" /> + </mask> + <mask name="WRT_1" value="0x02" > + <value value="0x00" name="4000:7FFF" cname="_WRT1_ON" /> + <value value="0x02" name="Off" cname="_WRT1_OFF" /> + </mask> + <mask name="WRT_2" value="0x04" > + <value value="0x00" name="8000:BFFF" cname="_WRT2_ON" /> + <value value="0x04" name="Off" cname="_WRT2_OFF" /> + </mask> + </config> + + <config offset="0xB" name="CONFIG6H" wmask="0xFF" bvalue="0xE0" > + <mask name="WRTC" value="0x20" > + <value value="0x00" name="All" cname="_WRTC_ON" /> + <value value="0x20" name="Off" cname="_WRTC_OFF" /> + </mask> + <mask name="WRTB" value="0x40" > + <value value="0x00" name="0000:07FF" cname="_WRTB_ON" /> + <value value="0x40" name="Off" cname="_WRTB_OFF" /> + </mask> + <mask name="WRTD" value="0x80" > + <value value="0x00" name="All" cname="_WRTD_ON" /> + <value value="0x80" name="Off" cname="_WRTD_OFF" /> + </mask> + </config> + + <config offset="0xC" name="CONFIG7L" wmask="0xFF" bvalue="0x07" > + <mask name="EBTR_0" value="0x01" > + <value value="0x00" name="0800:3FFF" cname="_EBTR0_ON" /> + <value value="0x01" name="Off" cname="_EBTR0_OFF" /> + </mask> + <mask name="EBTR_1" value="0x02" > + <value value="0x00" name="4000:7FFF" cname="_EBTR1_ON" /> + <value value="0x02" name="Off" cname="_EBTR1_OFF" /> + </mask> + <mask name="EBTR_2" value="0x04" > + <value value="0x00" name="8000:BFFF" cname="_EBTR2_ON" /> + <value value="0x04" name="Off" cname="_EBTR2_OFF" /> + </mask> + </config> + + <config offset="0xD" name="CONFIG7H" wmask="0xFF" bvalue="0x40" > + <mask name="EBTRB" value="0x40" > + <value value="0x00" name="0000:07FF" cname="_EBTRB_ON" /> + <value value="0x40" name="Off" cname="_EBTRB_OFF" /> + </mask> + </config> + +<!--* Packages *************************************************************--> + <package types="tqfp" nb_pins="80" > + <pin index="1" name="" /> + <pin index="2" name="" /> + <pin index="3" name="" /> + <pin index="4" name="" /> + <pin index="5" name="" /> + <pin index="6" name="" /> + <pin index="7" name="" /> + <pin index="8" name="" /> + <pin index="9" name="" /> + <pin index="10" name="" /> + <pin index="11" name="" /> + <pin index="12" name="" /> + <pin index="13" name="" /> + <pin index="14" name="" /> + <pin index="15" name="" /> + <pin index="16" name="" /> + <pin index="17" name="" /> + <pin index="18" name="" /> + <pin index="19" name="" /> + <pin index="20" name="" /> + <pin index="21" name="" /> + <pin index="22" name="" /> + <pin index="23" name="" /> + <pin index="24" name="" /> + <pin index="25" name="" /> + <pin index="26" name="" /> + <pin index="27" name="" /> + <pin index="28" name="" /> + <pin index="29" name="" /> + <pin index="30" name="" /> + <pin index="31" name="" /> + <pin index="32" name="" /> + <pin index="33" name="" /> + <pin index="34" name="" /> + <pin index="35" name="" /> + <pin index="36" name="" /> + <pin index="37" name="" /> + <pin index="38" name="" /> + <pin index="39" name="" /> + <pin index="40" name="" /> + <pin index="41" name="" /> + <pin index="42" name="" /> + <pin index="43" name="" /> + <pin index="44" name="" /> + <pin index="45" name="" /> + <pin index="46" name="" /> + <pin index="47" name="" /> + <pin index="48" name="" /> + <pin index="49" name="" /> + <pin index="50" name="" /> + <pin index="51" name="" /> + <pin index="52" name="" /> + <pin index="53" name="" /> + <pin index="54" name="" /> + <pin index="55" name="" /> + <pin index="56" name="" /> + <pin index="57" name="" /> + <pin index="58" name="" /> + <pin index="59" name="" /> + <pin index="60" name="" /> + <pin index="61" name="" /> + <pin index="62" name="" /> + <pin index="63" name="" /> + <pin index="64" name="" /> + <pin index="65" name="" /> + <pin index="66" name="" /> + <pin index="67" name="" /> + <pin index="68" name="" /> + <pin index="69" name="" /> + <pin index="70" name="" /> + <pin index="71" name="" /> + <pin index="72" name="" /> + <pin index="73" name="" /> + <pin index="74" name="" /> + <pin index="75" name="" /> + <pin index="76" name="" /> + <pin index="77" name="" /> + <pin index="78" name="" /> + <pin index="79" name="" /> + <pin index="80" name="" /> + </package> + +</device> |