354 lines
9.3 KiB
C
354 lines
9.3 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Copyright (C) 2020 The Linux Foundation. All rights reserved.
|
|
*/
|
|
|
|
#include <linux/module.h>
|
|
#include <linux/soc/qcom/qmi.h>
|
|
|
|
#include "pdr_internal.h"
|
|
|
|
const struct qmi_elem_info servreg_location_entry_ei[] = {
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0,
|
|
.offset = offsetof(struct servreg_location_entry,
|
|
name),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_4_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u32),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0,
|
|
.offset = offsetof(struct servreg_location_entry,
|
|
instance),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_1_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0,
|
|
.offset = offsetof(struct servreg_location_entry,
|
|
service_data_valid),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_4_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u32),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0,
|
|
.offset = offsetof(struct servreg_location_entry,
|
|
service_data),
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_location_entry_ei);
|
|
|
|
const struct qmi_elem_info servreg_get_domain_list_req_ei[] = {
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x01,
|
|
.offset = offsetof(struct servreg_get_domain_list_req,
|
|
service_name),
|
|
},
|
|
{
|
|
.data_type = QMI_OPT_FLAG,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x10,
|
|
.offset = offsetof(struct servreg_get_domain_list_req,
|
|
domain_offset_valid),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_4_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u32),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x10,
|
|
.offset = offsetof(struct servreg_get_domain_list_req,
|
|
domain_offset),
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_get_domain_list_req_ei);
|
|
|
|
const struct qmi_elem_info servreg_get_domain_list_resp_ei[] = {
|
|
{
|
|
.data_type = QMI_STRUCT,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(struct qmi_response_type_v01),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
resp),
|
|
.ei_array = qmi_response_type_v01_ei,
|
|
},
|
|
{
|
|
.data_type = QMI_OPT_FLAG,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x10,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
total_domains_valid),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_2_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u16),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x10,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
total_domains),
|
|
},
|
|
{
|
|
.data_type = QMI_OPT_FLAG,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x11,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
db_rev_count_valid),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_2_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u16),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x11,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
db_rev_count),
|
|
},
|
|
{
|
|
.data_type = QMI_OPT_FLAG,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x12,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
domain_list_valid),
|
|
},
|
|
{
|
|
.data_type = QMI_DATA_LEN,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x12,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
domain_list_len),
|
|
},
|
|
{
|
|
.data_type = QMI_STRUCT,
|
|
.elem_len = SERVREG_DOMAIN_LIST_LENGTH,
|
|
.elem_size = sizeof(struct servreg_location_entry),
|
|
.array_type = VAR_LEN_ARRAY,
|
|
.tlv_type = 0x12,
|
|
.offset = offsetof(struct servreg_get_domain_list_resp,
|
|
domain_list),
|
|
.ei_array = servreg_location_entry_ei,
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_get_domain_list_resp_ei);
|
|
|
|
const struct qmi_elem_info servreg_register_listener_req_ei[] = {
|
|
{
|
|
.data_type = QMI_UNSIGNED_1_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x01,
|
|
.offset = offsetof(struct servreg_register_listener_req,
|
|
enable),
|
|
},
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_register_listener_req,
|
|
service_path),
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_register_listener_req_ei);
|
|
|
|
const struct qmi_elem_info servreg_register_listener_resp_ei[] = {
|
|
{
|
|
.data_type = QMI_STRUCT,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(struct qmi_response_type_v01),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_register_listener_resp,
|
|
resp),
|
|
.ei_array = qmi_response_type_v01_ei,
|
|
},
|
|
{
|
|
.data_type = QMI_OPT_FLAG,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u8),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x10,
|
|
.offset = offsetof(struct servreg_register_listener_resp,
|
|
curr_state_valid),
|
|
},
|
|
{
|
|
.data_type = QMI_SIGNED_4_BYTE_ENUM,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(enum servreg_service_state),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x10,
|
|
.offset = offsetof(struct servreg_register_listener_resp,
|
|
curr_state),
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_register_listener_resp_ei);
|
|
|
|
const struct qmi_elem_info servreg_restart_pd_req_ei[] = {
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x01,
|
|
.offset = offsetof(struct servreg_restart_pd_req,
|
|
service_path),
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_restart_pd_req_ei);
|
|
|
|
const struct qmi_elem_info servreg_restart_pd_resp_ei[] = {
|
|
{
|
|
.data_type = QMI_STRUCT,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(struct qmi_response_type_v01),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_restart_pd_resp,
|
|
resp),
|
|
.ei_array = qmi_response_type_v01_ei,
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_restart_pd_resp_ei);
|
|
|
|
const struct qmi_elem_info servreg_state_updated_ind_ei[] = {
|
|
{
|
|
.data_type = QMI_SIGNED_4_BYTE_ENUM,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u32),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x01,
|
|
.offset = offsetof(struct servreg_state_updated_ind,
|
|
curr_state),
|
|
},
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_state_updated_ind,
|
|
service_path),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_2_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u16),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x03,
|
|
.offset = offsetof(struct servreg_state_updated_ind,
|
|
transaction_id),
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_state_updated_ind_ei);
|
|
|
|
const struct qmi_elem_info servreg_set_ack_req_ei[] = {
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x01,
|
|
.offset = offsetof(struct servreg_set_ack_req,
|
|
service_path),
|
|
},
|
|
{
|
|
.data_type = QMI_UNSIGNED_2_BYTE,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(u16),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_set_ack_req,
|
|
transaction_id),
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_set_ack_req_ei);
|
|
|
|
const struct qmi_elem_info servreg_set_ack_resp_ei[] = {
|
|
{
|
|
.data_type = QMI_STRUCT,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof(struct qmi_response_type_v01),
|
|
.array_type = NO_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_set_ack_resp,
|
|
resp),
|
|
.ei_array = qmi_response_type_v01_ei,
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_set_ack_resp_ei);
|
|
|
|
const struct qmi_elem_info servreg_loc_pfr_req_ei[] = {
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = VAR_LEN_ARRAY,
|
|
.tlv_type = 0x01,
|
|
.offset = offsetof(struct servreg_loc_pfr_req, service)
|
|
},
|
|
{
|
|
.data_type = QMI_STRING,
|
|
.elem_len = SERVREG_NAME_LENGTH + 1,
|
|
.elem_size = sizeof(char),
|
|
.array_type = VAR_LEN_ARRAY,
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_loc_pfr_req, reason)
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_loc_pfr_req_ei);
|
|
|
|
const struct qmi_elem_info servreg_loc_pfr_resp_ei[] = {
|
|
{
|
|
.data_type = QMI_STRUCT,
|
|
.elem_len = 1,
|
|
.elem_size = sizeof_field(struct servreg_loc_pfr_resp, rsp),
|
|
.tlv_type = 0x02,
|
|
.offset = offsetof(struct servreg_loc_pfr_resp, rsp),
|
|
.ei_array = qmi_response_type_v01_ei,
|
|
},
|
|
{}
|
|
};
|
|
EXPORT_SYMBOL_GPL(servreg_loc_pfr_resp_ei);
|
|
|
|
MODULE_LICENSE("GPL");
|
|
MODULE_DESCRIPTION("Qualcomm Protection Domain messages data");
|