Commit 56ceb76a authored by Robert Schmidt's avatar Robert Schmidt

Merge remote-tracking branch 'origin/readme-correction' into integration_2023_w33

parents d1ac08ff ca96b9e9
...@@ -410,16 +410,33 @@ in HSS config: ...@@ -410,16 +410,33 @@ in HSS config:
NB_USERS: 10 NB_USERS: 10
``` ```
in UE config: All UE parameter values will be taken from the mounted config file, so modify
the corresponding UE file to reflect the above changes
```yaml ```yaml
MCC: '208' oai_ue0:
MNC: '96' [...]
SHORT_IMSI: '0100000001' volumes:
LTE_KEY: 'fec86ba6eb707ed08905757b1bb44b8f' - ../../conf_files/lteue.usim-ci.conf:/opt/oai-lte-ue/etc/ue_usim.conf
OPC: 'c42449363bbad02b66d16bc975d77cc1' ```
MSISDN: '001011234561010'
HPLMN: 20896 and in the UE file, you should have
```
PLMN: {
PLMN0: {
FULLNAME="OpenAirInterface";
SHORTNAME="OAICN";
MNC="96";
MCC="208";
};
};
[...]
SIM: {
MSIN="0100000001";
USIM_API_K="fec86ba6eb707ed08905757b1bb44b8f";
OPC="c42449363bbad02b66d16bc975d77cc1";
MSISDN="001011234561010";
};
``` ```
As you can see: `LTE_K` and `LTE_KEY` are the same value. And `OP_KEY` and `OPC` can be deduced from each other. Look in HSS logs. As you can see: `LTE_K` and `LTE_KEY` are the same value. And `OP_KEY` and `OPC` can be deduced from each other. Look in HSS logs.
...@@ -471,13 +488,19 @@ in SPGW-C/-U configs: ...@@ -471,13 +488,19 @@ in SPGW-C/-U configs:
REALM: openairinterface.org REALM: openairinterface.org
``` ```
in eNB config: In eNB, all the parameter values will be taken from the mounted config file.
```yaml ```yaml
MCC: '208' oai_enb0:
MNC: '96' [...]
MNC_LENGTH: 2 volumes:
TAC: 1 - ../../conf_files/enb.band7.25prb.rfsim.conf:/opt/oai-enb/etc/enb.conf
```
with the eNB config reading:
```libconfig
plmn_list = ( { mcc = 208; mnc = 96; mnc_length = 2; } );
``` ```
The values SHALL match, and `TAC` shall match `TAC_0` from MME. The values SHALL match, and `TAC` shall match `TAC_0` from MME.
......
...@@ -321,19 +321,52 @@ In the `SMF` section, provide your own DNS IP address: ...@@ -321,19 +321,52 @@ In the `SMF` section, provide your own DNS IP address:
DEFAULT_DNS_IPV4_ADDRESS=172.21.3.100 DEFAULT_DNS_IPV4_ADDRESS=172.21.3.100
``` ```
In the `gNB` section, provide your docker-host primary IP address and interface name: in our case `172.21.16.128` and `eno1`. gNB section:
All the parameter values will be taken from the mounted config file
```yaml ```yaml
GNB_NGA_IF_NAME: eno1 oai-gnb:
GNB_NGA_IP_ADDRESS: 172.21.16.128 [...]
GNB_NGU_IF_NAME: eno1 volumes:
GNB_NGU_IP_ADDRESS: 172.21.16.128 - ../../conf_files/gnb.sa.band78.106prb.l2sim.conf:/opt/oai-gnb/etc/gnb.conf
```
with the configuration file having something like:
```libconfig
NETWORK_INTERFACES :
{
GNB_INTERFACE_NAME_FOR_NG_AMF = "eno1";
GNB_IPV4_ADDRESS_FOR_NG_AMF = "172.21.16.128";
GNB_INTERFACE_NAME_FOR_NGU = "eno1";
GNB_IPV4_ADDRESS_FOR_NGU = "172.21.16.128";
GNB_PORT_FOR_NGU = 2152; # Spec 2152
};
``` ```
Same thing in the `nr-ue` section: For the UE, all the parameter values will be taken from the mounted config
file. Example:
```yaml ```yaml
NR_UE_NFAPI_IF_NAME: eno1 oai-nr-ue0:
[...]
volumes:
- ../../conf_files/nrue.band78.106prb.l2sim.conf:/opt/oai-nr-ue/etc/nr-ue.conf
- ../../../openair1/SIMULATION/LTE_PHY/BLER_SIMULATIONS/AWGN/AWGN_results:/opt/oai-nr-ue/openair1/SIMULATION/LTE_PHY/BLER_SIMULATIONS/AWGN/AWGN_results
```
where the UE configuration (mounted to `/opt/oai-nr-ue/etc/nr-ue.conf`) reads
```libconfig
MACRLCs = (
{
num_cc = 1;
tr_n_preference = "nfapi";
local_n_if_name = "eno1";
remote_n_address = "127.0.0.1"; //Proxy IP
local_n_address = "127.0.0.1";
...
``` ```
This tutorial is a first draft. This nFAPI feature and the proxy are still under development. This tutorial is a first draft. This nFAPI feature and the proxy are still under development.
......
...@@ -234,24 +234,23 @@ oaitun_ue1: flags=4305<UP,POINTOPOINT,RUNNING,NOARP,MULTICAST> mtu 1500 ...@@ -234,24 +234,23 @@ oaitun_ue1: flags=4305<UP,POINTOPOINT,RUNNING,NOARP,MULTICAST> mtu 1500
## 2.4. Deploy Second OAI NR-UE in RF simulator mode and in Standalone Mode ## ## 2.4. Deploy Second OAI NR-UE in RF simulator mode and in Standalone Mode ##
```bash Create a entry for new IMSI (208990100001101) in oai_db.sql file.
Create a entry for new IMSI (208990100001101) in oai_db.sql file For this, refer to section [Making the NR-UE connect to the core
Refer Section - [Making the NR-UE connect to the core network](#51-making-the-nr-ue-connect-to-the-core-network) network](#51-making-the-nr-ue-connect-to-the-core-network)
Create the entry for the second UE in `docker-compose.yaml` file as follows:
Create entry for Second UE in docker-compose.yaml file as follows: ```yaml
oai-nr-ue2: oai-nr-ue2:
image: oai-nr-ue:develop image: oai-nr-ue:develop
privileged: true privileged: true
container_name: rfsim5g-oai-nr-ue2 container_name: rfsim5g-oai-nr-ue2
environment: environment:
FULL_IMSI: '208990100001101'
FULL_KEY: 'fec86ba6eb707ed08905757b1bb44b8f'
OPC: 'C42449363BBAD02B66D16BC975D77CC1'
DNN: oai
NSSAI_SST: 1
USE_ADDITIONAL_OPTIONS: -E --sa --rfsim -r 106 --numerology 1 -C 3619200000 --rfsimulator.serveraddr 192.168.71.140 --log_config.global_log_options level,nocolor,time USE_ADDITIONAL_OPTIONS: -E --sa --rfsim -r 106 --numerology 1 -C 3619200000 --rfsimulator.serveraddr 192.168.71.140 --log_config.global_log_options level,nocolor,time
depends_on: depends_on:
- oai-gnb - oai-gnb
volumes:
- ../../conf_files/nrue.uicc.conf:/opt/oai-nr-ue/etc/nr-ue.conf
networks: networks:
public_net: public_net:
ipv4_address: 192.168.71.151 ipv4_address: 192.168.71.151
...@@ -496,13 +495,31 @@ INSERT INTO `users` VALUES ('208990100001101','1','55000000000000',NULL,'PURGED' ...@@ -496,13 +495,31 @@ INSERT INTO `users` VALUES ('208990100001101','1','55000000000000',NULL,'PURGED'
As you can see, 2 other values shall match in the NR-UE section of `docker-compose.yaml`: As you can see, 2 other values shall match in the NR-UE section of `docker-compose.yaml`:
OAI UE - 1 All the values such as IMSI and KEY are taken from the configuration file mounted into the container. For the first UE, provision as usual through the config file
* `FULL_IMSI: '208990100001100'`
* `FULL_KEY: 'fec86ba6eb707ed08905757b1bb44b8f'` ```yaml
oai-nr-ue:
[...]
volumes:
- ../../conf_files/nrue.uicc.conf:/opt/oai-nr-ue/etc/nr-ue.conf
```
with the config having:
```libconfig
uicc0 = {
imsi = "208990100001100";
key = "fec86ba6eb707ed08905757b1bb44b8f";
opc= "C42449363BBAD02B66D16BC975D77CC1";
dnn= "oai";
nssai_sst=1;
}
```
OAI UE - 2 The second UE's IMSI might be changed by either having the second UEs
* `FULL_IMSI: '208990100001101'` docker-compose entry mount another config, or add `--uicc0.imsi
* `FULL_KEY: 'fec86ba6eb707ed08905757b1bb44b8f'` 208990100001101` in `USE_ADDITIONAL_OPTIONS` entry. Note that the latter is a
feature of the configuration module to overwrite any configuration option in
the config file on the command line.
We are also using a dedicated `oai-smf.conf` for the `SMF` container: the `oai` DNN shall match the one in the NR-UE section of `docker-compose.yaml` (`DNN: oai`). We are also using a dedicated `oai-smf.conf` for the `SMF` container: the `oai` DNN shall match the one in the NR-UE section of `docker-compose.yaml` (`DNN: oai`).
......
The configuration module objectives are The configuration module objectives are
1. Allow easy parameters management in oai, helping the development of a flexible, modularized and fully configurable softmodem. 1. Allow easy parameters management in oai, helping the development of a flexible, modularized and fully configurable softmodem.
1. Use a common configuration API in all oai modules 2. Use a common configuration API in all oai modules
1. Allow development of alternative configuration sources without modifying the oai code. Today the only delivered configuration source is the libconfig format configuration file. 3. Allow development of alternative configuration sources without modifying the oai code. Today the only delivered configuration source is the libconfig format configuration file.
As a developer you may need to look at these sections: As a developer you may need to look at these sections:
......
The configuration module maps a configuration file section to a `paramdef_t` structure array. One `config_get` call can be used to return the values of all the parameters described in the `paramdef_t` array. The configuration module maps a configuration file section to a `paramdef_t` structure array. One `config_get` call can be used to return the values of all the parameters described in the `paramdef_t` array.
Retrieving a single occurence of a parameter set ( a group in the libconfig terminology) is just a two steps task: Retrieving a single occurence of a parameter set ( a group in the libconfig terminology) is just a two steps task:
1. describe the parameters in a `paramdef_t` array 1. describe the parameters in a `paramdef_t` array
1. call the `config_get` function 2. call the `config_get` function
[config_get example](../../config/devusage/addaparam.md) [config_get example](../../config/devusage/addaparam.md)
......
[[_TOC_]]
-O is the only mandatory command line option to start the eNodeb softmodem (lte-softmodem executable), it is used to specify the configuration source with the associated parameters: # General usage
`-O` is the only mandatory command line option to start the softmodems (4G/5G xNB, UEs). It is used to specify the configuration source with the associated parameters:
```bash ```bash
$ ./lte-softmodem -O <configsource>:<parameter1>:<parameter2>:... $ ./lte-softmodem -O <configsource>:<parameter1>:<parameter2>:...
``` ```
The configuration module can also be used without a configuration source, ie to only parse the command line. In this case the -O switch is optional. This mode is used in the ue-softmodem executable and by the phy_simulators executables (ulsim, dlsim) The same applies for `nr-softmodem`, `lte-uesoftmodem`, `nr-uesoftmodem`.
The configuration module can also be used without a configuration source, ie to only parse the command line. In this case the -O switch is optional. This mode is typically used in the `lte-uesoftmodem` executable and by the physical simulator executables (`ulsim`, `dlsim`).
# Configuration sources
Currently the available config sources are: Currently the available config sources are:
...@@ -13,6 +20,8 @@ $ ./lte-softmodem -O libconfig:<config>:dbgl<debuglevel> ...@@ -13,6 +20,8 @@ $ ./lte-softmodem -O libconfig:<config>:dbgl<debuglevel>
``` ```
- **cmdlineonly**: command line only, the default mode for lte-uesoftmodem and the phy simiulators. In this case -O may be used to specify the config module debug level. - **cmdlineonly**: command line only, the default mode for lte-uesoftmodem and the phy simiulators. In this case -O may be used to specify the config module debug level.
# Detailed configuration information and debugging
The debug level is a mask: The debug level is a mask:
* bit 1: print parameters values * bit 1: print parameters values
* bit 2: print memory allocation/free performed by the config module * bit 2: print memory allocation/free performed by the config module
...@@ -32,8 +41,8 @@ bit 5 (dbgl32) can be useful to detect unused parameters from a config file or t ...@@ -32,8 +41,8 @@ bit 5 (dbgl32) can be useful to detect unused parameters from a config file or t
To get help on supported parameters you can use specific options: To get help on supported parameters you can use specific options:
* ---help: print help for command line only parameters and for parameters not defined in a specific section * `--help`: print help for command line only parameters and for parameters not defined in a specific section
* ---help_< prefix > : print help for parameters defined under the section < prefix > * `--help_<prefix>` : print help for parameters defined under the section `<prefix>`
``` ```
./lte-softmodem -O libconfig:/usr/local/oai/conf/enb.nbiot.band7.tm1.50PRB.usrpb210.conf --help ./lte-softmodem -O libconfig:/usr/local/oai/conf/enb.nbiot.band7.tm1.50PRB.usrpb210.conf --help
...@@ -84,15 +93,16 @@ Getting ENBSParams ...@@ -84,15 +93,16 @@ Getting ENBSParams
-------------------------------------------------------------------- --------------------------------------------------------------------
/usr/local/oai/issue390_configmodule_cmdlinebug/openairinterface5g/common/config/config_cmdline.c:224 config_process_cmdline() Exiting OAI softmodem: [CONFIG] Exiting after displaying help /usr/local/oai/issue390_configmodule_cmdlinebug/openairinterface5g/common/config/config_cmdline.c:224 config_process_cmdline() Exiting OAI softmodem: [CONFIG] Exiting after displaying help
``` ```
For the lte-softmodem (the eNodeB) The config source parameter defaults to libconfig, preserving the initial -O option format. In this case you cannot specify the debug level. For the lte-softmodem (the eNodeB), the config source parameter defaults to libconfig, preserving the initial -O option format. In this case you cannot specify the debug level.
```bash ```bash
$ ./lte-softmodem -O <config> $ ./lte-softmodem -O <config>
``` ```
# Configuration of the configuration module
Configuration file parameters, except for the configuration file path, can be specified in a **config** section in the configuration file: Configuration file parameters, except for the configuration file path, can be specified in a **config** section in the configuration file:
``` ```
...@@ -101,7 +111,12 @@ config: ...@@ -101,7 +111,12 @@ config:
debugflags = 1; debugflags = 1;
} }
``` ```
Configuration files examples can be found in the targets/PROJECTS/GENERIC-LTE-EPC/CONF sub-directory of the oai source tree. To minimize the number of configuration file to maintain, any parameter can also be specified on the command line. For example to modify the lte bandwidth to 20 MHz where the configuration file specifies 10MHz you can enter:
Configuration files examples can be found in the `targets/PROJECTS/GENERIC-LTE-EPC/CONF` sub-directory of the oai source tree.
# Overwriting config options from the command line
To minimize the number of configuration file to maintain, any parameter can also be specified on the command line. For example to modify the lte bandwidth to 20 MHz where the configuration file specifies 10MHz you can enter:
```bash ```bash
$ ./lte-softmodem -O <config> --eNBs.[0].component_carriers.[0].N_RB_DL 100 $ ./lte-softmodem -O <config> --eNBs.[0].component_carriers.[0].N_RB_DL 100
......
...@@ -81,6 +81,7 @@ Legacy unmaintained files: ...@@ -81,6 +81,7 @@ Legacy unmaintained files:
- The [logging module](../common/utils/LOG/DOC/log.md) - The [logging module](../common/utils/LOG/DOC/log.md)
- The [shared object loader](../common/utils/DOC/loader.md) - The [shared object loader](../common/utils/DOC/loader.md)
- The [threadpool](../common/utils/threadPool/thread-pool.md) used in L1 - The [threadpool](../common/utils/threadPool/thread-pool.md) used in L1
- The [LDPC implementation](../openair1/PHY/CODING/DOC/LDPCImplementation.md) is a shared library
## SDRs ## SDRs
......
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