Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wangwenhui
OpenXG-RAN
Commits
bd1c609c
Commit
bd1c609c
authored
Oct 12, 2018
by
laurent
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
issue 359 dlsim CPU measurements
parent
f34e735e
Changes
8
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
614 additions
and
757 deletions
+614
-757
cmake_targets/lte-simulators/CMakeLists.txt
cmake_targets/lte-simulators/CMakeLists.txt
+1
-0
openair1/PHY/defs_UE.h
openair1/PHY/defs_UE.h
+1
-0
openair1/PHY/defs_eNB.h
openair1/PHY/defs_eNB.h
+1
-1
openair1/SCHED/phy_procedures_lte_eNb.c
openair1/SCHED/phy_procedures_lte_eNb.c
+2
-0
openair1/SCHED_UE/phy_procedures_lte_ue.c
openair1/SCHED_UE/phy_procedures_lte_ue.c
+29
-25
openair1/SIMULATION/LTE_PHY/common_sim.h
openair1/SIMULATION/LTE_PHY/common_sim.h
+164
-0
openair1/SIMULATION/LTE_PHY/dlsim.c
openair1/SIMULATION/LTE_PHY/dlsim.c
+290
-501
openair1/SIMULATION/LTE_PHY/ulsim.c
openair1/SIMULATION/LTE_PHY/ulsim.c
+126
-230
No files found.
cmake_targets/lte-simulators/CMakeLists.txt
View file @
bd1c609c
...
...
@@ -9,4 +9,5 @@ set(MU_RECIEVER False)
set
(
NAS_UE False
)
set
(
MESSAGE_CHART_GENERATOR False
)
set
(
RRC_ASN1_VERSION
"Rel14"
)
set
(
UE_TIMING_TRACE True
)
include
(
${
CMAKE_CURRENT_SOURCE_DIR
}
/../CMakeLists.txt
)
openair1/PHY/defs_UE.h
View file @
bd1c609c
...
...
@@ -847,6 +847,7 @@ typedef struct {
time_stats_t
pdsch_procedures_stat
[
RX_NB_TH
];
time_stats_t
pdsch_procedures_per_slot_stat
[
RX_NB_TH
][
LTE_SLOTS_PER_SUBFRAME
];
time_stats_t
dlsch_procedures_stat
[
RX_NB_TH
];
time_stats_t
crnti_procedures_stats
;
time_stats_t
ofdm_demod_stats
;
time_stats_t
dlsch_rx_pdcch_stats
;
...
...
openair1/PHY/defs_eNB.h
View file @
bd1c609c
...
...
@@ -1074,12 +1074,12 @@ typedef struct PHY_VARS_eNB_s {
int
hw_timing_advance
;
time_stats_t
phy_proc
;
time_stats_t
phy_proc_tx
;
time_stats_t
phy_proc_rx
;
time_stats_t
rx_prach
;
time_stats_t
ofdm_mod_stats
;
time_stats_t
dlsch_common_and_dci
;
time_stats_t
dlsch_encoding_stats
;
time_stats_t
dlsch_modulation_stats
;
time_stats_t
dlsch_scrambling_stats
;
...
...
openair1/SCHED/phy_procedures_lte_eNb.c
View file @
bd1c609c
...
...
@@ -484,6 +484,7 @@ void phy_procedures_eNB_TX(PHY_VARS_eNB *eNB,
VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME
(
VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_PROCEDURES_ENB_TX
+
(
eNB
->
CC_id
),
1
);
if
(
do_meas
==
1
)
start_meas
(
&
eNB
->
phy_proc_tx
);
if
(
do_meas
==
1
)
start_meas
(
&
eNB
->
dlsch_common_and_dci
);
// clear the transmit data array for the current subframe
for
(
aa
=
0
;
aa
<
fp
->
nb_antenna_ports_eNB
;
aa
++
)
{
...
...
@@ -578,6 +579,7 @@ void phy_procedures_eNB_TX(PHY_VARS_eNB *eNB,
subframe
);
}
if
(
do_meas
==
1
)
stop_meas
(
&
eNB
->
dlsch_common_and_dci
);
VCD_SIGNAL_DUMPER_DUMP_FUNCTION_BY_NAME
(
VCD_SIGNAL_DUMPER_FUNCTIONS_PHY_ENB_PDCCH_TX
,
0
);
...
...
openair1/SCHED_UE/phy_procedures_lte_ue.c
View file @
bd1c609c
This diff is collapsed.
Click to expand it.
openair1/SIMULATION/LTE_PHY/common_sim.h
0 → 100644
View file @
bd1c609c
static
int
cmpdouble
(
const
void
*
p1
,
const
void
*
p2
)
{
return
*
(
double
*
)
p1
>
*
(
double
*
)
p2
;
}
double
median
(
varArray_t
*
input
)
{
return
*
(
double
*
)((
uint8_t
*
)(
input
+
1
)
+
(
input
->
size
/
2
)
*
input
->
atomSize
);
}
double
q1
(
varArray_t
*
input
)
{
return
*
(
double
*
)((
uint8_t
*
)(
input
+
1
)
+
(
input
->
size
/
4
)
*
input
->
atomSize
);
}
double
q3
(
varArray_t
*
input
)
{
return
*
(
double
*
)((
uint8_t
*
)(
input
+
1
)
+
(
3
*
input
->
size
/
4
)
*
input
->
atomSize
);
}
void
dumpVarArray
(
varArray_t
*
input
)
{
double
*
ptr
=
dataArray
(
input
);
printf
(
"dumping size=%ld
\n
"
,
input
->
size
);
for
(
int
i
=
0
;
i
<
input
->
size
;
i
++
)
printf
(
"%.1f:"
,
*
ptr
++
);
printf
(
"
\n
"
);
}
void
sumUpStats
(
time_stats_t
*
res
,
time_stats_t
*
src
,
int
lastActive
)
{
reset_meas
(
res
);
for
(
int
i
=
0
;
i
<
RX_NB_TH
;
i
++
)
{
res
->
diff
+=
src
[
i
].
diff
;
res
->
diff_square
+=
src
[
i
].
diff_square
;
res
->
trials
+=
src
[
i
].
trials
;
if
(
src
[
i
].
max
>
res
->
max
)
res
->
max
=
src
[
i
].
max
;
}
res
->
p_time
=
src
[
lastActive
].
p_time
;
}
void
sumUpStatsSlot
(
time_stats_t
*
res
,
time_stats_t
src
[
RX_NB_TH
][
2
],
int
lastActive
)
{
reset_meas
(
res
);
for
(
int
i
=
0
;
i
<
RX_NB_TH
;
i
++
)
{
res
->
diff
+=
src
[
i
][
0
].
diff
+
src
[
i
][
1
].
diff
;
res
->
diff_square
+=
src
[
i
][
0
].
diff_square
+
src
[
i
][
1
].
diff_square
;
res
->
trials
+=
src
[
i
][
0
].
trials
+
src
[
i
][
1
].
trials
;
if
(
src
[
i
][
0
].
max
>
res
->
max
)
res
->
max
=
src
[
i
][
0
].
max
;
if
(
src
[
i
][
1
].
max
>
res
->
max
)
res
->
max
=
src
[
i
][
1
].
max
;}
int
last
=
src
[
lastActive
][
0
].
in
<
src
[
lastActive
][
1
].
in
?
1
:
0
;
res
->
p_time
=
src
[
lastActive
][
last
].
p_time
;
}
void
printStatIndent
(
time_stats_t
*
ptr
,
char
*
txt
)
{
printf
(
"|__ %-50s %.2f us (%d trials)
\n
"
,
txt
,
ptr
->
trials
?
inMicroS
(
ptr
->
diff
/
ptr
->
trials
)
:
0
,
ptr
->
trials
);
}
void
printStatIndent2
(
time_stats_t
*
ptr
,
char
*
txt
,
int
turbo_iter
)
{
double
timeBase
=
1
/
(
1000
*
cpu_freq_GHz
);
printf
(
" |__ %-45s %.2f us (cycles/block %ld, %5d trials)
\n
"
,
txt
,
ptr
->
trials
?
((
double
)
ptr
->
diff
)
/
ptr
->
trials
*
timeBase
:
0
,
turbo_iter
?
(
uint64_t
)
round
(((
double
)
ptr
->
diff
)
/
turbo_iter
)
:
0
,
ptr
->
trials
);
}
double
squareRoot
(
time_stats_t
*
ptr
)
{
double
timeBase
=
1
/
(
1000
*
cpu_freq_GHz
);
return
sqrt
((
double
)
ptr
->
diff_square
*
pow
(
timeBase
,
2
)
/
ptr
->
trials
-
pow
((
double
)
ptr
->
diff
/
ptr
->
trials
*
timeBase
,
2
));
}
void
printDistribution
(
time_stats_t
*
ptr
,
varArray_t
*
sortedList
,
char
*
txt
)
{
double
timeBase
=
1
/
(
1000
*
cpu_freq_GHz
);
printf
(
"%-50s :%.2f us (%d trials)
\n
"
,
txt
,
(
double
)
ptr
->
diff
/
ptr
->
trials
*
timeBase
,
ptr
->
trials
);
printf
(
"|__ Statistics std=%.2f, median=%.2f, q1=%.2f, q3=%.2f µs (on %ld trials)
\n
"
,
squareRoot
(
ptr
),
median
(
sortedList
),
q1
(
sortedList
),
q3
(
sortedList
),
sortedList
->
size
);
}
void
logDistribution
(
FILE
*
fd
,
time_stats_t
*
ptr
,
varArray_t
*
sortedList
,
int
dropped
)
{
fprintf
(
fd
,
"%f;%f;%f;%f;%f;%f;%d;"
,
squareRoot
(
ptr
),
(
double
)
ptr
->
max
,
*
(
double
*
)
dataArray
(
sortedList
),
median
(
sortedList
),
q1
(
sortedList
),
q3
(
sortedList
),
dropped
);
}
struct
option
*
parse_oai_options
(
paramdef_t
*
options
)
{
int
l
;
for
(
l
=
0
;
options
[
l
].
optname
[
0
]
!=
0
;
l
++
)
{};
struct
option
*
long_options
=
calloc
(
sizeof
(
struct
option
),
l
);
for
(
int
i
=
0
;
options
[
i
].
optname
[
0
]
!=
0
;
i
++
)
{
long_options
[
i
].
name
=
options
[
i
].
optname
;
long_options
[
i
].
has_arg
=
options
[
i
].
paramflags
==
PARAMFLAG_BOOL
?
no_argument
:
required_argument
;
if
(
options
[
i
].
voidptr
)
switch
(
options
[
i
].
type
)
{
case
TYPE_INT
:
*
options
[
i
].
iptr
=
options
[
i
].
defintval
;
break
;
case
TYPE_DOUBLE
:
*
options
[
i
].
dblptr
=
options
[
i
].
defdblval
;
break
;
case
TYPE_UINT8
:
*
options
[
i
].
u8ptr
=
options
[
i
].
defintval
;
break
;
case
TYPE_UINT16
:
*
options
[
i
].
u16ptr
=
options
[
i
].
defintval
;
break
;
default:
printf
(
"not parsed type for default value %s
\n
"
,
options
[
i
].
optname
);
exit
(
1
);
}
continue
;
};
return
long_options
;
}
void
display_options_values
(
paramdef_t
*
options
,
int
verbose
)
{
for
(
paramdef_t
*
ptr
=
options
;
ptr
->
optname
[
0
]
!=
0
;
ptr
++
)
{
char
varText
[
256
]
=
"need specific display"
;
if
(
ptr
->
voidptr
!=
NULL
)
{
if
(
(
ptr
->
paramflags
&
PARAMFLAG_BOOL
)
)
strcpy
(
varText
,
*
(
bool
*
)
ptr
->
iptr
?
"True"
:
"False"
);
else
switch
(
ptr
->
type
)
{
case
TYPE_INT
:
sprintf
(
varText
,
"%d"
,
*
ptr
->
iptr
);
break
;
case
TYPE_DOUBLE
:
sprintf
(
varText
,
"%.2f"
,
*
ptr
->
dblptr
);
break
;
case
TYPE_UINT8
:
sprintf
(
varText
,
"%d"
,(
int
)
*
ptr
->
u8ptr
);
break
;
case
TYPE_UINT16
:
sprintf
(
varText
,
"%d"
,(
int
)
*
ptr
->
u16ptr
);
break
;
default:
printf
(
"not decoded type
\n
"
);
exit
(
1
);
}
}
printf
(
"--%-20s set to %s
\n
"
,
ptr
->
optname
,
varText
);
if
(
verbose
)
printf
(
"%s
\n
"
,
ptr
->
helpstr
);
}
}
openair1/SIMULATION/LTE_PHY/dlsim.c
View file @
bd1c609c
This diff is collapsed.
Click to expand it.
openair1/SIMULATION/LTE_PHY/ulsim.c
View file @
bd1c609c
/*
Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The OpenAirInterface Software Alliance licenses this file to You under
the OAI Public License, Version 1.1 (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.openairinterface.org/?page_id=698
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.
-------------------------------------------------------------------------------
For more information about the OpenAirInterface (OAI) Software Alliance:
contact@openairinterface.org
*/
*
Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
*
contributor license agreements. See the NOTICE file distributed with
*
this work for additional information regarding copyright ownership.
*
The OpenAirInterface Software Alliance licenses this file to You under
*
the OAI Public License, Version 1.1 (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.openairinterface.org/?page_id=698
*
*
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.
*
-------------------------------------------------------------------------------
*
For more information about the OpenAirInterface (OAI) Software Alliance:
*
contact@openairinterface.org
*/
/*! \file ulsim.c
\brief Top-level UL simulator
...
...
@@ -60,32 +60,7 @@
double
cpuf
;
#define inMicroS(a) (((double)(a))/(cpu_freq_GHz*1000.0))
//#define MCS_COUNT 23//added for PHY abstraction
static
int
cmpdouble
(
const
void
*
p1
,
const
void
*
p2
)
{
return
*
(
double
*
)
p1
>
*
(
double
*
)
p2
;
}
double
median
(
varArray_t
*
input
)
{
return
*
(
double
*
)((
uint8_t
*
)(
input
+
1
)
+
(
input
->
size
/
2
)
*
input
->
atomSize
);
}
double
q1
(
varArray_t
*
input
)
{
return
*
(
double
*
)((
uint8_t
*
)(
input
+
1
)
+
(
input
->
size
/
4
)
*
input
->
atomSize
);
}
double
q3
(
varArray_t
*
input
)
{
return
*
(
double
*
)((
uint8_t
*
)(
input
+
1
)
+
(
3
*
input
->
size
/
4
)
*
input
->
atomSize
);
}
void
dumpVarArray
(
varArray_t
*
input
)
{
double
*
ptr
=
dataArray
(
input
);
printf
(
"dumping size=%ld
\n
"
,
input
->
size
);
for
(
int
i
=
0
;
i
<
input
->
size
;
i
++
)
printf
(
"%.1f:"
,
*
ptr
++
);
printf
(
"
\n
"
);
}
#include <openair1/SIMULATION/LTE_PHY/common_sim.h>
channel_desc_t
*
eNB2UE
[
NUMBER_OF_eNB_MAX
][
NUMBER_OF_UE_MAX
];
channel_desc_t
*
UE2eNB
[
NUMBER_OF_UE_MAX
][
NUMBER_OF_eNB_MAX
];
//Added for PHY abstractionopenair1/PHY/TOOLS/lte_phy_scope.h
...
...
@@ -348,48 +323,8 @@ void fill_ulsch_dci(PHY_VARS_eNB *eNB,
ul_req
->
tl
.
tag
=
NFAPI_UL_CONFIG_REQUEST_BODY_TAG
;
}
void
printStatIndent
(
time_stats_t
*
ptr
,
char
*
txt
)
{
printf
(
"|__ %-50s %.2f us (%d trials)
\n
"
,
txt
,
inMicroS
(
ptr
->
diff
/
ptr
->
trials
),
ptr
->
trials
);
}
void
printStatIndent2
(
time_stats_t
*
ptr
,
char
*
txt
,
int
turbo_iter
)
{
double
timeBase
=
1
/
(
1000
*
cpu_freq_GHz
);
printf
(
" |__ %-45s %.2f us (cycles/block %7g, %5d trials)
\n
"
,
txt
,
((
double
)
ptr
->
diff
)
/
ptr
->
trials
*
timeBase
,
round
(((
double
)
ptr
->
diff
)
/
turbo_iter
),
ptr
->
trials
);
}
double
squareRoot
(
time_stats_t
*
ptr
)
{
double
timeBase
=
1
/
(
1000
*
cpu_freq_GHz
);
return
sqrt
((
double
)
ptr
->
diff_square
*
pow
(
timeBase
,
2
)
/
ptr
->
trials
-
pow
((
double
)
ptr
->
diff
/
ptr
->
trials
*
timeBase
,
2
));
}
void
printDistribution
(
time_stats_t
*
ptr
,
varArray_t
*
sortedList
,
char
*
txt
)
{
double
timeBase
=
1
/
(
1000
*
cpu_freq_GHz
);
printf
(
"%-50s :%.2f us (%d trials)
\n
"
,
txt
,
(
double
)
ptr
->
diff
/
ptr
->
trials
*
timeBase
,
ptr
->
trials
);
printf
(
"|__ Statistics std=%.2f, median=%.2f, q1=%.2f, q3=%.2f µs (on %ld trials)
\n
"
,
squareRoot
(
ptr
),
median
(
sortedList
),
q1
(
sortedList
),
q3
(
sortedList
),
sortedList
->
size
);
}
void
logDistribution
(
FILE
*
fd
,
time_stats_t
*
ptr
,
varArray_t
*
sortedList
,
int
dropped
)
{
fprintf
(
fd
,
"%f;%f;%f;%f;%f;%f;%d;"
,
squareRoot
(
ptr
),
(
double
)
ptr
->
max
,
*
(
double
*
)
dataArray
(
sortedList
),
median
(
sortedList
),
q1
(
sortedList
),
q3
(
sortedList
),
dropped
);
}
enum
eTypes
{
eBool
,
eInt
,
eFloat
,
eText
};
static
int
verbose
,
disable_bundling
=
0
,
cqi_flag
=
0
,
extended_prefix_flag
=
0
,
test_perf
=
0
,
subframe
=
3
,
transmission_m
=
1
,
n_rx
=
1
;
static
int
verbose
,
help
,
disable_bundling
=
0
,
cqi_flag
=
0
,
extended_prefix_flag
=
0
,
test_perf
=
0
,
subframe
=
3
,
transmission_m
=
1
,
n_rx
=
1
;
int
main
(
int
argc
,
char
**
argv
)
{
int
i
,
j
,
aa
,
u
;
...
...
@@ -505,13 +440,13 @@ int main(int argc, char **argv) {
//set_glog(LOG_DEBUG,LOG_MED);
//hapZEbm:n:Y:X:x:s:w:e:q:d:D:O:c:r:i:f:y:c:oA:C:R:g:N:l:S:T:QB:PI:LF
static
paramdef_t
options
[]
=
{
{
"awgn"
,
"
Additive white gaussian noise
"
,
PARAMFLAG_BOOL
,
strptr
:
NULL
,
defintval
:
0
,
TYPE_INT
,
0
,
NULL
,
NULL
},
{
"awgn"
,
"
Use AWGN channel and not multipath
"
,
PARAMFLAG_BOOL
,
strptr
:
NULL
,
defintval
:
0
,
TYPE_INT
,
0
,
NULL
,
NULL
},
{
"BnbRBs"
,
"The LTE bandwith in RBs (100 is 20MHz)"
,
0
,
iptr
:&
N_RB_DL
,
defintval
:
25
,
TYPE_INT
,
0
},
{
"mcs"
,
"The MCS to use"
,
0
,
iptr
:&
mcs
,
defintval
:
10
,
TYPE_INT
,
0
},
{
"nb_frame"
,
"number of frame in a test"
,
0
,
iptr
:&
n_frames
,
defintval
:
1
,
TYPE_INT
,
0
},
{
"snr"
,
"starting snr"
,
0
,
dblptr
:&
snr0
,
defdblval
:-
2
.
9
,
TYPE_DOUBLE
,
0
},
{
"wsnrInterrupt"
,
"snr int ?"
,
0
,
dblptr
:&
snr_int
,
defdblval
:
30
,
TYPE_DOUBLE
,
0
},
{
"e_snr_step"
,
"step increasin
t
snr"
,
0
,
dblptr
:&
input_snr_step
,
defdblval
:
0
.
2
,
TYPE_DOUBLE
,
0
},
{
"e_snr_step"
,
"step increasin
g
snr"
,
0
,
dblptr
:&
input_snr_step
,
defdblval
:
0
.
2
,
TYPE_DOUBLE
,
0
},
{
"rb_dynamic"
,
"number of rb in dynamic allocation"
,
0
,
iptr
:
NULL
,
defintval
:
0
,
TYPE_INT
,
0
},
{
"first_rb"
,
"first rb used in dynamic allocation"
,
0
,
iptr
:&
first_rb
,
defintval
:
0
,
TYPE_INT
,
0
},
{
"osrs"
,
"enable srs generation"
,
PARAMFLAG_BOOL
,
iptr
:&
srs_flag
,
defintval
:
0
,
TYPE_INT
,
0
},
...
...
@@ -538,37 +473,12 @@ int main(int argc, char **argv) {
{
"bundling_disable"
,
"bundling disable"
,
PARAMFLAG_BOOL
,
iptr
:&
disable_bundling
,
defintval
:
0
,
TYPE_INT
,
0
},
{
"Y"
,
"n_ch_rlz"
,
0
,
iptr
:&
n_ch_rlz
,
defintval
:
1
,
TYPE_INT
,
0
},
{
"X"
,
"abstx"
,
PARAMFLAG_BOOL
,
iptr
:&
abstx
,
defintval
:
0
,
TYPE_INT
,
0
},
{
"Operf"
,
"
test perf mode ?
"
,
0
,
iptr
:&
test_perf
,
defintval
:
0
,
TYPE_INT
,
0
},
{
"Operf"
,
"
Set the percentage of effective rate to testbench the modem performance (typically 30 and 70, range 1-100)
"
,
0
,
iptr
:&
test_perf
,
defintval
:
0
,
TYPE_INT
,
0
},
{
"verbose"
,
"display debug text"
,
PARAMFLAG_BOOL
,
iptr
:&
verbose
,
defintval
:
0
,
TYPE_INT
,
0
},
{
"help"
,
"display help and exit"
,
PARAMFLAG_BOOL
,
iptr
:&
help
,
defintval
:
0
,
TYPE_INT
,
0
},
{
""
,
""
,
0
,
iptr
:
NULL
,
defintval
:
0
,
TYPE_INT
,
0
},
};
int
l
;
for
(
l
=
0
;
options
[
l
].
optname
[
0
]
!=
0
;
l
++
)
{};
struct
option
*
long_options
=
calloc
(
sizeof
(
struct
option
),
l
);
for
(
int
i
=
0
;
options
[
i
].
optname
[
0
]
!=
0
;
i
++
)
{
long_options
[
i
].
name
=
options
[
i
].
optname
;
long_options
[
i
].
has_arg
=
options
[
i
].
paramflags
==
PARAMFLAG_BOOL
?
no_argument
:
required_argument
;
if
(
options
[
i
].
voidptr
)
switch
(
options
[
i
].
type
)
{
case
TYPE_INT
:
*
options
[
i
].
iptr
=
options
[
i
].
defintval
;
break
;
case
TYPE_DOUBLE
:
*
options
[
i
].
dblptr
=
options
[
i
].
defdblval
;
break
;
default:
printf
(
"not parsed type for default value %s
\n
"
,
options
[
i
].
optname
);
exit
(
1
);
}
continue
;
};
struct
option
*
long_options
=
parse_oai_options
(
options
);
int
option_index
;
...
...
@@ -587,6 +497,14 @@ int main(int argc, char **argv) {
*
(
double
*
)
options
[
option_index
].
dblptr
=
atof
(
optarg
);
break
;
case
TYPE_UINT8
:
*
(
uint8_t
*
)
options
[
option_index
].
dblptr
=
atoi
(
optarg
);
break
;
case
TYPE_UINT16
:
*
(
uint16_t
*
)
options
[
option_index
].
dblptr
=
atoi
(
optarg
);
break
;
default:
printf
(
"not decoded type.
\n
"
);
exit
(
1
);
...
...
@@ -683,7 +601,7 @@ int main(int argc, char **argv) {
break
;
default:
printf
(
"Wrong option
\n
"
);
printf
(
"Wrong option: %s
\n
"
,
long_options
[
option_index
].
name
);
exit
(
1
);
break
;
}
...
...
@@ -694,34 +612,12 @@ int main(int argc, char **argv) {
exit
(
1
);
}
paramdef_t
*
ptr
=
options
;
for
(
ptr
=
options
;
ptr
->
optname
[
0
]
!=
0
;
ptr
++
)
{
char
varText
[
256
]
=
"need specific display"
;
if
(
ptr
->
voidptr
!=
NULL
)
{
if
(
(
ptr
->
paramflags
&
PARAMFLAG_BOOL
)
)
strcpy
(
varText
,
*
(
bool
*
)
ptr
->
iptr
?
"True"
:
"False"
);
else
switch
(
ptr
->
type
)
{
case
TYPE_INT
:
sprintf
(
varText
,
"%d"
,
*
ptr
->
iptr
);
break
;
case
TYPE_DOUBLE
:
sprintf
(
varText
,
"%.2f"
,
*
ptr
->
dblptr
);
break
;
if
(
help
||
verbose
)
display_options_values
(
options
,
true
);
if
(
help
)
exit
(
0
);
default:
printf
(
"not decoded type
\n
"
);
exit
(
1
);
}
}
printf
(
"Option: %20s set to %s
\n
"
,
ptr
->
optname
,
varText
);
if
(
verbose
)
printf
(
"%s
\n
"
,
ptr
->
helpstr
);
}
set_parallel_conf
(
"PARALLEL_RU_L1_TRX_SPLIT"
);
set_worker_conf
(
"WORKER_ENABLE"
);
RC
.
nb_L1_inst
=
1
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment