186ce2a71SBen Skeggs #ifndef __NVFW_SEC2_H__ 286ce2a71SBen Skeggs #define __NVFW_SEC2_H__ 386ce2a71SBen Skeggs 47a4dde71SBen Skeggs struct nv_sec2_args { 57a4dde71SBen Skeggs u32 freq_hz; 67a4dde71SBen Skeggs u32 falc_trace_size; 77a4dde71SBen Skeggs u32 falc_trace_dma_base; 87a4dde71SBen Skeggs u32 falc_trace_dma_idx; 97a4dde71SBen Skeggs bool secure_mode; 107a4dde71SBen Skeggs }; 117a4dde71SBen Skeggs 12d114a139SBen Skeggs #define NV_SEC2_UNIT_INIT 0x01 1386ce2a71SBen Skeggs #define NV_SEC2_UNIT_ACR 0x08 1486ce2a71SBen Skeggs 15d114a139SBen Skeggs struct nv_sec2_init_msg { 16b448a266STimur Tabi struct nvfw_falcon_msg hdr; 17d114a139SBen Skeggs #define NV_SEC2_INIT_MSG_INIT 0x00 18d114a139SBen Skeggs u8 msg_type; 19d114a139SBen Skeggs 20d114a139SBen Skeggs u8 num_queues; 21d114a139SBen Skeggs u16 os_debug_entry_point; 22d114a139SBen Skeggs 23d114a139SBen Skeggs struct { 24d114a139SBen Skeggs u32 offset; 25d114a139SBen Skeggs u16 size; 26d114a139SBen Skeggs u8 index; 27d114a139SBen Skeggs #define NV_SEC2_INIT_MSG_QUEUE_ID_CMDQ 0x00 28d114a139SBen Skeggs #define NV_SEC2_INIT_MSG_QUEUE_ID_MSGQ 0x01 29d114a139SBen Skeggs u8 id; 30d114a139SBen Skeggs } queue_info[2]; 31d114a139SBen Skeggs 32d114a139SBen Skeggs u32 sw_managed_area_offset; 33d114a139SBen Skeggs u16 sw_managed_area_size; 34d114a139SBen Skeggs }; 35d114a139SBen Skeggs 3686ce2a71SBen Skeggs struct nv_sec2_acr_cmd { 37b448a266STimur Tabi struct nvfw_falcon_cmd hdr; 3886ce2a71SBen Skeggs #define NV_SEC2_ACR_CMD_BOOTSTRAP_FALCON 0x00 3986ce2a71SBen Skeggs u8 cmd_type; 4086ce2a71SBen Skeggs }; 4186ce2a71SBen Skeggs 4286ce2a71SBen Skeggs struct nv_sec2_acr_msg { 43b448a266STimur Tabi struct nvfw_falcon_cmd hdr; 4486ce2a71SBen Skeggs u8 msg_type; 4586ce2a71SBen Skeggs }; 4686ce2a71SBen Skeggs 4786ce2a71SBen Skeggs struct nv_sec2_acr_bootstrap_falcon_cmd { 4886ce2a71SBen Skeggs struct nv_sec2_acr_cmd cmd; 4986ce2a71SBen Skeggs #define NV_SEC2_ACR_BOOTSTRAP_FALCON_FLAGS_RESET_YES 0x00000000 5086ce2a71SBen Skeggs #define NV_SEC2_ACR_BOOTSTRAP_FALCON_FLAGS_RESET_NO 0x00000001 5186ce2a71SBen Skeggs u32 flags; 5286ce2a71SBen Skeggs u32 falcon_id; 5386ce2a71SBen Skeggs }; 5486ce2a71SBen Skeggs 5586ce2a71SBen Skeggs struct nv_sec2_acr_bootstrap_falcon_msg { 5686ce2a71SBen Skeggs struct nv_sec2_acr_msg msg; 5786ce2a71SBen Skeggs u32 error_code; 5886ce2a71SBen Skeggs u32 falcon_id; 5986ce2a71SBen Skeggs }; 6086ce2a71SBen Skeggs #endif 61