xref: /rk3399_ARM-atf/lib/cpus/cpu-ops.mk (revision 6b0d97b24a9414b754e9531cba7275438d5f77be)
15541bb3fSSoby Mathew#
25541bb3fSSoby Mathew# Copyright (c) 2014, ARM Limited and Contributors. All rights reserved.
35541bb3fSSoby Mathew#
45541bb3fSSoby Mathew# Redistribution and use in source and binary forms, with or without
55541bb3fSSoby Mathew# modification, are permitted provided that the following conditions are met:
65541bb3fSSoby Mathew#
75541bb3fSSoby Mathew# Redistributions of source code must retain the above copyright notice, this
85541bb3fSSoby Mathew# list of conditions and the following disclaimer.
95541bb3fSSoby Mathew#
105541bb3fSSoby Mathew# Redistributions in binary form must reproduce the above copyright notice,
115541bb3fSSoby Mathew# this list of conditions and the following disclaimer in the documentation
125541bb3fSSoby Mathew# and/or other materials provided with the distribution.
135541bb3fSSoby Mathew#
145541bb3fSSoby Mathew# Neither the name of ARM nor the names of its contributors may be used
155541bb3fSSoby Mathew# to endorse or promote products derived from this software without specific
165541bb3fSSoby Mathew# prior written permission.
175541bb3fSSoby Mathew#
185541bb3fSSoby Mathew# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
195541bb3fSSoby Mathew# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
205541bb3fSSoby Mathew# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
215541bb3fSSoby Mathew# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
225541bb3fSSoby Mathew# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
235541bb3fSSoby Mathew# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
245541bb3fSSoby Mathew# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
255541bb3fSSoby Mathew# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
265541bb3fSSoby Mathew# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
275541bb3fSSoby Mathew# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
285541bb3fSSoby Mathew# POSSIBILITY OF SUCH DAMAGE.
295541bb3fSSoby Mathew#
305541bb3fSSoby Mathew
315541bb3fSSoby Mathew# Cortex A57 specific optimisation to skip L1 cache flush when
325541bb3fSSoby Mathew# cluster is powered down.
335541bb3fSSoby MathewSKIP_A57_L1_FLUSH_PWR_DWN	?=0
345541bb3fSSoby Mathew
355541bb3fSSoby Mathew# Process SKIP_A57_L1_FLUSH_PWR_DWN flag
365541bb3fSSoby Mathew$(eval $(call assert_boolean,SKIP_A57_L1_FLUSH_PWR_DWN))
375541bb3fSSoby Mathew$(eval $(call add_define,SKIP_A57_L1_FLUSH_PWR_DWN))
385541bb3fSSoby Mathew
395541bb3fSSoby Mathew
405541bb3fSSoby Mathew# CPU Errata Build flags. These should be enabled by the
415541bb3fSSoby Mathew# platform if the errata needs to be applied.
425541bb3fSSoby Mathew
43*6b0d97b2SJimmy Huang# Flag to apply errata 826319 during reset. This errata applies only to
44*6b0d97b2SJimmy Huang# revision <= r0p2 of the Cortex A53 cpu.
45*6b0d97b2SJimmy HuangERRATA_A53_826319	?=0
46*6b0d97b2SJimmy Huang
47*6b0d97b2SJimmy Huang# Flag to apply errata 836870 during reset. This errata applies only to
48*6b0d97b2SJimmy Huang# revision <= r0p3 of the Cortex A53 cpu. From r0p4 and onwards, this
49*6b0d97b2SJimmy Huang# errata is enabled by default.
50*6b0d97b2SJimmy HuangERRATA_A53_836870	?=0
51*6b0d97b2SJimmy Huang
525541bb3fSSoby Mathew# Flag to apply errata 806969 during reset. This errata applies only to
535541bb3fSSoby Mathew# revision r0p0 of the Cortex A57 cpu.
545541bb3fSSoby MathewERRATA_A57_806969	?=0
555541bb3fSSoby Mathew
565541bb3fSSoby Mathew# Flag to apply errata 813420 during reset. This errata applies only to
575541bb3fSSoby Mathew# revision r0p0 of the Cortex A57 cpu.
585541bb3fSSoby MathewERRATA_A57_813420	?=0
595541bb3fSSoby Mathew
60*6b0d97b2SJimmy Huang# Process ERRATA_A53_826319 flag
61*6b0d97b2SJimmy Huang$(eval $(call assert_boolean,ERRATA_A53_826319))
62*6b0d97b2SJimmy Huang$(eval $(call add_define,ERRATA_A53_826319))
63*6b0d97b2SJimmy Huang
64*6b0d97b2SJimmy Huang# Process ERRATA_A53_836870 flag
65*6b0d97b2SJimmy Huang$(eval $(call assert_boolean,ERRATA_A53_836870))
66*6b0d97b2SJimmy Huang$(eval $(call add_define,ERRATA_A53_836870))
67*6b0d97b2SJimmy Huang
685541bb3fSSoby Mathew# Process ERRATA_A57_806969 flag
695541bb3fSSoby Mathew$(eval $(call assert_boolean,ERRATA_A57_806969))
705541bb3fSSoby Mathew$(eval $(call add_define,ERRATA_A57_806969))
715541bb3fSSoby Mathew
725541bb3fSSoby Mathew# Process ERRATA_A57_813420 flag
735541bb3fSSoby Mathew$(eval $(call assert_boolean,ERRATA_A57_813420))
745541bb3fSSoby Mathew$(eval $(call add_define,ERRATA_A57_813420))
75