| Gilles Peskine | c86f20a | 2021-04-22 00:20:47 +0200 | [diff] [blame] | 1 | """Mbed TLS build tree information and manipulation. | 
|  | 2 | """ | 
|  | 3 |  | 
|  | 4 | # Copyright The Mbed TLS Contributors | 
| Dave Rodgman | 16799db | 2023-11-02 19:47:20 +0000 | [diff] [blame] | 5 | # SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later | 
| Gilles Peskine | c86f20a | 2021-04-22 00:20:47 +0200 | [diff] [blame] | 6 | # | 
| Gilles Peskine | c86f20a | 2021-04-22 00:20:47 +0200 | [diff] [blame] | 7 |  | 
|  | 8 | import os | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 9 | import inspect | 
| Thomas Daubney | d35b94b | 2023-11-22 17:00:34 +0000 | [diff] [blame] | 10 | from typing import Optional | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 11 |  | 
| Ronald Cron | 070e865 | 2023-10-09 10:25:45 +0200 | [diff] [blame] | 12 | def looks_like_tf_psa_crypto_root(path: str) -> bool: | 
| David Horstmann | 795d8b5 | 2023-07-18 17:03:03 +0100 | [diff] [blame] | 13 | """Whether the given directory looks like the root of the PSA Crypto source tree.""" | 
|  | 14 | return all(os.path.isdir(os.path.join(path, subdir)) | 
| David Horstmann | 2fde999 | 2023-08-29 09:48:39 +0100 | [diff] [blame] | 15 | for subdir in ['include', 'core', 'drivers', 'programs', 'tests']) | 
| Gilles Peskine | c86f20a | 2021-04-22 00:20:47 +0200 | [diff] [blame] | 16 |  | 
|  | 17 | def looks_like_mbedtls_root(path: str) -> bool: | 
|  | 18 | """Whether the given directory looks like the root of the Mbed TLS source tree.""" | 
|  | 19 | return all(os.path.isdir(os.path.join(path, subdir)) | 
|  | 20 | for subdir in ['include', 'library', 'programs', 'tests']) | 
|  | 21 |  | 
| David Horstmann | 795d8b5 | 2023-07-18 17:03:03 +0100 | [diff] [blame] | 22 | def looks_like_root(path: str) -> bool: | 
| Ronald Cron | 070e865 | 2023-10-09 10:25:45 +0200 | [diff] [blame] | 23 | return looks_like_tf_psa_crypto_root(path) or looks_like_mbedtls_root(path) | 
| David Horstmann | 795d8b5 | 2023-07-18 17:03:03 +0100 | [diff] [blame] | 24 |  | 
| Thomas Daubney | 04c446c | 2023-12-01 17:18:38 +0000 | [diff] [blame] | 25 | def crypto_core_directory(root: Optional[str] = None, relative: Optional[bool] = False) -> str: | 
| Thomas Daubney | 46588de | 2023-11-30 13:59:30 +0000 | [diff] [blame] | 26 | """ | 
| Thomas Daubney | 99030e2 | 2023-12-01 09:52:35 +0000 | [diff] [blame] | 27 | Return the path of the directory containing the PSA crypto core | 
| Thomas Daubney | 46588de | 2023-11-30 13:59:30 +0000 | [diff] [blame] | 28 | for either TF-PSA-Crypto or Mbed TLS. | 
| Thomas Daubney | 04c446c | 2023-12-01 17:18:38 +0000 | [diff] [blame] | 29 |  | 
|  | 30 | Returns either the full path or relative path depending on the | 
|  | 31 | "relative" boolean argument. | 
| Thomas Daubney | 46588de | 2023-11-30 13:59:30 +0000 | [diff] [blame] | 32 | """ | 
| Thomas Daubney | d35b94b | 2023-11-22 17:00:34 +0000 | [diff] [blame] | 33 | if root is None: | 
| Thomas Daubney | 755d321 | 2023-11-22 17:18:22 +0000 | [diff] [blame] | 34 | root = guess_project_root() | 
| Thomas Daubney | d35b94b | 2023-11-22 17:00:34 +0000 | [diff] [blame] | 35 | if looks_like_tf_psa_crypto_root(root): | 
| Thomas Daubney | 04c446c | 2023-12-01 17:18:38 +0000 | [diff] [blame] | 36 | if relative: | 
|  | 37 | return "core" | 
| Thomas Daubney | beec452 | 2023-11-24 10:48:44 +0000 | [diff] [blame] | 38 | return os.path.join(root, "core") | 
| Thomas Daubney | d35b94b | 2023-11-22 17:00:34 +0000 | [diff] [blame] | 39 | elif looks_like_mbedtls_root(root): | 
| Thomas Daubney | 04c446c | 2023-12-01 17:18:38 +0000 | [diff] [blame] | 40 | if relative: | 
|  | 41 | return "library" | 
| Thomas Daubney | beec452 | 2023-11-24 10:48:44 +0000 | [diff] [blame] | 42 | return os.path.join(root, "library") | 
| Thomas Daubney | 13ecb69 | 2023-11-16 18:34:58 +0000 | [diff] [blame] | 43 | else: | 
|  | 44 | raise Exception('Neither Mbed TLS nor TF-PSA-Crypto source tree found') | 
|  | 45 |  | 
| Thomas Daubney | 08c6dc4 | 2023-11-30 13:56:09 +0000 | [diff] [blame] | 46 | def crypto_library_filename(root: Optional[str] = None) -> str: | 
| Thomas Daubney | cdbf2fd | 2023-11-24 10:54:56 +0000 | [diff] [blame] | 47 | """Return the crypto library filename for either TF-PSA-Crypto or Mbed TLS.""" | 
| Thomas Daubney | 8932404 | 2023-11-23 10:14:12 +0000 | [diff] [blame] | 48 | if root is None: | 
|  | 49 | root = guess_project_root() | 
|  | 50 | if looks_like_tf_psa_crypto_root(root): | 
|  | 51 | return "tfpsacrypto" | 
|  | 52 | elif looks_like_mbedtls_root(root): | 
|  | 53 | return "mbedcrypto" | 
|  | 54 | else: | 
|  | 55 | raise Exception('Neither Mbed TLS nor TF-PSA-Crypto source tree found') | 
|  | 56 |  | 
| Gilles Peskine | d9071e7 | 2022-09-18 21:17:09 +0200 | [diff] [blame] | 57 | def check_repo_path(): | 
| Thomas Daubney | d1f2934 | 2023-11-30 17:25:55 +0000 | [diff] [blame] | 58 | """Check that the current working directory is the project root, and throw | 
| Gilles Peskine | d9071e7 | 2022-09-18 21:17:09 +0200 | [diff] [blame] | 59 | an exception if not. | 
|  | 60 | """ | 
|  | 61 | if not all(os.path.isdir(d) for d in ["include", "library", "tests"]): | 
|  | 62 | raise Exception("This script must be run from Mbed TLS root") | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 63 |  | 
| Gilles Peskine | c86f20a | 2021-04-22 00:20:47 +0200 | [diff] [blame] | 64 | def chdir_to_root() -> None: | 
|  | 65 | """Detect the root of the Mbed TLS source tree and change to it. | 
|  | 66 |  | 
|  | 67 | The current directory must be up to two levels deep inside an Mbed TLS | 
|  | 68 | source tree. | 
|  | 69 | """ | 
|  | 70 | for d in [os.path.curdir, | 
|  | 71 | os.path.pardir, | 
|  | 72 | os.path.join(os.path.pardir, os.path.pardir)]: | 
| David Horstmann | 795d8b5 | 2023-07-18 17:03:03 +0100 | [diff] [blame] | 73 | if looks_like_root(d): | 
| Gilles Peskine | c86f20a | 2021-04-22 00:20:47 +0200 | [diff] [blame] | 74 | os.chdir(d) | 
|  | 75 | return | 
|  | 76 | raise Exception('Mbed TLS source tree not found') | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 77 |  | 
| Thomas Daubney | 755d321 | 2023-11-22 17:18:22 +0000 | [diff] [blame] | 78 | def guess_project_root(): | 
|  | 79 | """Guess project source code directory. | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 80 |  | 
| Thomas Daubney | 755d321 | 2023-11-22 17:18:22 +0000 | [diff] [blame] | 81 | Return the first possible project root directory. | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 82 | """ | 
|  | 83 | dirs = set({}) | 
| Jerry Yu | 0cb2cf6 | 2021-12-10 14:21:27 +0800 | [diff] [blame] | 84 | for frame in inspect.stack(): | 
|  | 85 | path = os.path.dirname(frame.filename) | 
|  | 86 | for d in ['.', os.path.pardir] \ | 
|  | 87 | + [os.path.join(*([os.path.pardir]*i)) for i in range(2, 10)]: | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 88 | d = os.path.abspath(os.path.join(path, d)) | 
|  | 89 | if d in dirs: | 
|  | 90 | continue | 
|  | 91 | dirs.add(d) | 
| David Horstmann | 795d8b5 | 2023-07-18 17:03:03 +0100 | [diff] [blame] | 92 | if looks_like_root(d): | 
| Jerry Yu | e6369b0 | 2021-12-02 13:51:26 +0800 | [diff] [blame] | 93 | return d | 
| Thomas Daubney | 755d321 | 2023-11-22 17:18:22 +0000 | [diff] [blame] | 94 | raise Exception('Neither Mbed TLS nor TF-PSA-Crypto source tree found') | 
| Thomas Daubney | d1f2934 | 2023-11-30 17:25:55 +0000 | [diff] [blame] | 95 |  | 
|  | 96 | def guess_mbedtls_root(root: Optional[str] = None) -> str: | 
|  | 97 | """Guess Mbed TLS source code directory. | 
|  | 98 |  | 
|  | 99 | Return the first possible Mbed TLS root directory. | 
|  | 100 | Raise an exception if we are not in Mbed TLS. | 
|  | 101 | """ | 
|  | 102 | if root is None: | 
|  | 103 | root = guess_project_root() | 
|  | 104 | if looks_like_mbedtls_root(root): | 
|  | 105 | return root | 
|  | 106 | else: | 
|  | 107 | raise Exception('Mbed TLS source tree not found') | 
| Thomas Daubney | db80b23 | 2023-11-30 17:33:54 +0000 | [diff] [blame] | 108 |  | 
|  | 109 | def guess_tf_psa_crypto_root(root: Optional[str] = None) -> str: | 
|  | 110 | """Guess TF-PSA-Crypto source code directory. | 
|  | 111 |  | 
|  | 112 | Return the first possible TF-PSA-Crypto root directory. | 
|  | 113 | Raise an exception if we are not in TF-PSA-Crypto. | 
|  | 114 | """ | 
|  | 115 | if root is None: | 
|  | 116 | root = guess_project_root() | 
|  | 117 | if looks_like_tf_psa_crypto_root(root): | 
|  | 118 | return root | 
|  | 119 | else: | 
|  | 120 | raise Exception('TF-PSA-Crypto source tree not found') |