-
Notifications
You must be signed in to change notification settings - Fork 4
/
rkafp.h
62 lines (48 loc) · 2.02 KB
/
rkafp.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
#ifndef _RKAFP_H
#define _RKAFP_H
#include <stdint.h>
#include <string.h>
/**
* Struct UPDATE_PART
* is embedded in the UPDATE_HEADER within an update.img file and represents a
* partition in the flash even though it is in the update.img file. The format
* of the update.img file is a design which has nothing to do with the format
* in the flash. Think of this as similar to a zip file directory record.
* Some of the offsets and lengths in this structure are in bytes. This makes this
* file format lame because these fields are only 32 bits, limiting partitions
* to 4 gbytes or so and the file format begins to fall over when it goes beyond
* 4 gbytes.
*
* See script file download_images.sh for a technique which does not use this
* poorly designed archive file format: "update.img". The partion files can
* come out of a standard archive file such as a zip file and be directed to
* their proper place in the flash using the parameter file, or a superset of it.
*/
struct UPDATE_PART {
char name[32];
char fullpath[60]; // a path of where the partition file came from
uint32_t flash_size; // how many sectors to reserve for this partition in the flash.
uint32_t part_offset; // starting byte offset within the update.img file for this partition
uint32_t flash_offset; // sector offset within the flash memory.
uint32_t padded_size; // part_bytecount rounded up to nearest sector in bytes
uint32_t part_bytecount; // size of partition source (bytes), lame because it's only 32 bits
};
struct UPDATE_HEADER {
char magic[4];
#define RKAFP_MAGIC "RKAF"
uint32_t length;
char model[34];
char id[30];
char manufacturer[56];
uint32_t unknown1;
uint32_t version;
uint32_t num_parts;
UPDATE_PART parts[16];
char reserved[116];
};
struct PARAM_HEADER {
char magic[4];
#define PARM_MAGIC "PARM"
uint32_t length;
};
#endif // _RKAFP_H