A couple of SME updates for recent fixes (one of which went to stable):
reverting the flushing of the SME hardware state along with the thread flushing and making sure we have the correct vector length before reallocating. An ACPI/IORT fix to avoid skipping ID mappings whose "number of IDs" is 0 (the spec reports the number of IDs in the mapping range minus 1). -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEE5RElWfyWxS+3PLO2a9axLQDIXvEFAmTD40YACgkQa9axLQDI XvGmrw/+LSbXPWdBR4d4NnEOuw2YpD7jZ9DosfrtTUm5ca+gnQzLr+6Z9ysVOMX1 jzEEVMacFHidpY3cSl9waakl/SKHyu6yPFVkKONWz0iFGbqY9w1RWvCQb7APHWUe +aaav0GQU/WfnaOGfipuw5mcMpZT4NUTQK3EPZ4C++YvaN4uQiEzivNLmaHkQTqV DwY/tUf3AgbEslfV5SO97eXjuZ+TO1DANaI+wdVrHd1k5Zcq+XYIyw+sbTEdUJOx KBuK5SjfovNU8x7sg5i1aTBFVR3/sPlPrc0ueGYZsSn3/mWNQHOu/Iy3HYIdFPVM P16udTKruXFZsJCLUeykf9DD4d/WnV7wmKZOZgtDTmHUu45CKsZawYC+cVIkNAIx kUnEZM+GcLdMY7Ry2oyeeb/deFK6QEt8GfbKfqNubYn/MKvNabTGimKze2gk1cQR w7s/WWDN0finRJVy9SZrKvB3NbTw28aUZ+zDd1MzbSQncRtn0mZ2O06muxAbrP+C OqgtG1VEmwc0mWs8A79GQ9UBY4NCVCdl49bFTRBlot3eyLWu8nZyDzS6XELqB9/n Q5j7SOmj4CiOLfJGeTKNKs5cGf1mm2NUs8hpdEOaCEa0+rkAgfLsUnwDtMmHwQZ8 sHSsRwf4BR1KexfCpehqoic8XhOA9IjrDMQAx710cbQeLYiJ5iA= =qoWG -----END PGP SIGNATURE----- Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux Pull arm64 fixes from Catalin Marinas: - A couple of SME updates for recent fixes (one of which went to stable): reverting the flushing of the SME hardware state along with the thread flushing and making sure we have the correct vector length before reallocating. - An ACPI/IORT fix to avoid skipping ID mappings whose "number of IDs" is 0 (the spec reports the number of IDs in the mapping range minus 1). * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: ACPI/IORT: Remove erroneous id_count check in iort_node_get_rmr_info() arm64/sme: Set new vector length before reallocating arm64/fpsimd: Don't flush SME register hardware state along with thread
This commit is contained in:
commit
f837f0a3c9
@ -917,6 +917,8 @@ int vec_set_vector_length(struct task_struct *task, enum vec_type type,
|
|||||||
if (task == current)
|
if (task == current)
|
||||||
put_cpu_fpsimd_context();
|
put_cpu_fpsimd_context();
|
||||||
|
|
||||||
|
task_set_vl(task, type, vl);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Free the changed states if they are not in use, SME will be
|
* Free the changed states if they are not in use, SME will be
|
||||||
* reallocated to the correct size on next use and we just
|
* reallocated to the correct size on next use and we just
|
||||||
@ -931,8 +933,6 @@ int vec_set_vector_length(struct task_struct *task, enum vec_type type,
|
|||||||
if (free_sme)
|
if (free_sme)
|
||||||
sme_free(task);
|
sme_free(task);
|
||||||
|
|
||||||
task_set_vl(task, type, vl);
|
|
||||||
|
|
||||||
out:
|
out:
|
||||||
update_tsk_thread_flag(task, vec_vl_inherit_flag(type),
|
update_tsk_thread_flag(task, vec_vl_inherit_flag(type),
|
||||||
flags & PR_SVE_VL_INHERIT);
|
flags & PR_SVE_VL_INHERIT);
|
||||||
@ -1666,7 +1666,6 @@ void fpsimd_flush_thread(void)
|
|||||||
|
|
||||||
fpsimd_flush_thread_vl(ARM64_VEC_SME);
|
fpsimd_flush_thread_vl(ARM64_VEC_SME);
|
||||||
current->thread.svcr = 0;
|
current->thread.svcr = 0;
|
||||||
sme_smstop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
current->thread.fp_type = FP_STATE_FPSIMD;
|
current->thread.fp_type = FP_STATE_FPSIMD;
|
||||||
|
@ -1007,9 +1007,6 @@ static void iort_node_get_rmr_info(struct acpi_iort_node *node,
|
|||||||
for (i = 0; i < node->mapping_count; i++, map++) {
|
for (i = 0; i < node->mapping_count; i++, map++) {
|
||||||
struct acpi_iort_node *parent;
|
struct acpi_iort_node *parent;
|
||||||
|
|
||||||
if (!map->id_count)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
parent = ACPI_ADD_PTR(struct acpi_iort_node, iort_table,
|
parent = ACPI_ADD_PTR(struct acpi_iort_node, iort_table,
|
||||||
map->output_reference);
|
map->output_reference);
|
||||||
if (parent != iommu)
|
if (parent != iommu)
|
||||||
|
Loading…
Reference in New Issue
Block a user