From f508189682b6fba62e08feeb1596f682bad5fff9 Mon Sep 17 00:00:00 2001 From: tpearson Date: Wed, 24 Feb 2010 18:42:24 +0000 Subject: Added KDE3 version of PikLab git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/piklab@1095639 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- src/progs/pickit2/base/pickit2.h | 123 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 src/progs/pickit2/base/pickit2.h (limited to 'src/progs/pickit2/base/pickit2.h') diff --git a/src/progs/pickit2/base/pickit2.h b/src/progs/pickit2/base/pickit2.h new file mode 100644 index 0000000..8efa8ff --- /dev/null +++ b/src/progs/pickit2/base/pickit2.h @@ -0,0 +1,123 @@ +/*************************************************************************** + * Copyright (C) 2006 Nicolas Hadacek * + * * + * 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 PICKIT2_H +#define PICKIT2_H + +#include "pickit.h" +#include "pickit2_data.h" + +namespace Pickit2 +{ +//----------------------------------------------------------------------------- +class Array : public Pickit::Array +{ +public: + Array() : Pickit::Array(64, 'Z', PrintAlphaNum) {} +}; + +//----------------------------------------------------------------------------- +class USBPort : public Pickit::USBPort +{ +public: + USBPort(Log::Base &log) : Pickit::USBPort(0x0033, log) {} + virtual Pickit::Array array() const { return Array(); } + void fillCommand(Pickit::Array &cmd1, uchar cmd2, uint nbBytes, uint address, uint i, bool longAddress = true) const; + Pickit::Array createCommand(uchar cmd, uint nbBytes, uint address, bool longAddress = true) const; + + bool readFirmwareCodeMemory(Device::Array &data, const Device::Array *vdata, ProgressMonitor &monitor); + //bool readFirmwareEepromMemory(Device::Array &data); + bool eraseFirmwareCodeMemory(); + bool writeFirmwareCodeMemory(const Device::Array &data, ProgressMonitor &monitor); + //bool writeFirmwareEepromMemory(const Device::Array &data); + bool resetFirmwareDevice(::Programmer::Mode mode) { return command(mode==::Programmer::BootloadMode ? 'B' : 0xFF); } + bool uploadFirmware(const Pic::Memory &memory, ProgressMonitor &monitor); + +private: + virtual uint readEndPoint() const { return 0x81; } + virtual uint writeEndPoint() const { return 0x01; } +}; + +//----------------------------------------------------------------------------- +class Hardware : public Pickit::Hardware +{ +public: + Hardware(::Programmer::Base &base) : Pickit::Hardware(base, new USBPort(base)) {} + virtual bool readVoltages(VoltagesData &voltages); + bool setVddVpp(double vdd, double vpp); +}; + +//----------------------------------------------------------------------------- +class Baseline : public Pickit::Baseline +{ +public: + Baseline(::Programmer::Base &base) : Pickit::Baseline(base) {} + virtual bool init(); + virtual char entryMode() const { return data(device().name()).entryMode; } + virtual uint nbWrites(Pic::MemoryRangeType type) const { return (type==Pic::MemoryRangeType::Eeprom ? 4 : 16); } +}; + +//----------------------------------------------------------------------------- +class P16F : public Pickit::P16F +{ +public: + P16F(::Programmer::Base &base) : Pickit::P16F(base) {} + virtual bool init(); + virtual char entryMode() const { return data(device().name()).entryMode; } + virtual uint nbWrites(Pic::MemoryRangeType type) const { return (type==Pic::MemoryRangeType::Code ? 16 : 4); } +}; + +class P16F87XA : public P16F +{ +public: + P16F87XA(::Programmer::Base &base) : P16F(base) {} + virtual bool init(); +}; + +class P16F7X : public P16F +{ +public: + P16F7X(::Programmer::Base &base) : P16F(base) {} + virtual bool init(); + virtual char writeCode() const { return 'w'; } +}; + +class P16F716 : public P16F +{ +public: + P16F716(::Programmer::Base &base) : P16F(base) {} + virtual bool init(); +}; + +//----------------------------------------------------------------------------- +class P18F : public Pickit::DeviceSpecific +{ +public: + P18F(::Programmer::Base &base) : Pickit::DeviceSpecific(base) {} + Hardware &hardware() { return static_cast(Pickit::DeviceSpecific::hardware()); } + virtual bool init(); + virtual bool doEraseRange(Pic::MemoryRangeType type); + virtual bool doErase(bool) { return doEraseCommand(0x87, 0x0F); } + bool doEraseCommand(uint cmd1, uint cmd2); + virtual bool doRead(Pic::MemoryRangeType type, Device::Array &data, const ::Programmer::VerifyData *vdata); + virtual bool doWrite(Pic::MemoryRangeType type, const Device::Array &data, bool force); + virtual char entryMode() const { return data(device().name()).entryMode; } +}; + +class P18F2X20 : public P18F +{ +public: + P18F2X20(::Programmer::Base &base) : P18F(base) {} + virtual bool doEraseRange(Pic::MemoryRangeType type); + virtual bool doErase(bool) { return doEraseCommand(0x80); } + bool doEraseCommand(uint cmd); +}; + +} // namespace + +#endif -- cgit v1.2.1