File: picbus.h

package info (click to toggle)
ponyprog 3.1.4%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 11,904 kB
  • sloc: cpp: 35,932; python: 981; sh: 565; xml: 67; makefile: 45; ansic: 38
file content (126 lines) | stat: -rw-r--r-- 3,715 bytes parent folder | download
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
//=========================================================================//
//                                                                         //
//  PonyProg - Serial Device Programmer                                    //
//                                                                         //
//  Copyright (C) 1997-2025   Claudio Lanconelli                           //
//                                                                         //
//  https://github.com/lancos/ponyprog                                        //
//                                                                         //
//-------------------------------------------------------------------------//
//                                                                         //
// 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 version2 of        //
// the License, or (at your option) any later version.                     //
//                                                                         //
// This program 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       //
// General Public License for more details.                                //
//                                                                         //
// You should have received a copy of the GNU  General Public License      //
// along with this program (see LICENSE);     if not, write to the         //
// Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. //
//                                                                         //
//=========================================================================//

#ifndef _PICBUS_H
#define _PICBUS_H

#include "busio.h"
#include "pgminter.h"

class PicBus : public BusIO
{
  public:
	PicBus(BusInterface *ptr = 0);
	//virtual ~PicBus();

	long Read(int addr, uint8_t *data, long length, int page_size = 0);
	long Write(int addr, uint8_t const *data, long length, int page_size = 0);

	int Erase(int type = ALL_TYPE);

	int Reset();

	long ReadConfig(uint16_t *data);
	long WriteConfig(uint16_t *data);

	void DisableCodeProtect();

	int CompareSingleWord(uint16_t data1, uint16_t data2, uint16_t mask);
	int CompareMultiWord(uint8_t *data1, uint8_t *data2, long length, int split);

	void SetDelay();

  protected:
	int SendDataWord(long wo, int wlen = 16);
	long RecDataWord(int wlen = 16);
	int WaitReadyAfterWrite(long timeout = 5000);

	int SendCmdCode(int opcode);
	int SendProgCode(uint16_t data);
	uint16_t RecvProgCode();
	int SendDataCode(uint16_t data);
	uint16_t RecvDataCode();

	void SetMCLR()
	{
		busI->SetControlLine(1);
	}
	void ClearMCLR()
	{
		busI->SetControlLine(0);
	}

	const uint16_t DataMask;
	const uint16_t ProgMask;

	//Command Opcode
	const uint8_t ReadProgCode;
	const uint8_t LoadProgCode;
	const uint8_t ReadDataCode;
	const uint8_t LoadDataCode;
	const uint8_t LoadConfigCode;
	const uint8_t IncAddressCode;
	const uint8_t EraseProgMem;
	const uint8_t EraseDataMem;
	const uint8_t BeginEraseProgCode;
	const uint8_t BeginProgOnlyCode;

  private:
	int SendDataBit(int b);
	int RecDataBit();

	void bitDI(int b)
	{
		busI->SetInvDataOut(b);
	}

	void setDI()
	{
		busI->SetInvDataOut(1);
	}

	void clearDI()
	{
		busI->SetInvDataOut(0);
	}

	void setCLK()
	{
		busI->SetClock(1);
	}

	void clearCLK()
	{
		busI->SetClock(0);
	}

	int getDO() const
	{
		return busI->GetDataIn();
	}
};

#endif