Skip to content

Commit 968a26a

Browse files
eberman-quicandersson
authored andcommitted
firmware: qcom_scm: Use fixed width src vm bitmap
The maximum VMID for assign_mem is 63. Use a u64 to represent this bitmap instead of architecture-dependent "unsigned int" which varies in size on 32-bit and 64-bit platforms. Acked-by: Kalle Valo <kvalo@kernel.org> (ath10k) Tested-by: Gokul krishna Krishnakumar <quic_gokukris@quicinc.com> Signed-off-by: Elliot Berman <quic_eberman@quicinc.com> Reviewed-by: Bjorn Andersson <andersson@kernel.org> Signed-off-by: Bjorn Andersson <andersson@kernel.org> Link: https://lore.kernel.org/r/20230213181832.3489174-1-quic_eberman@quicinc.com
1 parent 9e4a765 commit 968a26a

7 files changed

Lines changed: 17 additions & 15 deletions

File tree

drivers/firmware/qcom_scm.c

Lines changed: 7 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -905,7 +905,7 @@ static int __qcom_scm_assign_mem(struct device *dev, phys_addr_t mem_region,
905905
* Return negative errno on failure or 0 on success with @srcvm updated.
906906
*/
907907
int qcom_scm_assign_mem(phys_addr_t mem_addr, size_t mem_sz,
908-
unsigned int *srcvm,
908+
u64 *srcvm,
909909
const struct qcom_scm_vmperm *newvm,
910910
unsigned int dest_cnt)
911911
{
@@ -922,9 +922,9 @@ int qcom_scm_assign_mem(phys_addr_t mem_addr, size_t mem_sz,
922922
__le32 *src;
923923
void *ptr;
924924
int ret, i, b;
925-
unsigned long srcvm_bits = *srcvm;
925+
u64 srcvm_bits = *srcvm;
926926

927-
src_sz = hweight_long(srcvm_bits) * sizeof(*src);
927+
src_sz = hweight64(srcvm_bits) * sizeof(*src);
928928
mem_to_map_sz = sizeof(*mem_to_map);
929929
dest_sz = dest_cnt * sizeof(*destvm);
930930
ptr_sz = ALIGN(src_sz, SZ_64) + ALIGN(mem_to_map_sz, SZ_64) +
@@ -937,8 +937,10 @@ int qcom_scm_assign_mem(phys_addr_t mem_addr, size_t mem_sz,
937937
/* Fill source vmid detail */
938938
src = ptr;
939939
i = 0;
940-
for_each_set_bit(b, &srcvm_bits, BITS_PER_LONG)
941-
src[i++] = cpu_to_le32(b);
940+
for (b = 0; b < BITS_PER_TYPE(u64); b++) {
941+
if (srcvm_bits & BIT(b))
942+
src[i++] = cpu_to_le32(b);
943+
}
942944

943945
/* Fill details of mem buff to map */
944946
mem_to_map = ptr + ALIGN(src_sz, SZ_64);

drivers/misc/fastrpc.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -262,7 +262,7 @@ struct fastrpc_channel_ctx {
262262
int domain_id;
263263
int sesscount;
264264
int vmcount;
265-
u32 perms;
265+
u64 perms;
266266
struct qcom_scm_vmperm vmperms[FASTRPC_MAX_VMIDS];
267267
struct rpmsg_device *rpdev;
268268
struct fastrpc_session_ctx session[FASTRPC_MAX_SESSIONS];

drivers/net/wireless/ath/ath10k/qmi.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -33,7 +33,7 @@ static int ath10k_qmi_map_msa_permission(struct ath10k_qmi *qmi,
3333
{
3434
struct qcom_scm_vmperm dst_perms[3];
3535
struct ath10k *ar = qmi->ar;
36-
unsigned int src_perms;
36+
u64 src_perms;
3737
u32 perm_count;
3838
int ret;
3939

@@ -65,7 +65,7 @@ static int ath10k_qmi_unmap_msa_permission(struct ath10k_qmi *qmi,
6565
{
6666
struct qcom_scm_vmperm dst_perms;
6767
struct ath10k *ar = qmi->ar;
68-
unsigned int src_perms;
68+
u64 src_perms;
6969
int ret;
7070

7171
src_perms = BIT(QCOM_SCM_VMID_MSS_MSA) | BIT(QCOM_SCM_VMID_WLAN);

drivers/remoteproc/qcom_q6v5_mss.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -235,8 +235,8 @@ struct q6v5 {
235235
bool has_qaccept_regs;
236236
bool has_ext_cntl_regs;
237237
bool has_vq6;
238-
int mpss_perm;
239-
int mba_perm;
238+
u64 mpss_perm;
239+
u64 mba_perm;
240240
const char *hexagon_mdt_image;
241241
int version;
242242
};
@@ -414,7 +414,7 @@ static void q6v5_pds_disable(struct q6v5 *qproc, struct device **pds,
414414
}
415415
}
416416

417-
static int q6v5_xfer_mem_ownership(struct q6v5 *qproc, int *current_perm,
417+
static int q6v5_xfer_mem_ownership(struct q6v5 *qproc, u64 *current_perm,
418418
bool local, bool remote, phys_addr_t addr,
419419
size_t size)
420420
{
@@ -967,7 +967,7 @@ static int q6v5_mpss_init_image(struct q6v5 *qproc, const struct firmware *fw,
967967
unsigned long dma_attrs = DMA_ATTR_FORCE_CONTIGUOUS;
968968
dma_addr_t phys;
969969
void *metadata;
970-
int mdata_perm;
970+
u64 mdata_perm;
971971
int xferop_ret;
972972
size_t size;
973973
void *ptr;

drivers/remoteproc/qcom_q6v5_pas.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -94,7 +94,7 @@ struct qcom_adsp {
9494
size_t region_assign_size;
9595

9696
int region_assign_idx;
97-
int region_assign_perms;
97+
u64 region_assign_perms;
9898

9999
struct qcom_rproc_glink glink_subdev;
100100
struct qcom_rproc_subdev smd_subdev;

drivers/soc/qcom/rmtfs_mem.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@ struct qcom_rmtfs_mem {
3131

3232
unsigned int client_id;
3333

34-
unsigned int perms;
34+
u64 perms;
3535
};
3636

3737
static ssize_t qcom_rmtfs_mem_show(struct device *dev,

include/linux/firmware/qcom/qcom_scm.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -94,7 +94,7 @@ extern int qcom_scm_mem_protect_video_var(u32 cp_start, u32 cp_size,
9494
u32 cp_nonpixel_start,
9595
u32 cp_nonpixel_size);
9696
extern int qcom_scm_assign_mem(phys_addr_t mem_addr, size_t mem_sz,
97-
unsigned int *src,
97+
u64 *src,
9898
const struct qcom_scm_vmperm *newvm,
9999
unsigned int dest_cnt);
100100

0 commit comments

Comments
 (0)