12345678910111213141516171819202122232425262728293031323334353637383940 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (C) 2012 ARM Ltd.
- */
- #include <linux/linkage.h>
- #include <linux/const.h>
- #include <asm/assembler.h>
- #include <asm/page.h>
- /*
- * Clear page @dest
- *
- * Parameters:
- * x0 - dest
- */
- SYM_FUNC_START(__pi_clear_page)
- mrs x1, dczid_el0
- tbnz x1, #4, 2f /* Branch if DC ZVA is prohibited */
- and w1, w1, #0xf
- mov x2, #4
- lsl x1, x2, x1
- 1: dc zva, x0
- add x0, x0, x1
- tst x0, #(PAGE_SIZE - 1)
- b.ne 1b
- ret
- 2: stnp xzr, xzr, [x0]
- stnp xzr, xzr, [x0, #16]
- stnp xzr, xzr, [x0, #32]
- stnp xzr, xzr, [x0, #48]
- add x0, x0, #64
- tst x0, #(PAGE_SIZE - 1)
- b.ne 2b
- ret
- SYM_FUNC_END(__pi_clear_page)
- SYM_FUNC_ALIAS(clear_page, __pi_clear_page)
- EXPORT_SYMBOL(clear_page)
|