15541bb3fSSoby Mathew# 254035fc4SSandrine Bailleux# Copyright (c) 2014-2016, 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 3554035fc4SSandrine Bailleux# Flag to disable the cache non-temporal hint. 3654035fc4SSandrine Bailleux# It is enabled by default. 3754035fc4SSandrine BailleuxA53_DISABLE_NON_TEMPORAL_HINT ?=1 3854035fc4SSandrine Bailleux 3954035fc4SSandrine Bailleux# Flag to disable the cache non-temporal hint. 4054035fc4SSandrine Bailleux# It is enabled by default. 4154035fc4SSandrine BailleuxA57_DISABLE_NON_TEMPORAL_HINT ?=1 4254035fc4SSandrine Bailleux 435541bb3fSSoby Mathew# Process SKIP_A57_L1_FLUSH_PWR_DWN flag 445541bb3fSSoby Mathew$(eval $(call assert_boolean,SKIP_A57_L1_FLUSH_PWR_DWN)) 455541bb3fSSoby Mathew$(eval $(call add_define,SKIP_A57_L1_FLUSH_PWR_DWN)) 465541bb3fSSoby Mathew 4754035fc4SSandrine Bailleux# Process A53_DISABLE_NON_TEMPORAL_HINT flag 4854035fc4SSandrine Bailleux$(eval $(call assert_boolean,A53_DISABLE_NON_TEMPORAL_HINT)) 4954035fc4SSandrine Bailleux$(eval $(call add_define,A53_DISABLE_NON_TEMPORAL_HINT)) 5054035fc4SSandrine Bailleux 5154035fc4SSandrine Bailleux# Process A57_DISABLE_NON_TEMPORAL_HINT flag 5254035fc4SSandrine Bailleux$(eval $(call assert_boolean,A57_DISABLE_NON_TEMPORAL_HINT)) 5354035fc4SSandrine Bailleux$(eval $(call add_define,A57_DISABLE_NON_TEMPORAL_HINT)) 5454035fc4SSandrine Bailleux 555541bb3fSSoby Mathew 56097b787aSSandrine Bailleux# CPU Errata Build flags. 57097b787aSSandrine Bailleux# These should be enabled by the platform if the erratum workaround needs to be 58097b787aSSandrine Bailleux# applied. 595541bb3fSSoby Mathew 60097b787aSSandrine Bailleux# Flag to apply erratum 826319 workaround during reset. This erratum applies 61097b787aSSandrine Bailleux# only to revision <= r0p2 of the Cortex A53 cpu. 626b0d97b2SJimmy HuangERRATA_A53_826319 ?=0 636b0d97b2SJimmy Huang 64097b787aSSandrine Bailleux# Flag to apply erratum 836870 workaround during reset. This erratum applies 65097b787aSSandrine Bailleux# only to revision <= r0p3 of the Cortex A53 cpu. From r0p4 and onwards, this 66097b787aSSandrine Bailleux# erratum workaround is enabled by default. 676b0d97b2SJimmy HuangERRATA_A53_836870 ?=0 686b0d97b2SJimmy Huang 69097b787aSSandrine Bailleux# Flag to apply erratum 806969 workaround during reset. This erratum applies 70097b787aSSandrine Bailleux# only to revision r0p0 of the Cortex A57 cpu. 715541bb3fSSoby MathewERRATA_A57_806969 ?=0 725541bb3fSSoby Mathew 73*ccbec91cSAntonio Nino Diaz# Flag to apply erratum 813419 workaround during reset. This erratum applies 74*ccbec91cSAntonio Nino Diaz# only to revision r0p0 of the Cortex A57 cpu. 75*ccbec91cSAntonio Nino DiazERRATA_A57_813419 ?=0 76*ccbec91cSAntonio Nino Diaz 77097b787aSSandrine Bailleux# Flag to apply erratum 813420 workaround during reset. This erratum applies 78097b787aSSandrine Bailleux# only to revision r0p0 of the Cortex A57 cpu. 795541bb3fSSoby MathewERRATA_A57_813420 ?=0 805541bb3fSSoby Mathew 81df22d602SSandrine Bailleux# Flag to apply erratum 826974 workaround during reset. This erratum applies 82df22d602SSandrine Bailleux# only to revision <= r1p1 of the Cortex A57 cpu. 83df22d602SSandrine BailleuxERRATA_A57_826974 ?=0 84df22d602SSandrine Bailleux 8507288865SSandrine Bailleux# Flag to apply erratum 826977 workaround during reset. This erratum applies 8607288865SSandrine Bailleux# only to revision <= r1p1 of the Cortex A57 cpu. 8707288865SSandrine BailleuxERRATA_A57_826977 ?=0 8807288865SSandrine Bailleux 89a8b1c769SSandrine Bailleux# Flag to apply erratum 828024 workaround during reset. This erratum applies 90a8b1c769SSandrine Bailleux# only to revision <= r1p1 of the Cortex A57 cpu. 91a8b1c769SSandrine BailleuxERRATA_A57_828024 ?=0 92a8b1c769SSandrine Bailleux 930b77197bSSandrine Bailleux# Flag to apply erratum 829520 workaround during reset. This erratum applies 940b77197bSSandrine Bailleux# only to revision <= r1p2 of the Cortex A57 cpu. 950b77197bSSandrine BailleuxERRATA_A57_829520 ?=0 960b77197bSSandrine Bailleux 97adeecf92SSandrine Bailleux# Flag to apply erratum 833471 workaround during reset. This erratum applies 98adeecf92SSandrine Bailleux# only to revision <= r1p2 of the Cortex A57 cpu. 99adeecf92SSandrine BailleuxERRATA_A57_833471 ?=0 100adeecf92SSandrine Bailleux 1016b0d97b2SJimmy Huang# Process ERRATA_A53_826319 flag 1026b0d97b2SJimmy Huang$(eval $(call assert_boolean,ERRATA_A53_826319)) 1036b0d97b2SJimmy Huang$(eval $(call add_define,ERRATA_A53_826319)) 1046b0d97b2SJimmy Huang 1056b0d97b2SJimmy Huang# Process ERRATA_A53_836870 flag 1066b0d97b2SJimmy Huang$(eval $(call assert_boolean,ERRATA_A53_836870)) 1076b0d97b2SJimmy Huang$(eval $(call add_define,ERRATA_A53_836870)) 1086b0d97b2SJimmy Huang 1095541bb3fSSoby Mathew# Process ERRATA_A57_806969 flag 1105541bb3fSSoby Mathew$(eval $(call assert_boolean,ERRATA_A57_806969)) 1115541bb3fSSoby Mathew$(eval $(call add_define,ERRATA_A57_806969)) 1125541bb3fSSoby Mathew 113*ccbec91cSAntonio Nino Diaz# Process ERRATA_A57_813419 flag 114*ccbec91cSAntonio Nino Diaz$(eval $(call assert_boolean,ERRATA_A57_813419)) 115*ccbec91cSAntonio Nino Diaz$(eval $(call add_define,ERRATA_A57_813419)) 116*ccbec91cSAntonio Nino Diaz 1175541bb3fSSoby Mathew# Process ERRATA_A57_813420 flag 1185541bb3fSSoby Mathew$(eval $(call assert_boolean,ERRATA_A57_813420)) 1195541bb3fSSoby Mathew$(eval $(call add_define,ERRATA_A57_813420)) 120df22d602SSandrine Bailleux 121df22d602SSandrine Bailleux# Process ERRATA_A57_826974 flag 122df22d602SSandrine Bailleux$(eval $(call assert_boolean,ERRATA_A57_826974)) 123df22d602SSandrine Bailleux$(eval $(call add_define,ERRATA_A57_826974)) 124a8b1c769SSandrine Bailleux 12507288865SSandrine Bailleux# Process ERRATA_A57_826977 flag 12607288865SSandrine Bailleux$(eval $(call assert_boolean,ERRATA_A57_826977)) 12707288865SSandrine Bailleux$(eval $(call add_define,ERRATA_A57_826977)) 12807288865SSandrine Bailleux 129a8b1c769SSandrine Bailleux# Process ERRATA_A57_828024 flag 130a8b1c769SSandrine Bailleux$(eval $(call assert_boolean,ERRATA_A57_828024)) 131a8b1c769SSandrine Bailleux$(eval $(call add_define,ERRATA_A57_828024)) 1320b77197bSSandrine Bailleux 1330b77197bSSandrine Bailleux# Process ERRATA_A57_829520 flag 1340b77197bSSandrine Bailleux$(eval $(call assert_boolean,ERRATA_A57_829520)) 1350b77197bSSandrine Bailleux$(eval $(call add_define,ERRATA_A57_829520)) 136adeecf92SSandrine Bailleux 137adeecf92SSandrine Bailleux# Process ERRATA_A57_833471 flag 138adeecf92SSandrine Bailleux$(eval $(call assert_boolean,ERRATA_A57_833471)) 139adeecf92SSandrine Bailleux$(eval $(call add_define,ERRATA_A57_833471)) 140