hc
2023-12-06 d38611ca164021d018c1b23eee65bbebc09c63e0
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
/* SPDX-License-Identifier: MIT */
#ifndef __NVKM_ACR_H__
#define __NVKM_ACR_H__
#define nvkm_acr(p) container_of((p), struct nvkm_acr, subdev)
#include <core/subdev.h>
#include <core/falcon.h>
 
enum nvkm_acr_lsf_id {
   NVKM_ACR_LSF_PMU = 0,
   NVKM_ACR_LSF_GSPLITE = 1,
   NVKM_ACR_LSF_FECS = 2,
   NVKM_ACR_LSF_GPCCS = 3,
   NVKM_ACR_LSF_NVDEC = 4,
   NVKM_ACR_LSF_SEC2 = 7,
   NVKM_ACR_LSF_MINION = 10,
   NVKM_ACR_LSF_NUM
};
 
static inline const char *
nvkm_acr_lsf_id(enum nvkm_acr_lsf_id id)
{
   switch (id) {
   case NVKM_ACR_LSF_PMU    : return "pmu";
   case NVKM_ACR_LSF_GSPLITE: return "gsplite";
   case NVKM_ACR_LSF_FECS   : return "fecs";
   case NVKM_ACR_LSF_GPCCS  : return "gpccs";
   case NVKM_ACR_LSF_NVDEC  : return "nvdec";
   case NVKM_ACR_LSF_SEC2   : return "sec2";
   case NVKM_ACR_LSF_MINION : return "minion";
   default:
       return "unknown";
   }
}
 
struct nvkm_acr {
   const struct nvkm_acr_func *func;
   struct nvkm_subdev subdev;
 
   struct list_head hsfw, hsf;
   struct list_head lsfw, lsf;
 
   u64 managed_falcons;
 
   struct nvkm_memory *wpr;
   u64 wpr_start;
   u64 wpr_end;
   u64 shadow_start;
 
   struct nvkm_memory *inst;
   struct nvkm_vmm *vmm;
 
   bool done;
 
   const struct firmware *wpr_fw;
   bool wpr_comp;
   u64 wpr_prev;
};
 
bool nvkm_acr_managed_falcon(struct nvkm_device *, enum nvkm_acr_lsf_id);
int nvkm_acr_bootstrap_falcons(struct nvkm_device *, unsigned long mask);
 
int gm200_acr_new(struct nvkm_device *, int, struct nvkm_acr **);
int gm20b_acr_new(struct nvkm_device *, int, struct nvkm_acr **);
int gp102_acr_new(struct nvkm_device *, int, struct nvkm_acr **);
int gp108_acr_new(struct nvkm_device *, int, struct nvkm_acr **);
int gp10b_acr_new(struct nvkm_device *, int, struct nvkm_acr **);
int tu102_acr_new(struct nvkm_device *, int, struct nvkm_acr **);
 
struct nvkm_acr_lsfw {
   const struct nvkm_acr_lsf_func *func;
   struct nvkm_falcon *falcon;
   enum nvkm_acr_lsf_id id;
 
   struct list_head head;
 
   struct nvkm_blob img;
 
   const struct firmware *sig;
 
   u32 bootloader_size;
   u32 bootloader_imem_offset;
 
   u32 app_size;
   u32 app_start_offset;
   u32 app_imem_entry;
   u32 app_resident_code_offset;
   u32 app_resident_code_size;
   u32 app_resident_data_offset;
   u32 app_resident_data_size;
 
   u32 ucode_size;
   u32 data_size;
 
   struct {
       u32 lsb;
       u32 img;
       u32 bld;
   } offset;
   u32 bl_data_size;
};
 
struct nvkm_acr_lsf_func {
/* The (currently) map directly to LSB header flags. */
#define NVKM_ACR_LSF_LOAD_CODE_AT_0                                  0x00000001
#define NVKM_ACR_LSF_DMACTL_REQ_CTX                                  0x00000004
#define NVKM_ACR_LSF_FORCE_PRIV_LOAD                                 0x00000008
   u32 flags;
   u32 bld_size;
   void (*bld_write)(struct nvkm_acr *, u32 bld, struct nvkm_acr_lsfw *);
   void (*bld_patch)(struct nvkm_acr *, u32 bld, s64 adjust);
   int (*boot)(struct nvkm_falcon *);
   u64 bootstrap_falcons;
   int (*bootstrap_falcon)(struct nvkm_falcon *, enum nvkm_acr_lsf_id);
   int (*bootstrap_multiple_falcons)(struct nvkm_falcon *, u32 mask);
};
 
int
nvkm_acr_lsfw_load_sig_image_desc(struct nvkm_subdev *, struct nvkm_falcon *,
                 enum nvkm_acr_lsf_id, const char *path,
                 int ver, const struct nvkm_acr_lsf_func *);
int
nvkm_acr_lsfw_load_sig_image_desc_v1(struct nvkm_subdev *, struct nvkm_falcon *,
                    enum nvkm_acr_lsf_id, const char *path,
                    int ver, const struct nvkm_acr_lsf_func *);
int
nvkm_acr_lsfw_load_bl_inst_data_sig(struct nvkm_subdev *, struct nvkm_falcon *,
                   enum nvkm_acr_lsf_id, const char *path,
                   int ver, const struct nvkm_acr_lsf_func *);
#endif