Commit e2e57a05 authored by Raphael Defosseux's avatar Raphael Defosseux

Merge remote-tracking branch 'origin/minor-doc-improvements' into integration_2024_w36

parents 69a84825 dbe5c5ee
## configuring the logging facility ## configuring the logging facility
The logging facility is fully configurable and it uses the [config module](../../../config/config.md) to get its parameters at init time. The [telnet server](../../telnetsrv/DOC/telnetsrv.md) includes a set of commands which can be used to dynamically modify the logging facility behavior The logging facility is fully configurable and it uses the [config module](../../../../common/config/DOC/config.md) to get its parameters at init time. The [telnet server](../../telnetsrv/DOC/telnetsrv.md) includes a set of commands which can be used to dynamically modify the logging facility behavior
All logging facility parameters are defined in the log_config section. Some parameters are global to the logging facility, they modify the way messages are printed to stdout. Conversely, some parameters are specific to a component and only modify the behavior for messages issued by a given component. A third type of parameters can be used to activate conditional debug code or dump messages or buffers. All logging facility parameters are defined in the log_config section. Some parameters are global to the logging facility, they modify the way messages are printed to stdout. Conversely, some parameters are specific to a component and only modify the behavior for messages issued by a given component. A third type of parameters can be used to activate conditional debug code or dump messages or buffers.
......
...@@ -103,7 +103,7 @@ of wireshark. Adapt as necessary. ...@@ -103,7 +103,7 @@ of wireshark. Adapt as necessary.
2) Then, in the menu, choose `Edit->Preferences`. 2) Then, in the menu, choose `Edit->Preferences`.
3) In the preference window, unroll `Protocols` and configure the following: 3) In the preference window, unroll `Protocols` and configure the following:
**MAC** **MAC-NR**
Go to `MAC-NR`. Select: Go to `MAC-NR`. Select:
...@@ -117,7 +117,7 @@ For `Source of LCID -> drb channel settings`: ...@@ -117,7 +117,7 @@ For `Source of LCID -> drb channel settings`:
Type `AM, SN Len=18`, same thing for DL RLC Bearer Type. Type `AM, SN Len=18`, same thing for DL RLC Bearer Type.
* Click OK. * Click OK.
**RLC** **RLC-NR**
Now, go to `RLC-NR`. Select: Now, go to `RLC-NR`. Select:
...@@ -129,7 +129,7 @@ Now, go to `RLC-NR`. Select: ...@@ -129,7 +129,7 @@ Now, go to `RLC-NR`. Select:
You don't need to select `May see RLC headers only` and You don't need to select `May see RLC headers only` and
`Try to reassemble UM frames`. `Try to reassemble UM frames`.
**PDCP** **PDCP-NR**
Now, go to `PDCP-NR`. Select what you need in there. Now, go to `PDCP-NR`. Select what you need in there.
...@@ -146,6 +146,12 @@ You are done with the preferences. You can click OK. ...@@ -146,6 +146,12 @@ You are done with the preferences. You can click OK.
4) Then, in the menu `Analyze`, choose `Enabled Protocols...`. 4) Then, in the menu `Analyze`, choose `Enabled Protocols...`.
5) In the new window search for `nr` and select `mac_nr_udp` to have `MAC-NR over UDP`. 5) In the new window search for `nr` and select `mac_nr_udp` to have `MAC-NR over UDP`.
**NAS-5GS**
Under `NAS-5GS`, select:
* `Try to detect and decode 5G-EA0 ciphered messages`
And that's it. Maybe other settings can be changed, but those steps should be And that's it. Maybe other settings can be changed, but those steps should be
enough for a start. enough for a start.
......
...@@ -18,38 +18,58 @@ ...@@ -18,38 +18,58 @@
The F1 interface is the functional split of 3GPP between the CU (centralized The F1 interface is the functional split of 3GPP between the CU (centralized
unit: PDCP, RRC, SDAP) and the DU (distributed unit: RLC, MAC, PHY). It is unit: PDCP, RRC, SDAP) and the DU (distributed unit: RLC, MAC, PHY). It is
standardized in TS 38.470 - 38.473 for 5G NR. No equivalent for 4G exists. standardized in TS 38.470 - 38.473 for 5G NR.
We assume that each DU handles only one cell. Multiple DUs connected to one CU F1 specs:
are supported. Mobility over F1 is not yet supported. * 3GPP TS 38.470 F1 general aspects and principles
* 3GPP TS 38.471 F1 layer 1
# Control plane status (F1-C) F1-C:
* 3GPP TS 38.472 F1 signalling transport
* 3GPP TS 38.473 F1 Application Protocol (F1AP)
## Implementation Status F1-U:
* 3GPP TS 38.474 F1 Data Transport
Note that OAI uses F1 "internally". That means, that even **if you run a No equivalent for 4G exists.
monolithic gNB, the internal information exchange uses F1**. You can therefore
expect that everything working in a monolithic deployment should also work in
F1. The current implementation is based on R16.3.
Note that NSA does NOT follow this logic yet, and does not work with F1. ## Control plane (F1-C)
The following messages are currently implemented: The interface F1-C is designed for the exchange of signalling messages between the
Radio Network Layer (RNL) and the Transport Network Layer (TNL). It
consists of F1 Application Protocol messages (F1-AP) exchanged over SCTP.
- F1 Setup Request and F1 Setup Response/Failure ## Data plane (F1-U)
- Initial UL RRC, UL/DL RRC Message Transfer
- F1 UE Context management messages for the "good case"
* Setup Request/Response
* Modification Request/Response
* Release Request/Command/Complete
All other messages are not implemented or not working reliably: F1-U uses GTP-U for information exchange.
- F1 CU/DU configuration updade # OAI Implementation Status
- Paging messages
- Warning Message transmissions
## High-level F1-C code structure The implementation of F1AP messages is seamlessly integrated into OAI, supporting both Monolithic SA
and CU/DU functional split modes. The F1 code is therefore always compiled with nr-softmodem.
This architecture ensures that even *when operating a monolithic gNB, internal information exchange
always utilizes F1AP messages*.
The major difference lies in the CU/DU split scenario, where ASN.1-encoded F1AP messages (F1-C) are
exchanges over SCTP, via a socket interface.
This is the current status:
- gNB-CU/gNB-DU split
- Supported deployments:
* SA
* Single cell per DU
* Multiple DUs connected to one CU (both CP and UP)
- Not supported:
* Mobility
* NSA
## F1-C
### F1AP messages
Refer to [FEATURE_SET.md](FEATURE_SET.md#gNB-F1AP) to learn about the current F1AP implementation status.
### High-level F1-C code structure
The F1 interface is used internally between CU (mostly RRC) and DU (mostly MAC) The F1 interface is used internally between CU (mostly RRC) and DU (mostly MAC)
to exchange information. In DL, the CU sends messages as defined by the to exchange information. In DL, the CU sends messages as defined by the
...@@ -69,38 +89,94 @@ dedicated handler). In F1, the DU task receives the ITTI message, encodes using ...@@ -69,38 +89,94 @@ dedicated handler). In F1, the DU task receives the ITTI message, encodes using
ASN.1, and sends it over a network socket. The CU task decodes, and sends the ASN.1, and sends it over a network socket. The CU task decodes, and sends the
same ITTI message to the RRC task as done directly in the monolithic case. same ITTI message to the RRC task as done directly in the monolithic case.
Summary of callbacks and handlers:
| Entity | Callback definition | Callback F1 Implementation | Callback Monolithic SA Implementation | Handler |
|--------|---------------------|----------------------------|---------------------------------------|----------------------|
| CU/RRC | `mac_rrc_dl.h` | `mac_rrc_dl_f1ap.c` | `mac_rrc_dl_direct.c` |No handler (use ITTI) |
| DU/MAC | `mac_rrc_ul.h` | `mac_rrc_ul_f1ap.c` | `mac_rrc_ul_direct.c` |`mac_rrc_dl_handler.c`|
A sequence diagram for downlink F1AP messages over the OAI CU/DU functional split:
```mermaid
sequenceDiagram
box rgba(17,158,189,255) CU/RRC
participant TASK_RRC_GNB
participant TASK_CU_F1
end
Note over TASK_RRC_GNB: MAC/RRC callback
TASK_RRC_GNB->>+TASK_CU_F1: F1AP message (ITTI)
Note over TASK_CU_F1: F1 message encoding
Note over TASK_CU_F1: ASN.1 encoding
box Grey DU/MAC
participant TASK_DU_F1
participant MAC
end
Note over TASK_DU_F1: F1AP DL message handler
TASK_CU_F1->>+TASK_DU_F1: SCTP (ITTI)
Note over TASK_DU_F1: F1 message decoding
Note over TASK_DU_F1: ASN.1 decoding
TASK_DU_F1->>+MAC: F1AP message (function call)
Note over MAC: MAC DL message handler
``` ```
+-------------+ and for the uplink F1AP messages:
| |
| CU/RRC | ```mermaid
| | sequenceDiagram
+-------------+ box rgba(17,158,189,255) CU/RRC
| ^ participant TASK_RRC_GNB
Callback def: mac_rrc_dl.h | | No handler needed: participant TASK_CU_F1
F1 impl: mac_rrc_dl_f1ap.c | | RRC has ITTI end
Monolithic: mac_rrc_dl_direct.c | | box Grey DU/MAC
| | participant TASK_DU_F1
DL | | UL participant TASK_MAC_GNB
| | end
| | Callback def: mac_rrc_ul.h Note over TASK_MAC_GNB: MAC/RRC callback
Message handler: | | F1 impl: mac_rrc_ul_f1ap.c TASK_MAC_GNB->>+TASK_DU_F1: F1AP message (ITTI)
mac_rrc_dl_handler.c | | Monolithic: mac_rrc_ul_direct.c Note over TASK_DU_F1: F1 message encoding
v | Note over TASK_DU_F1: ASN.1 encoding
+-------------+ Note over TASK_CU_F1: F1AP UL message handler
| | TASK_DU_F1->>+TASK_CU_F1: SCTP (ITTI)
| DU/MAC | Note over TASK_CU_F1: F1 message decoding
| | Note over TASK_CU_F1: ASN.1 decoding
+-------------+ TASK_CU_F1->>+TASK_RRC_GNB: F1AP message (ITTI)
```
Alternative sequence handling (e.g. Monolithic), for downlink:
```mermaid
sequenceDiagram
box rgba(17,158,189,255) RRC
participant TASK_RRC_GNB
end
Note over TASK_RRC_GNB: mac_rrc_dl_direct.c callback
box Grey MAC
participant TASK_MAC_GNB
end
TASK_RRC_GNB->>+TASK_MAC_GNB: raw F1AP message
Note over TASK_MAC_GNB: mac_rrc_dl_handler.c
```
and for the uplink:
```mermaid
sequenceDiagram
box rgba(17,158,189,255) RRC
participant TASK_RRC_GNB
end
box Grey MAC
participant TASK_MAC_GNB
end
Note over TASK_MAC_GNB: mac_rrc_ul_direct.c callback
TASK_MAC_GNB->>+TASK_RRC_GNB: raw F1AP message (ITTI)
``` ```
# Data plane status (F1-U) ## F1-U
F1-U uses GTP-U for information exchange. The GTP protocol uses some extensions Current status:
for NR-U protocol to report buffer status, but this is not properly tested and
might malfunction. One limitation is that the current implementation
acknowledges each packet individually.
Multiple DUs at one CU are supported in the data plane (as in the control plane). * Buffer status report over GTP-U
* Each packet is acknowledged individually
* Support of multiple DUs per CU
# How to run # How to run
......
...@@ -197,13 +197,17 @@ These modes of operation are supported: ...@@ -197,13 +197,17 @@ These modes of operation are supported:
## gNB F1AP ## gNB F1AP
- Integration of F1AP messages and procedures for the control plane exchanges between the CU and DU entities according to 38.473 Rel. 16 - Integration of F1AP messages and procedures for the control plane exchanges between the CU and DU entities according to 38.473 Rel. 16
- F1 Setup request/response/failure - F1 Interface Management:
- F1 DL/UL RRC message transfer * F1 Setup request/response/failure
- F1 Initial UL RRC message transfer - F1 RRC Message Transfer:
- F1 UE Context setup request/response * F1 Initial UL RRC Message Transfer
- F1 UE Context modification request/response * F1 DL RRC Message Transfer
- F1 UE Context modification required * F1 UL RRC Message Transfer
- F1 UE Context release req/cmd/complete - F1 UE Context Management:
* F1 UE Context setup request/response
* F1 UE Context modification request/response
* F1 UE Context modification required
* F1 UE Context release req/cmd/complete
- F1 gNB CU configuration update - F1 gNB CU configuration update
- F1 Reset (handled at DU only, full reset only) - F1 Reset (handled at DU only, full reset only)
- Interface with RRC - Interface with RRC
......
...@@ -159,6 +159,41 @@ cd ~/openairinterface5g/cmake_targets/ran_build/build ...@@ -159,6 +159,41 @@ cd ~/openairinterface5g/cmake_targets/ran_build/build
sudo ./nr-uesoftmodem -r 32 --numerology 3 --band 257 -C 27533280000 --sa --uicc0.imsi 001010000000001 --ssb 72 --rfsim sudo ./nr-uesoftmodem -r 32 --numerology 3 --band 257 -C 27533280000 --sa --uicc0.imsi 001010000000001 --ssb 72 --rfsim
``` ```
### Connection to an NG-Core
A configuration file can be fed to the nrUE command line in order to connect to the local NGC.
The nrUE configuration file (e.g. [ue.conf](../targets/PROJECTS/GENERIC-NR-5GC/CONF/ue.conf)) is structured in a key-value format and contains the relevant UICC parameters that are necessary to authenticate the UE to the local 5GC. E.g.:
```shell
uicc0 = {
imsi = "001010000000001";
key = "fec86ba6eb707ed08905757b1bb44b8f";
opc = "C42449363BBAD02B66D16BC975D77CC1";
dnn = "oai";
nssai_sst = 1;
}
```
| **Parameter** | **Description** | **Default Value** |
|---------------|-----------------|-------------------|
| **IMSI** | Unique identifier for the UE within the mobile network. Used by the network to identify the UE during authentication. It ensures that the UE is correctly identified by the network. | 001010000000001 |
| **key** | Cryptographic key shared between the UE and the network, used for encryption during the authentication process. | `fec86ba6eb707ed08905757b1bb44b8f` |
| **OPC** | Operator key for the Milenage Authentication and Key Agreement algorithm used for encryption during the authentication process. | Ensures secure communication between the UE and the network by matching the encryption keys. | `C42449363BBAD02B66D16BC975D77CC1` |
| **DNN** | Specifies the name of the data network the UE wishes to connect to, similar to an APN in 4G networks. | `oai` |
| **NSSAI** | Allows the UE to select the appropriate network slice, which provides different QoS. | `1` |
The UE configuration must match the one of the network's AMF. The nrUE can connect by default to OAI CN5G with no need to provide the configuration file.
When running the `nr-uesoftmodem`, one can specify the nrUE configuration file using the `-O` option. E.g.:
```bash
sudo ./nr-uesoftmodem --rfsim --rfsimulator.serveraddr 127.0.0.1 --sa -r 106 --numerology 1 --band 78 -C 3619200000 -O ~/nrue.uicc.conf
```
The CL option `--uicc0.imsi` can override the IMSI value in the configuration file if necessary (e.g. when running multiple UEs): `--uicc0.imsi 001010000000001`.
More details available at [ci-scripts/yaml_files/5g_rfsimulator/README.md](../ci-scripts/yaml_files/5g_rfsimulator/README.md).
## 5.2 End-to-end connectivity test ## 5.2 End-to-end connectivity test
- Ping test from the UE host to the CN5G - Ping test from the UE host to the CN5G
```bash ```bash
......
...@@ -102,47 +102,65 @@ Command line parameters for UE in `--sa` mode: ...@@ -102,47 +102,65 @@ Command line parameters for UE in `--sa` mode:
- `--band` : NR band number (default value 78) - `--band` : NR band number (default value 78)
- `--ssb` : SSB start subcarrier (default value 516) - `--ssb` : SSB start subcarrier (default value 516)
**Optional parameters**: To simplify the configuration for the user testing OAI UE with OAI gNB, the latter prints the following LOG that guides the user to correctly set some of the UE command line parameters:
- `-E`: use three-quarter sampling for split 8 sample rate. Required for
certain radios (e.g., 40MHz with B210). If used on the gNB, it is a good idea
to use for the UE as well (and vice versa).
- `--ue-scan-carrier` : scan for cells in current bandwidth. This option can be used if the SSB position of the gNB is unknown. If multiple cells are detected, the UE will try to connect to the first cell. By default, this option is disabled and the UE attempts to only decode SSB given by `--ssb`.
To simplify the configuration for the user testing OAI UE with OAI gNB, the latter prints the following LOG that guides the user to correctly set some of the UE command line parameters. ```shell
```
[PHY] Command line parameters for OAI UE: -C 3319680000 -r 106 --numerology 1 --ssb 516 [PHY] Command line parameters for OAI UE: -C 3319680000 -r 106 --numerology 1 --ssb 516
``` ```
You can run this, using USRPs, on two separate machines: You can run this, using USRPs, on two separate machines:
``` ```shell
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.fr1.106PRB.usrpb210.conf --gNBs.[0].min_rxtxtime 6 --sa sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.fr1.106PRB.usrpb210.conf --gNBs.[0].min_rxtxtime 6 --sa
sudo ./nr-uesoftmodem -r 106 --numerology 1 --band 78 -C 3619200000 --ssb 516 --sa sudo ./nr-uesoftmodem -r 106 --numerology 1 --band 78 -C 3619200000 --ssb 516 --sa
``` ```
With the RFsimulator (on the same machine): With the **RFsimulator** (on the same machine), just add the option `--rfsim` to both gNB and NR UE command lines.
```bash UE capabilities can be passed according to the [UE Capabilities](#UE-Capabilities) section.
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.fr1.106PRB.usrpb210.conf --gNBs.[0].min_rxtxtime 6 --rfsim --sa
sudo ./nr-uesoftmodem -r 106 --numerology 1 --band 78 -C 3619200000 --ssb 516 --rfsim --sa
```
Additionally, at UE side `--uecap_file` option can be used to pass the UE Capabilities input file (path location + filename), e.g. `--uecap_file ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/uecap_ports1.xml` A detailed tutorial is provided at this page [NR_SA_Tutorial_OAI_nrUE.md](./NR_SA_Tutorial_OAI_nrUE.md).
## Some useful NR-UE parameters ## Optional NR-UE command line options
Some other useful paramters of the UE are Here are some useful command line options for the NR UE:
- `--ue-fo-compensation`: enables the frequency offset compenstation at the UE. This is useful when running over the air and/or without an external clock/time source | Parameter | Description |
- `--usrp-args`: this is the equivalend paramter of `sdr_addrs` field in the gNB config file and can be used to identify the USRP and set some basic paramters (like the clock source) |--------------------------|---------------------------------------------------------------------------------------------------------------|
- `--clock-source`: sets the clock-source (internal or external). | `--ue-scan-carrier` | Scan for cells in current bandwidth. This option can be used if the SSB position of the gNB is unknown. If multiple cells are detected, the UE will try to connect to the first cell. By default, this option is disabled and the UE attempts to only decode SSB given by `--ssb`. |
- `--time-source`: sets the time-source (internal or external). | `--ue-fo-compensation` | Enables the frequency offset compensation at the UE. Useful when running over the air and/or without an external clock/time source. |
| `--usrp-args` | Equivalent to the `sdr_addrs` field in the gNB config file. Used to identify the USRP and set some basic parameters (like the clock source). |
| `--clock-source` | Sets the clock source (internal or external). |
| `--time-source` | Sets the time source (internal or external). |
You can see all options by typing You can view all available options by typing:
```
```shell
./nr-uesoftmodem --help ./nr-uesoftmodem --help
``` ```
## Common gNB and NR UE command line options
### Three-quarter sampling
The command line option `-E` can be used to enable three-quarter sampling for split 8 sample rate. Required for certain radios (e.g., 40MHz with B210). If used on the gNB, it is a good idea to use for the UE as well (and vice versa).
### UE Capabilities
The `--uecap_file` option can be used to pass the UE Capabilities input file (path location + filename), e.g.`--uecap_file ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/uecap_ports1.xml` for 1 layer or e.g. `--uecap_file ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/uecap_ports2.xml` for 2 layers.
This option is available for the following combinations of operation modes and gNB/nrUE softmodems:
| Mode | Executable | Description |
|------------|----------------|-----------------------------------------------------|
| SA | nr-uesoftmodem | Send UE capabilities from the UE to the gNB via RRC |
| phy-test | nr-softmodem | Mimic the reception of UE capabilities by the gNB |
| do-ra | nr-softmodem | Mimic the reception of UE capabilities by the gNB |
e.g.
```shell
sudo ./nr-uesoftmodem --sa -r 106 --numerology 1 --band 78 -C 3319680000 --ue-nb-ant-tx 2 --ue-nb-ant-rx 2 --uecap_file /opt/oai-nr-ue/etc/uecap.xml
```
## How to run a NTN configuration ## How to run a NTN configuration
...@@ -310,7 +328,7 @@ In summary: ...@@ -310,7 +328,7 @@ In summary:
* `scp usera@machineA:/the/path/where/you/launched/nr-softmodem/r*config.raw userb@machineB:/the/path/where/you/will/launch/nr-uesoftmodem/` * `scp usera@machineA:/the/path/where/you/launched/nr-softmodem/r*config.raw userb@machineB:/the/path/where/you/will/launch/nr-uesoftmodem/`
* Obviously this operation should be done before launching the `nr-uesoftmodem` executable. * Obviously this operation should be done before launching the `nr-uesoftmodem` executable.
In phy-test mode it is possible to mimic the reception of UE Capabilities at gNB by passing through the command line parameter `--uecap_file` the location and file name of the input UE Capability file, e.g. `--uecap_file ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/uecap_ports1.xml` (1 layer) or `--uecap_file ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/uecap_ports2.xml` (2 layers). In phy-test mode it is possible to mimic the reception of UE Capabilities at gNB through the command line parameter `--uecap_file`. Refer to the [UE Capabilities](#UE-Capabilities) section for more details.
## noS1 setup with OAI UE ## noS1 setup with OAI UE
...@@ -346,7 +364,7 @@ The do-ra flag is used to ran the NR Random Access procedures in contention-free ...@@ -346,7 +364,7 @@ The do-ra flag is used to ran the NR Random Access procedures in contention-free
In order to run the RA, the `--do-ra` flag is needed for both the gNB and the UE. In order to run the RA, the `--do-ra` flag is needed for both the gNB and the UE.
In do-ra mode it is possible to mimic the reception of UE Capabilities at gNB by passing through the command line parameter `--uecap_file` the location and file name of the input UE Capability file, e.g. `--uecap_file ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/uecap_ports1.xml` In do-ra mode it is possible to mimic the reception of UE Capabilities at gNB through the command line parameter `--uecap_file`. Refer to the [UE Capabilities](#UE-Capabilities) section for more details.
To run using the RFsimulator: To run using the RFsimulator:
......
...@@ -25,7 +25,8 @@ ninja tests ...@@ -25,7 +25,8 @@ ninja tests
``` ```
Then, you can run `ctest` to run all tests: Then, you can run `ctest` to run all tests:
```
```bash
$ ctest $ ctest
Test project /home/richie/w/ctest/build Test project /home/richie/w/ctest/build
Start 1: nr_rlc_tests Start 1: nr_rlc_tests
...@@ -36,6 +37,8 @@ Test project /home/richie/w/ctest/build ...@@ -36,6 +37,8 @@ Test project /home/richie/w/ctest/build
Total Test time (real) = 0.06 sec Total Test time (real) = 0.06 sec
``` ```
The user can see all available tests by typing `ctest -N` and then run a specific with `ctest -R <test_name>`, e.g. `ctest -R nr_rlc_tests`.
A couple of interesting variables are `--verbose`, `--output-on-failure`. A couple of interesting variables are `--verbose`, `--output-on-failure`.
# How to add a new test # How to add a new test
...@@ -59,7 +62,8 @@ process is ...@@ -59,7 +62,8 @@ process is
In the simplest case, in an existing `CMakeLists.txt`, you might add the In the simplest case, in an existing `CMakeLists.txt`, you might add the
following: following:
```
```bash
if(ENABLE_TESTS) if(ENABLE_TESTS)
add_executable(my_test mytest.c) add_executable(my_test mytest.c)
add_dependencies(tests my_test) add_dependencies(tests my_test)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment