mirror of https://github.com/ARMmbed/mbed-os.git
				
				
				
			Merge pull request #3695 from c1728p9/fix_invalid_device_names
Enforce device_name is valid in targets.jsonpull/3734/head
						commit
						34de26dc3a
					
				| 
						 | 
				
			
			@ -5,6 +5,7 @@ script:
 | 
			
		|||
  - make -C events/equeue test clean
 | 
			
		||||
  - PYTHONPATH=. python tools/test/config_test/config_test.py
 | 
			
		||||
  - PYTHONPATH=. python tools/test/build_api/build_api_test.py
 | 
			
		||||
  - PYTHONPATH=. python tools/test/targets/target_test.py
 | 
			
		||||
  - python tools/test/pylint.py
 | 
			
		||||
  - py.test tools/test/toolchains/api.py
 | 
			
		||||
  - python tools/test/memap/memap_test.py
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -226,7 +226,7 @@
 | 
			
		|||
        "device_has": ["ANALOGIN", "ANALOGOUT", "CAN", "I2C", "INTERRUPTIN", "PWMOUT", "RTC", "SERIAL", "SERIAL_FC", "SPI", "SPISLAVE"],
 | 
			
		||||
        "default_lib": "small",
 | 
			
		||||
        "release_versions": ["2"],
 | 
			
		||||
        "device_name": "lpc1549"
 | 
			
		||||
        "device_name": "LPC1549JBD64"
 | 
			
		||||
    },
 | 
			
		||||
    "LPC1768": {
 | 
			
		||||
        "inherits": ["LPCTarget"],
 | 
			
		||||
| 
						 | 
				
			
			@ -632,7 +632,7 @@
 | 
			
		|||
        "detect_code": ["0217"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "ANALOGOUT", "ERROR_RED", "I2C", "I2CSLAVE", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SLEEP", "SPI", "SPISLAVE", "STDIO_MESSAGES"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name" : "MK66FN256xxx15"
 | 
			
		||||
        "device_name" : "MK82FN256xxx15"
 | 
			
		||||
    },
 | 
			
		||||
    "NUCLEO_F030R8": {
 | 
			
		||||
        "supported_form_factors": ["ARDUINO", "MORPHO"],
 | 
			
		||||
| 
						 | 
				
			
			@ -1073,7 +1073,7 @@
 | 
			
		|||
        "macros": ["TRANSACTION_QUEUE_SIZE_SPI=2","USBHOST_OTHER"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "ANALOGOUT", "CAN", "I2C", "I2CSLAVE", "I2C_ASYNCH", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_ASYNCH", "SERIAL_FC", "SLEEP", "SPI", "SPISLAVE", "SPI_ASYNCH", "STDIO_MESSAGES", "TRNG"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "stm32l476rg"
 | 
			
		||||
        "device_name": "STM32L476RG"
 | 
			
		||||
    },
 | 
			
		||||
    "NUCLEO_L486RG": {
 | 
			
		||||
        "supported_form_factors": ["ARDUINO", "MORPHO"],
 | 
			
		||||
| 
						 | 
				
			
			@ -1086,7 +1086,7 @@
 | 
			
		|||
        "macros": ["TRANSACTION_QUEUE_SIZE_SPI=2","USBHOST_OTHER"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "ANALOGOUT", "CAN", "I2C", "I2CSLAVE", "I2C_ASYNCH", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_ASYNCH", "SERIAL_FC", "SLEEP", "SPI", "SPISLAVE", "SPI_ASYNCH", "STDIO_MESSAGES", "TRNG"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "stm32l486rg"
 | 
			
		||||
        "device_name": "STM32L486RG"
 | 
			
		||||
    },
 | 
			
		||||
    "STM32F3XX": {
 | 
			
		||||
        "inherits": ["Target"],
 | 
			
		||||
| 
						 | 
				
			
			@ -1240,7 +1240,7 @@
 | 
			
		|||
        "macros": ["TRANSACTION_QUEUE_SIZE_SPI=2", "USBHOST_OTHER"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "ANALOGOUT", "CAN", "I2C", "I2CSLAVE", "I2C_ASYNCH", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_FC", "SLEEP", "SPI", "SPISLAVE", "SPI_ASYNCH", "STDIO_MESSAGES", "TRNG"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "stm32l476vg"
 | 
			
		||||
        "device_name": "STM32L476VG"
 | 
			
		||||
    },
 | 
			
		||||
    "MTS_MDOT_F405RG": {
 | 
			
		||||
        "inherits": ["Target"],
 | 
			
		||||
| 
						 | 
				
			
			@ -1828,8 +1828,7 @@
 | 
			
		|||
        "macros": ["CMSDK_BEETLE", "WSF_MS_PER_TICK=20", "WSF_TOKEN_ENABLED=FALSE", "WSF_TRACE_ENABLED=TRUE", "WSF_ASSERT_ENABLED=FALSE", "WSF_PRINTF_MAX_LEN=128", "ASIC", "CONFIG_HOST_REV=0x20", "CONFIG_ALLOW_DEEP_SLEEP=FALSE", "HCI_VS_TARGET", "CONFIG_ALLOW_SETTING_WRITE=TRUE", "WSF_MAX_HANDLERS=20", "NO_LEDS"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "CLCD", "I2C", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "SERIAL", "SLEEP", "SPI"],
 | 
			
		||||
        "features": ["BLE"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "beetle"
 | 
			
		||||
        "release_versions": ["2", "5"]
 | 
			
		||||
    },
 | 
			
		||||
    "RZ_A1H": {
 | 
			
		||||
        "supported_form_factors": ["ARDUINO"],
 | 
			
		||||
| 
						 | 
				
			
			@ -1840,8 +1839,7 @@
 | 
			
		|||
        "inherits": ["Target"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "CAN", "ERROR_PATTERN", "ETHERNET", "I2C", "I2CSLAVE", "I2C_ASYNCH", "INTERRUPTIN", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_ASYNCH", "SERIAL_FC", "SPI", "SPISLAVE", "SPI_ASYNCH", "STDIO_MESSAGES"],
 | 
			
		||||
        "features": ["LWIP"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "r7s721001"
 | 
			
		||||
        "release_versions": ["2", "5"]
 | 
			
		||||
    },
 | 
			
		||||
    "VK_RZ_A1H": {
 | 
			
		||||
        "inherits": ["Target"],
 | 
			
		||||
| 
						 | 
				
			
			@ -1853,8 +1851,7 @@
 | 
			
		|||
        "device_has": ["ANALOGIN", "CAN", "ERROR_PATTERN", "ETHERNET", "I2C", "I2CSLAVE", "INTERRUPTIN", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_FC", "SPI", "SPISLAVE", "STDIO_MESSAGES"],
 | 
			
		||||
        "features": ["LWIP"],
 | 
			
		||||
        "default_lib": "std",
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "r7s721000"
 | 
			
		||||
        "release_versions": ["2", "5"]
 | 
			
		||||
    },
 | 
			
		||||
    "MAXWSNENV": {
 | 
			
		||||
        "inherits": ["Target"],
 | 
			
		||||
| 
						 | 
				
			
			@ -1873,8 +1870,7 @@
 | 
			
		|||
        "extra_labels": ["Maxim", "MAX32600"],
 | 
			
		||||
        "supported_toolchains": ["GCC_ARM", "IAR", "ARM"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "ANALOGOUT", "ERROR_PATTERN", "I2C", "INTERRUPTIN", "LOWPOWERTIMER", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_FC", "SLEEP", "SPI", "STDIO_MESSAGES"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "max326000x85"
 | 
			
		||||
        "release_versions": ["2", "5"]
 | 
			
		||||
    },
 | 
			
		||||
    "MAX32620HSP": {
 | 
			
		||||
        "inherits": ["Target"],
 | 
			
		||||
| 
						 | 
				
			
			@ -2253,7 +2249,6 @@
 | 
			
		|||
        "macros": ["EFR32MG1P233F256GM48", "TRANSACTION_QUEUE_SIZE_SPI=4"],
 | 
			
		||||
        "supported_toolchains": ["GCC_ARM", "ARM", "uARM", "IAR"],
 | 
			
		||||
        "release_versions": ["2", "5"],
 | 
			
		||||
        "device_name": "EFR32MG1P233F256GM48",
 | 
			
		||||
        "public": false
 | 
			
		||||
    },
 | 
			
		||||
    "EFR32MG1_BRD4150": {
 | 
			
		||||
| 
						 | 
				
			
			@ -2601,7 +2596,6 @@
 | 
			
		|||
        "macros": ["CM3", "CPU_NCS36510", "TARGET_NCS36510", "LOAD_ADDRESS=0x3000"],
 | 
			
		||||
        "supported_toolchains": ["GCC_ARM", "ARM", "IAR"],
 | 
			
		||||
        "device_has": ["ANALOGIN", "SERIAL", "I2C", "INTERRUPTIN", "PORTIN", "PORTINOUT", "PORTOUT", "PWMOUT", "RTC", "SERIAL", "SERIAL_FC", "SLEEP", "SPI", "LOWPOWERTIMER", "TRNG"],
 | 
			
		||||
        "device_name": "NCS36510",
 | 
			
		||||
        "release_versions": ["2", "5"]
 | 
			
		||||
    },
 | 
			
		||||
    "NUMAKER_PFM_M453": {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -25,11 +25,19 @@ class IAR(Exporter):
 | 
			
		|||
    with open(def_loc, 'r') as f:
 | 
			
		||||
        IAR_DEFS = json.load(f)
 | 
			
		||||
 | 
			
		||||
    #supported targets have a device name and corresponding definition in
 | 
			
		||||
    #iar_definitions.json
 | 
			
		||||
    TARGETS = [target for target, obj in TARGET_MAP.iteritems()
 | 
			
		||||
               if hasattr(obj, 'device_name') and
 | 
			
		||||
               obj.device_name in IAR_DEFS.keys() and "IAR" in obj.supported_toolchains]
 | 
			
		||||
    def _iar_support(tgt, iar_targets):
 | 
			
		||||
        if "IAR" not in tgt.supported_toolchains:
 | 
			
		||||
            return False
 | 
			
		||||
        if hasattr(tgt, 'device_name') and tgt.device_name in iar_targets:
 | 
			
		||||
            return True
 | 
			
		||||
        if tgt.name in iar_targets:
 | 
			
		||||
            return True
 | 
			
		||||
        return False
 | 
			
		||||
 | 
			
		||||
    #supported targets have a name or device_name which maps to a definition
 | 
			
		||||
    #in iar_definitions.json
 | 
			
		||||
    TARGETS = [target for target, obj in TARGET_MAP.iteritems() if
 | 
			
		||||
               _iar_support(obj, IAR_DEFS.keys())]
 | 
			
		||||
 | 
			
		||||
    def iar_groups(self, grouped_src):
 | 
			
		||||
        """Return a namedtuple of group info
 | 
			
		||||
| 
						 | 
				
			
			@ -56,7 +64,9 @@ class IAR(Exporter):
 | 
			
		|||
 | 
			
		||||
    def iar_device(self):
 | 
			
		||||
        """Retrieve info from iar_definitions.json"""
 | 
			
		||||
        device_name =  TARGET_MAP[self.target].device_name
 | 
			
		||||
        tgt = TARGET_MAP[self.target]
 | 
			
		||||
        device_name = (tgt.device_name if hasattr(tgt, "device_name") else
 | 
			
		||||
                       tgt.name)
 | 
			
		||||
        device_info = self.IAR_DEFS[device_name]
 | 
			
		||||
        iar_defaults ={
 | 
			
		||||
            "OGChipSelectEditMenu": "",
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -133,14 +133,14 @@
 | 
			
		|||
    "STM32F091RC": {
 | 
			
		||||
        "OGChipSelectEditMenu": "STM32F091RC\tST STM32F091RC"
 | 
			
		||||
    },
 | 
			
		||||
    "r7s721001": {
 | 
			
		||||
    "RZ_A1H": {
 | 
			
		||||
        "OGChipSelectEditMenu": "R7S721001\tRenesas R7S721001",
 | 
			
		||||
        "CoreVariant": 37,
 | 
			
		||||
        "GFPUCoreSlave": 37,
 | 
			
		||||
        "GBECoreSlave": 37,
 | 
			
		||||
        "NEON":1
 | 
			
		||||
    },
 | 
			
		||||
    "r7s721000": {
 | 
			
		||||
    "VK_RZ_A1H": {
 | 
			
		||||
        "OGChipSelectEditMenu": "R7S721000\tRenesas R7S721000",
 | 
			
		||||
        "CoreVariant": 37,
 | 
			
		||||
        "GFPUCoreSlave": 37,
 | 
			
		||||
| 
						 | 
				
			
			@ -153,7 +153,7 @@
 | 
			
		|||
    "STM32F031K6": {
 | 
			
		||||
        "OGChipSelectEditMenu": "STM32F031x6\tST STM32F031x6"
 | 
			
		||||
    },
 | 
			
		||||
    "max326000x85": {
 | 
			
		||||
    "MAX32600MBED": {
 | 
			
		||||
        "OGChipSelectEditMenu": "MAX32600x85\tMaxim MAX32600x85"
 | 
			
		||||
    },
 | 
			
		||||
    "STM32F407VG": {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -0,0 +1,43 @@
 | 
			
		|||
#!/usr/bin/env python
 | 
			
		||||
"""
 | 
			
		||||
 mbed
 | 
			
		||||
 Copyright (c) 2017-2017 ARM Limited
 | 
			
		||||
 | 
			
		||||
 Licensed under the Apache License, Version 2.0 (the "License");
 | 
			
		||||
 you may not use this file except in compliance with the License.
 | 
			
		||||
 You may obtain a copy of the License at
 | 
			
		||||
 | 
			
		||||
     http://www.apache.org/licenses/LICENSE-2.0
 | 
			
		||||
 | 
			
		||||
 Unless required by applicable law or agreed to in writing, software
 | 
			
		||||
 distributed under the License is distributed on an "AS IS" BASIS,
 | 
			
		||||
 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
			
		||||
 See the License for the specific language governing permissions and
 | 
			
		||||
 limitations under the License.
 | 
			
		||||
"""
 | 
			
		||||
 | 
			
		||||
import sys
 | 
			
		||||
from os.path import join, abspath, dirname
 | 
			
		||||
import unittest
 | 
			
		||||
 | 
			
		||||
# Be sure that the tools directory is in the search path
 | 
			
		||||
ROOT = abspath(join(dirname(__file__), "..", "..", ".."))
 | 
			
		||||
sys.path.insert(0, ROOT)
 | 
			
		||||
 | 
			
		||||
from tools.targets import TARGETS
 | 
			
		||||
from tools.arm_pack_manager import Cache
 | 
			
		||||
 | 
			
		||||
class TestTargets(unittest.TestCase):
 | 
			
		||||
 | 
			
		||||
    def test_device_name(self):
 | 
			
		||||
        """Assert device name is in a pack"""
 | 
			
		||||
        cache = Cache(True, True)
 | 
			
		||||
        named_targets = (target for target in TARGETS if
 | 
			
		||||
                         hasattr(target, "device_name"))
 | 
			
		||||
        for target in named_targets:
 | 
			
		||||
            self.assertTrue(target.device_name in cache.index,
 | 
			
		||||
                            "Target %s contains invalid device_name %s" %
 | 
			
		||||
                            (target.name, target.device_name))
 | 
			
		||||
 | 
			
		||||
if __name__ == '__main__':
 | 
			
		||||
    unittest.main()
 | 
			
		||||
		Loading…
	
		Reference in New Issue