-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpar2creator.h
156 lines (116 loc) · 6.21 KB
/
par2creator.h
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
// This file is part of par2cmdline (a PAR 2.0 compatible file verification and
// repair tool). See http://parchive.sourceforge.net for details of PAR 2.0.
//
// Copyright (c) 2003 Peter Brian Clements
//
// par2cmdline 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.
//
// par2cmdline 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; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#ifndef __PAR2CREATOR_H__
#define __PAR2CREATOR_H__
#include <pthread.h>
class MainPacket;
class CreatorPacket;
class CriticalPacket;
class Par2Creator
{
public:
Par2Creator(void);
~Par2Creator(void);
// Create recovery files from the source files specified on the command line
Result Process(const CommandLine &commandline);
protected:
// Steps in the creation process:
// Compute block size from block count or vice versa depending on which was
// specified on the command line
bool ComputeBlockSizeAndBlockCount(const list<CommandLine::ExtraFile> &extrafiles);
// Determine how many recovery blocks to create based on the source block
// count and the requested level of redundancy.
bool ComputeRecoveryBlockCount(u32 redundancy);
// Determine how much recovery data can be computed on one pass
bool CalculateProcessBlockSize(size_t memorylimit);
// Determine how many recovery files to create.
bool ComputeRecoveryFileCount(void);
// Open all of the source files, compute the Hashes and CRC values, and store
// the results in the file verification and file description packets.
bool OpenSourceFiles(const list<CommandLine::ExtraFile> &extrafiles);
// Create the main packet and determine the set_id_hash to use with all packets
bool CreateMainPacket(void);
// Create the creator packet.
bool CreateCreatorPacket(void);
// Initialise all of the source blocks ready to start reading data from the source files.
bool CreateSourceBlocks(void);
// Create all of the output files and allocate all packets to appropriate file offets.
bool InitialiseOutputFiles(string par2filename);
// Allocate memory buffers for reading and writing data to disk.
bool AllocateBuffers(void);
// Compute the Reed Solomon matrix
bool ComputeRSMatrix(void);
// Read source data, process it through the RS matrix and write it to disk.
bool ProcessData(u64 blockoffset, size_t blocklength);
// Finish computation of the recovery packets and write the headers to disk.
bool WriteRecoveryPacketHeaders(void);
// Finish computing the full file hash values of the source files
bool FinishFileHashComputation(void);
// Fill in all remaining details in the critical packets.
bool FinishCriticalPackets(void);
// Write all other critical packets to disk.
bool WriteCriticalPackets(void);
// Close all files.
bool CloseFiles(void);
// Submethods of ProcessData
bool CreateParityBlocks (size_t blocklength, u32 inputindex);
// In the next function, aEndBlockNo is the last block number + 1.
void CreateParityBlockRange (size_t blocklength, u32 inputindex, u32 aStartBlockNo, u32 aEndBlockNo);
// Thread start function
static void *CreateParityBlockRangeFunc (void *aParams);
protected:
CommandLine::NoiseLevel noiselevel; // How noisy we should be
u64 blocksize; // The size of each block.
size_t chunksize; // How much of each block will be processed at a
// time (due to memory constraints).
void *inputbuffer; // chunksize
void *outputbuffer; // chunksize * recoveryblockcount
u32 sourcefilecount; // Number of source files for which recovery data will be computed.
u32 sourceblockcount; // Total number of data blocks that the source files will be
// virtualy sliced into.
u64 largestfilesize; // The size of the largest source file
CommandLine::Scheme recoveryfilescheme; // What scheme will be used to select the
// sizes for the recovery files.
u32 recoveryfilecount; // The number of recovery files that will be created
u32 recoveryblockcount; // The number of recovery blocks that will be placed
// in the recovery files.
u32 firstrecoveryblock; // The lowest exponent value to use for the recovery blocks.
MainPacket *mainpacket; // The main packet
CreatorPacket *creatorpacket; // The creator packet
vector<Par2CreatorSourceFile*> sourcefiles; // Array containing details of the source files
// as well as the file verification and file
// description packets for them.
vector<DataBlock> sourceblocks; // Array with one entry for every source block.
vector<DiskFile> recoveryfiles; // Array with one entry for every recovery file.
vector<RecoveryPacket> recoverypackets; // Array with one entry for every recovery packet.
list<CriticalPacket*> criticalpackets; // A list of all of the critical packets.
list<CriticalPacketEntry> criticalpacketentries; // A list of which critical packet will
// be written to which recovery file.
ReedSolomon<Galois16> rs; // The Reed Solomon matrix.
u64 progress; // How much data has been processed.
u64 totaldata; // Total amount of data to be processed.
int previouslyReportedFraction;
pthread_mutex_t progressMutex;
int numCPUs;
bool deferhashcomputation; // If we have enough memory to compute all recovery data
// in one pass, then we can defer the computation of
// the full file hash and block crc and hashes until
// the recovery data is computed.
};
#endif // __PAR2CREATOR_H__