/* * FP/SIMD state saving and restoring * * Copyright (C) 2012 ARM Ltd. * Author: Catalin Marinas * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include #include /* * Save the FP registers. * * x0 - pointer to struct fpsimd_state */ ENTRY(fpsimd_save_state) stp q0, q1, [x0, #16 * 0] stp q2, q3, [x0, #16 * 2] stp q4, q5, [x0, #16 * 4] stp q6, q7, [x0, #16 * 6] stp q8, q9, [x0, #16 * 8] stp q10, q11, [x0, #16 * 10] stp q12, q13, [x0, #16 * 12] stp q14, q15, [x0, #16 * 14] stp q16, q17, [x0, #16 * 16] stp q18, q19, [x0, #16 * 18] stp q20, q21, [x0, #16 * 20] stp q22, q23, [x0, #16 * 22] stp q24, q25, [x0, #16 * 24] stp q26, q27, [x0, #16 * 26] stp q28, q29, [x0, #16 * 28] stp q30, q31, [x0, #16 * 30]! mrs x8, fpsr str w8, [x0, #16 * 2] mrs x8, fpcr str w8, [x0, #16 * 2 + 4] ret ENDPROC(fpsimd_save_state) /* * Load the FP registers. * * x0 - pointer to struct fpsimd_state */ ENTRY(fpsimd_load_state) ldp q0, q1, [x0, #16 * 0] ldp q2, q3, [x0, #16 * 2] ldp q4, q5, [x0, #16 * 4] ldp q6, q7, [x0, #16 * 6] ldp q8, q9, [x0, #16 * 8] ldp q10, q11, [x0, #16 * 10] ldp q12, q13, [x0, #16 * 12] ldp q14, q15, [x0, #16 * 14] ldp q16, q17, [x0, #16 * 16] ldp q18, q19, [x0, #16 * 18] ldp q20, q21, [x0, #16 * 20] ldp q22, q23, [x0, #16 * 22] ldp q24, q25, [x0, #16 * 24] ldp q26, q27, [x0, #16 * 26] ldp q28, q29, [x0, #16 * 28] ldp q30, q31, [x0, #16 * 30]! ldr w8, [x0, #16 * 2] ldr w9, [x0, #16 * 2 + 4] msr fpsr, x8 msr fpcr, x9 ret ENDPROC(fpsimd_load_state)