-
Notifications
You must be signed in to change notification settings - Fork 308
/
plat_auth.c
59 lines (46 loc) · 1.79 KB
/
plat_auth.c
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
// SPDX-License-Identifier: BSD-3-Clause
//
// Copyright(c) 2017 Intel Corporation. All rights reserved.
//
// Author: Liam Girdwood <liam.r.girdwood@linux.intel.com>
// Keyon Jie <yang.jie@linux.intel.com>
#include "rimage.h"
#include "manifest.h"
#include "plat_auth.h"
void ri_adsp_meta_data_create_v1_8(struct image *image, int meta_start_offset,
int meta_end_offset)
{
struct sof_man_adsp_meta_file_ext_v1_8 *meta =
image->fw_image + meta_start_offset;
fprintf(stdout, " meta: completing ADSP manifest\n");
meta->comp_desc[0].limit_offset = MAN_DESC_OFFSET_V1_8 +
image->image_end - meta_end_offset;
fprintf(stdout, " meta: limit is 0x%x\n",
meta->comp_desc[0].limit_offset);
/* now hash the AdspFwBinaryDesc -> EOF */
}
void ri_adsp_meta_data_create_v2_5(struct image *image, int meta_start_offset,
int meta_end_offset)
{
struct sof_man_adsp_meta_file_ext_v2_5 *meta =
image->fw_image + meta_start_offset;
fprintf(stdout, " meta: completing ADSP manifest\n");
meta->comp_desc[0].limit_offset = MAN_DESC_OFFSET_V1_8 +
image->image_end - meta_end_offset;
fprintf(stdout, " meta: limit is 0x%x\n",
meta->comp_desc[0].limit_offset);
/* now hash the AdspFwBinaryDesc -> EOF */
}
void ri_plat_ext_data_create(struct image *image)
{
struct partition_info_ext *part = image->fw_image
+ MAN_PART_INFO_OFFSET_V1_8;
struct sof_man_adsp_meta_file_ext_v1_8 *meta =
image->fw_image + MAN_META_EXT_OFFSET_V1_8;
struct sof_man_fw_desc *desc = image->fw_image + MAN_DESC_OFFSET_V1_8;
fprintf(stdout, " auth: completing authentication manifest\n");
part->length = meta->comp_desc[0].limit_offset - MAN_DESC_OFFSET_V1_8;
part->length += MAN_PAGE_SIZE - (part->length % MAN_PAGE_SIZE);
/* do this here atm */
desc->header.preload_page_count = part->length / MAN_PAGE_SIZE;
}