summaryrefslogtreecommitdiffstats
path: root/src/devices/pic/prog/pic_debug.h
blob: dfb8af6baf9c0868db92d0e4e1c3109a5287786e (plain)
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
/***************************************************************************
 *   Copyright (C) 2006 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.                                   *
 ***************************************************************************/
#ifndef PIC_DEBUG_H
#define PIC_DEBUG_H

#include "progs/base/generic_debug.h"
#include "pic_prog.h"
#include "devices/base/register.h"

namespace Debugger
{
class PicBase;

//----------------------------------------------------------------------------
class PicSpecific : public DeviceSpecific
{
public:
  PicSpecific(Debugger::Base &base) : DeviceSpecific(base) {}
  const Pic::Data &device() const { return static_cast<const Pic::Data &>(*_base.device()); }
  PicBase &base();
  const PicBase &base() const;
  virtual bool updateStatus();
  virtual Register::TypeData wregTypeData() const = 0;
};

//----------------------------------------------------------------------------
class P16FSpecific : public PicSpecific
{
public:
  P16FSpecific(Debugger::Base &base) : PicSpecific(base) {}
  virtual QString statusString() const;
  virtual Register::TypeData wregTypeData() const;
};

//----------------------------------------------------------------------------
class P18FSpecific : public PicSpecific
{
public:
  P18FSpecific(Debugger::Base &base) : PicSpecific(base) {}
  virtual QString statusString() const;
  virtual bool updateStatus();
  virtual Register::TypeData wregTypeData() const;
};

//----------------------------------------------------------------------------
class PicBase : public Debugger::Base
{
public:
  PicBase(Programmer::PicBase &base) : Debugger::Base(base) {}
  PicSpecific *deviceSpecific() { return static_cast<PicSpecific *>(_deviceSpecific); }
  const PicSpecific *deviceSpecific() const { return static_cast<const PicSpecific *>(_deviceSpecific); }
  const Pic::Data *device() const { return static_cast<const Pic::Data *>(Debugger::Base::device()); }
  Register::TypeData registerTypeData(const QString &name) const;
  virtual bool updatePortStatus(uint index, QMap<uint, Device::PortBitData> &bits);
};

} // namespace

#endif