/usr/include/gpsim/16bit-processors.h is in gpsim-dev 0.27.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 | /*
Copyright (C) 1998 T. Scott Dattalo
This file is part of the libgpsim library of gpsim
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library 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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, see
<http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
#ifndef __16_BIT_PROCESSORS_H__
#define __16_BIT_PROCESSORS_H__
#include "pic-processor.h"
#include "pic-ioports.h"
#include "intcon.h"
#include "16bit-registers.h"
#include "16bit-tmrs.h"
#include "pir.h"
#include "uart.h"
#include "a2dconverter.h"
#include "a2d_v2.h"
#include "value.h"
// forward references
extern instruction *disasm16 (pic_processor *cpu, unsigned int address, unsigned int inst);
class ConfigMemory;
//------------------------------------------------------------------------
//
// pic_processor
// |
// \__ _16bit_processor
//
// Base class for the 16bit PIC processors
//
class _16bit_processor : public pic_processor
{
public:
static const unsigned int CONFIG1L = 0x300000;
static const unsigned int CONFIG1H = 0x300001;
static const unsigned int CONFIG2L = 0x300002;
static const unsigned int CONFIG2H = 0x300003;
static const unsigned int CONFIG3L = 0x300004;
static const unsigned int CONFIG3H = 0x300005;
static const unsigned int CONFIG4L = 0x300006;
static const unsigned int CONFIG4H = 0x300007;
static const unsigned int CONFIG5L = 0x300008;
static const unsigned int CONFIG5H = 0x300009;
static const unsigned int CONFIG6L = 0x30000A;
static const unsigned int CONFIG6H = 0x30000B;
static const unsigned int CONFIG7L = 0x30000C;
static const unsigned int CONFIG7H = 0x30000D;
// The early 18xxx parts all contain ports A,B,C
PicPortRegister *m_porta;
PicTrisRegister *m_trisa;
PicLatchRegister *m_lata;
PicPortBRegister *m_portb;
PicTrisRegister *m_trisb;
PicLatchRegister *m_latb;
PicPortRegister *m_portc;
PicTrisRegister *m_trisc;
PicLatchRegister *m_latc;
sfr_register adresl;
sfr_register adresh;
INTCON_16 intcon;
INTCON2 intcon2;
INTCON3 intcon3;
BSR bsr;
TMR0_16 tmr0l;
TMR0H tmr0h;
T0CON t0con;
RCON rcon;
PIR1v2 pir1;
sfr_register ipr1;
sfr_register ipr2;
T1CON t1con;
PIE pie1;
PIR2v2 pir2;
PIE pie2;
T2CON t2con;
PR2 pr2;
TMR2 tmr2;
TMRL tmr1l;
TMRH tmr1h;
CCPCON ccp1con;
CCPRL ccpr1l;
CCPRH ccpr1h;
CCPCON ccp2con;
CCPRL ccpr2l;
CCPRH ccpr2h;
TMRL tmr3l;
TMRH tmr3h;
T3CON t3con;
PIR_SET_2 pir_set_def;
OSCCON osccon;
LVDCON lvdcon;
WDTCON wdtcon;
sfr_register prodh,prodl;
sfr_register pclatu;
Fast_Stack fast_stack;
Indirect_Addressing ind0;
Indirect_Addressing ind1;
Indirect_Addressing ind2;
USART_MODULE usart;
//Stack16 stack16;
TBL_MODULE tbl;
TMR2_MODULE tmr2_module;
TMR3_MODULE tmr3_module;
SSP_MODULE ssp;
// Some configuration stuff for stripping down where needed
virtual bool HasPortC(void) { return true; };
virtual bool HasCCP2(void) { return true; };
virtual void create_symbols();
void interrupt();
virtual void create();// {return;};
virtual PROCESSOR_TYPE isa(){return _PIC17_PROCESSOR_;};
virtual PROCESSOR_TYPE base_isa(){return _PIC17_PROCESSOR_;};
virtual unsigned int access_gprs() { return 0x80; };
virtual instruction * disasm (unsigned int address, unsigned int inst)
{
return disasm16(this, address, inst);
}
virtual void create_sfr_map();
virtual void delete_sfr_map();
virtual void create_config_memory();
// Return the portion of pclath that is used during branching instructions
virtual unsigned int get_pclath_branching_jump()
{
return ((pclatu.value.get()<<16) | ((pclath->value.get() & 0xf8)<<8));
}
// Return the portion of pclath that is used during modify PCL instructions
virtual unsigned int get_pclath_branching_modpcl()
{
return ((pclatu.value.get()<<16) | ((pclath->value.get() & 0xff)<<8));
}
virtual void option_new_bits_6_7(unsigned int);
// Declare a set of functions that will allow the base class to
// get information about the derived classes. NOTE, the values returned here
// will cause errors if they are used (in some cases)
// -- the derived classes must define their parameters appropriately.
virtual unsigned int register_memory_size () const { return 0x1000;};
virtual unsigned int last_actual_register () const { return 0x0F7F;};
virtual void set_out_of_range_pm(unsigned int address, unsigned int value);
virtual void create_iopin_map();
virtual int map_pm_address2index(int address) const {return address/2;};
virtual int map_pm_index2address(int index) const {return index*2;};
virtual unsigned int get_program_memory_at_address(unsigned int address);
virtual unsigned int get_config_word(unsigned int address);
virtual bool set_config_word(unsigned int address, unsigned int cfg_word);
virtual unsigned int configMemorySize() { return CONFIG7H-CONFIG1L+1; }
virtual unsigned int IdentMemorySize() const { return 4; } // four words default (18F)
virtual void enter_sleep();
virtual void exit_sleep();
virtual void osc_mode(unsigned int );
virtual void set_extended_instruction(bool);
virtual bool extended_instruction() {return extended_instruction_flag;}
static pic_processor *construct();
_16bit_processor(const char *_name=0, const char *desc=0);
virtual ~_16bit_processor();
unsigned int getCurrentDisasmAddress() { return m_current_disasm_address;}
unsigned int getCurrentDisasmIndex() { return m_current_disasm_address/2;}
void setCurrentDisasmAddress(unsigned a) { m_current_disasm_address =a; }
protected:
unsigned int m_current_disasm_address; // Used only when .hex/.cod files are loaded
unsigned int idloc[4]; ///< ID locations - not all 16-bit CPUs have 8 bytes
bool extended_instruction_flag; // Instruction set extension and Indexed Addressing
unsigned int last_register;
};
class _16bit_compat_adc : public _16bit_processor
{
public:
ADCON0 *adcon0;
ADCON1 *adcon1;
_16bit_compat_adc(const char *_name=0, const char *desc=0);
~_16bit_compat_adc();
virtual void create_symbols();
virtual void create();
virtual void create_sfr_map();
virtual void a2d_compat();
};
class _16bit_v2_adc : public _16bit_processor
{
public:
ADCON0_V2 *adcon0;
ADCON1_V2 *adcon1;
ADCON2_V2 *adcon2;
_16bit_v2_adc(const char *_name=0, const char *desc=0);
~_16bit_v2_adc();
virtual void create(int nChannels);
};
#define cpu16 ( (_16bit_processor *)cpu)
#define FOSC0 (1<<0)
#define FOSC1 (1<<1)
#define FOSC2 (1<<2)
// FOSC3 may not be used
#define FOSC3 (1<<3)
#define OSCEN (1<<5)
//------------------------------------------------------------------------
// Config1H - default 3 bits FOSC
class Config1H : public ConfigWord
{
#define CONFIG1H_default (OSCEN | FOSC2 | FOSC1 | FOSC0)
public:
Config1H(_16bit_processor *pCpu, unsigned int addr)
: ConfigWord("CONFIG1H", CONFIG1H_default, "Oscillator configuration", pCpu, addr)
{
set(CONFIG1H_default);
}
virtual void set(gint64 v)
{
Integer::set(v);
if (m_pCpu)
{
m_pCpu->osc_mode(v & ( FOSC2 | FOSC1 | FOSC0));
}
}
virtual string toString();
};
//------------------------------------------------------------------------
// Config1H - 4 bits FOSC
class Config1H_4bits : public ConfigWord
{
public:
Config1H_4bits(_16bit_processor *pCpu, unsigned int addr, unsigned int def_val)
: ConfigWord("CONFIG1H", def_val, "Oscillator configuration", pCpu, addr)
{
set(def_val);
}
virtual void set(gint64 v)
{
Integer::set(v);
if (m_pCpu)
{
m_pCpu->osc_mode(v & ( FOSC3 | FOSC2 | FOSC1 | FOSC0));
}
}
virtual string toString();
};
#endif
|