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
spbro
OpenXG-RAN
Commits
2b5f756d
Commit
2b5f756d
authored
Jan 29, 2016
by
kaltenbe
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
getting ready for rename
parent
ec96a43d
Changes
4
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
60 additions
and
2291 deletions
+60
-2291
targets/ARCH/SODERA/USERSPACE/LIB/sodera_lib.cpp
targets/ARCH/SODERA/USERSPACE/LIB/sodera_lib.cpp
+56
-31
targets/ARCH/SODERA/lms7_trx_LTE_mimo_RF.ini
targets/ARCH/SODERA/lms7_trx_LTE_mimo_RF.ini
+0
-1128
targets/ARCH/SODERA/lms7_trx_LTE_mimo_TSG.ini
targets/ARCH/SODERA/lms7_trx_LTE_mimo_TSG.ini
+0
-1128
targets/PROJECTS/GENERIC-LTE-EPC/CONF/enb.band7.tm1.50PRB.bladerfx40.conf
.../GENERIC-LTE-EPC/CONF/enb.band7.tm1.50PRB.bladerfx40.conf
+4
-4
No files found.
targets/ARCH/SODERA/USERSPACE/LIB/sodera_lib.cpp
View file @
2b5f756d
...
@@ -86,7 +86,6 @@ typedef struct
...
@@ -86,7 +86,6 @@ typedef struct
int
handles
[
BUFFERSCOUNT
];
int
handles
[
BUFFERSCOUNT
];
int
current_handle
;
int
current_handle
;
int
samples_left_buffer
;
int
samples_left_buffer
;
int
last_transfer
;
double
sample_rate
;
double
sample_rate
;
// time offset between transmiter timestamp and receiver timestamp;
// time offset between transmiter timestamp and receiver timestamp;
...
@@ -153,40 +152,47 @@ static int trx_sodera_start(openair0_device *device)
...
@@ -153,40 +152,47 @@ static int trx_sodera_start(openair0_device *device)
// init recv and send streaming
// init recv and send streaming
printf
(
"Starting LMS Streaming
\n
"
);
s
->
rx_count
=
0
;
s
->
rx_count
=
0
;
s
->
tx_count
=
0
;
s
->
tx_count
=
0
;
s
->
rx_timestamp
=
0
;
s
->
rx_timestamp
=
0
;
s
->
current_handle
=
0
;
s
->
current_handle
=
0
;
s
->
last_transfer
=
0
;
// switch off RX
// switch off RX
uint16_t
regVal
=
SPI_read
(
&
s
->
Port
,
0x0005
);
uint16_t
regVal
=
SPI_read
(
&
s
->
Port
,
0x0005
);
SPI_write
(
&
s
->
Port
,
0x0005
,
regVal
&
~
0x6
);
SPI_write
(
&
s
->
Port
,
0x0005
,
regVal
&
~
0x6
);
if
(
s
->
channelscount
==
2
)
{
SPI_write
(
&
s
->
Port
,
0x0001
,
0x0003
);
SPI_write
(
&
s
->
Port
,
0x0007
,
0x000A
);
}
else
{
SPI_write
(
&
s
->
Port
,
0x0001
,
0x0001
);
SPI_write
(
&
s
->
Port
,
0x0007
,
0x0008
);
}
// USB FIFO reset
// USB FIFO reset
LMScomms
::
GenericPacket
ctrPkt
;
LMScomms
::
GenericPacket
ctrPkt
;
ctrPkt
.
cmd
=
CMD_USB_FIFO_RST
;
ctrPkt
.
cmd
=
CMD_USB_FIFO_RST
;
ctrPkt
.
outBuffer
.
push_back
(
0x01
);
ctrPkt
.
outBuffer
.
push_back
(
0x01
);
s
->
Port
.
TransferPacket
(
ctrPkt
);
s
->
Port
.
TransferPacket
(
ctrPkt
);
ctrPkt
.
outBuffer
[
0
]
=
0x00
;
ctrPkt
.
outBuffer
[
0
]
=
0x00
;
s
->
Port
.
TransferPacket
(
ctrPkt
);
s
->
Port
.
TransferPacket
(
ctrPkt
);
regVal
=
SPI_read
(
&
s
->
Port
,
0x0005
);
regVal
=
SPI_read
(
&
s
->
Port
,
0x0005
);
// provide timestamp, set streamTXEN, set TX/RX enable
// provide timestamp, set streamTXEN, set TX/RX enable
SPI_write
(
&
s
->
Port
,
0x0005
,(
regVal
&
~
0x20
)
|
0x6
);
SPI_write
(
&
s
->
Port
,
0x0005
,(
regVal
&
~
0x20
)
|
0x6
);
if
(
s
->
channelscount
==
2
)
{
SPI_write
(
&
s
->
Port
,
0x0001
,
0x0003
);
SPI_write
(
&
s
->
Port
,
0x0007
,
0x000A
);
}
else
{
SPI_write
(
&
s
->
Port
,
0x0001
,
0x0001
);
SPI_write
(
&
s
->
Port
,
0x0007
,
0x0008
);
}
for
(
int
i
=
0
;
i
<
BUFFERSCOUNT
;
i
++
)
for
(
int
i
=
0
;
i
<
BUFFERSCOUNT
;
i
++
)
s
->
handles
[
i
]
=
s
->
Port
.
BeginDataReading
(
&
s
->
buffers_rx
[
i
*
BUFFERSIZE
],
BUFFERSIZE
);
s
->
handles
[
i
]
=
s
->
Port
.
BeginDataReading
(
&
s
->
buffers_rx
[
i
*
BUFFERSIZE
],
BUFFERSIZE
);
printf
(
"Armed %d transfers
\n
"
,
BUFFERSCOUNT
);
return
0
;
return
0
;
}
}
...
@@ -209,6 +215,8 @@ static int trx_sodera_write(openair0_device *device, openair0_timestamp timestam
...
@@ -209,6 +215,8 @@ static int trx_sodera_write(openair0_device *device, openair0_timestamp timestam
return
0
;
return
0
;
}
}
#define DEBUG_READ 1
static
int
trx_sodera_read
(
openair0_device
*
device
,
openair0_timestamp
*
ptimestamp
,
void
**
buff
,
int
nsamps
,
int
cc
)
static
int
trx_sodera_read
(
openair0_device
*
device
,
openair0_timestamp
*
ptimestamp
,
void
**
buff
,
int
nsamps
,
int
cc
)
{
{
sodera_t
*
s
=
(
sodera_t
*
)
device
->
priv
;
sodera_t
*
s
=
(
sodera_t
*
)
device
->
priv
;
...
@@ -222,16 +230,21 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
...
@@ -222,16 +230,21 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
int
ind
=
0
;
int
ind
=
0
;
int
buffsize
;
int
buffsize
;
int
spp
;
int
spp
;
int
bufindex
;
// this assumes that each request is of size 4096 bytes (spp = 4080/4/channelscount)
// this assumes that each request is of size 4096 bytes (spp = 4080/4/channelscount)
spp
=
sizeof
(
p
->
data
)
>>
2
;
// spp = size of payload in samples
spp
=
sizeof
(
p
->
data
)
>>
2
;
// spp = size of payload in samples
spp
/=
s
->
channelscount
;
spp
/=
s
->
channelscount
;
#ifdef DEBUG_READ
printf
(
"
\n
In trx_read
\n
"
);
printf
(
"s->current_handle %d
\n
"
,
s
->
current_handle
);
printf
(
"s->samples_left_buffer %d
\n
"
,
s
->
samples_left_buffer
);
#endif
// first get rid of remaining samples
// first get rid of remaining samples
if
(
s
->
samples_left_buffer
>
0
)
{
if
(
s
->
samples_left_buffer
>
0
)
{
buffsize
=
min
(
s
->
samples_left_buffer
,
nsamps
);
buffsize
=
min
(
s
->
samples_left_buffer
,
nsamps
);
pktStart
=
((
StreamPacket_t
*
)
&
s
->
buffers_rx
[
(
s
->
current_handle
-
1
)
*
BUFFERSIZE
])
->
data
;
pktStart
=
((
StreamPacket_t
*
)
&
s
->
buffers_rx
[
s
->
current_handle
*
BUFFERSIZE
])
->
data
;
pktStart
+=
(
spp
-
s
->
samples_left_buffer
);
pktStart
+=
(
spp
-
s
->
samples_left_buffer
);
const
int
stepSize
=
s
->
channelscount
*
3
;
const
int
stepSize
=
s
->
channelscount
*
3
;
...
@@ -253,10 +266,9 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
...
@@ -253,10 +266,9 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
if
(
ind
==
nsamps
)
{
if
(
ind
==
nsamps
)
{
s
->
samples_left_buffer
-=
nsamps
;
s
->
samples_left_buffer
-=
nsamps
;
s
->
rx_count
+=
nsamps
;
s
->
rx_count
+=
nsamps
;
s
->
rx_timestamp
+=
s
->
last_transfer
;
*
ptimestamp
=
s
->
rx_timestamp
;
*
ptimestamp
=
s
->
rx_timestamp
;
s
->
last_transfer
=
nsamps
;
s
->
rx_timestamp
+=
nsamps
;
return
(
nsamps
);
return
(
nsamps
);
}
}
else
{
else
{
...
@@ -273,29 +285,38 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
...
@@ -273,29 +285,38 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
if
((
nsamps
%
spp
)
>
0
)
if
((
nsamps
%
spp
)
>
0
)
num_p
++
;
num_p
++
;
s
->
samples_left_buffer
=
(
num_p
*
spp
)
-
nsamps
;
s
->
samples_left_buffer
=
(
num_p
*
spp
)
-
nsamps
;
for
(
int
i
=
0
;
i
<
num_p
;
i
++
)
s
->
handles
[
i
]
=
s
->
Port
.
BeginDataReading
(
&
s
->
buffers_rx
[
i
*
BUFFERSIZE
],
BUFFERSIZE
);
s
->
current_handle
=
num_p
;
#ifdef DEBUG_READ
printf
(
"num_p %d
\n
"
,
num_p
);
#endif
const
int
stepSize
=
s
->
channelscount
*
3
;
const
int
stepSize
=
s
->
channelscount
*
3
;
for
(
i
=
0
;
i
<
num_p
;
i
++
)
{
for
(
i
=
0
;
i
<
num_p
;
i
++
)
{
if
(
s
->
Port
.
WaitForReading
(
s
->
handles
[
i
],
1000
)
==
false
)
{
bufindex
=
(
s
->
current_handle
+
i
)
&
(
BUFFERSCOUNT
-
1
);
printf
(
"[recv] Error: request %d samples (%d/%d) WaitForReading timed out
\n
"
,
nsamps
,
i
,
num_p
);
if
(
s
->
Port
.
WaitForReading
(
s
->
handles
[
bufindex
],
1000
)
==
false
)
{
printf
(
"[recv] Error: request %d samples (%d/%d) WaitForReading timed out
\n
"
,
nsamps
,
bufindex
,
num_p
);
*
ptimestamp
=
s
->
rx_timestamp
;
s
->
rx_timestamp
+=
samples_received
;
return
(
samples_received
);
return
(
samples_received
);
}
}
long
bytesToRead
=
BUFFERSIZE
;
long
bytesToRead
=
BUFFERSIZE
;
if
(
s
->
Port
.
FinishDataReading
(
&
s
->
buffers_rx
[
i
*
BUFFERSIZE
],
bytesToRead
,
s
->
handles
[
i
])
!=
BUFFERSIZE
)
{
if
(
s
->
Port
.
FinishDataReading
(
&
s
->
buffers_rx
[
bufindex
*
BUFFERSIZE
],
bytesToRead
,
s
->
handles
[
bufindex
])
!=
BUFFERSIZE
)
{
printf
(
"[recv] Error: request %d samples (%d/%d) WaitForReading timed out
\n
"
,
nsamps
,
i
,
num_p
);
printf
(
"[recv] Error: request %d samples (%d/%d) WaitForReading timed out
\n
"
,
nsamps
,
bufindex
,
num_p
);
*
ptimestamp
=
s
->
rx_timestamp
;
s
->
rx_timestamp
+=
samples_received
;
return
(
samples_received
);
return
(
samples_received
);
}
}
p
=
(
StreamPacket_t
*
)
&
s
->
buffers_rx
[
i
*
BUFFERSIZE
];
p
=
(
StreamPacket_t
*
)
&
s
->
buffers_rx
[
bufindex
*
BUFFERSIZE
];
// handle timestamp
// handle timestamp
if
((
i
==
0
)
&
(
ind
==
0
))
{
// grab the timestamp from HW
if
((
i
==
0
)
&
(
ind
==
0
))
{
// grab the timestamp from HW
s
->
rx_timestamp
=
p
->
counter
;
*
ptimestamp
=
p
->
counter
;
s
->
rx_timestamp
=
p
->
counter
+
nsamps
;
// for next time
#ifdef DEBUG_READ
printf
(
"RX timestamp %d
\n
"
,
s
->
rx_timestamp
);
#endif
}
}
else
{
// check the timestamp
else
{
// check the timestamp
if
(
i
==
0
)
{
if
(
i
==
0
)
{
...
@@ -304,6 +325,8 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
...
@@ -304,6 +325,8 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
return
(
ind
);
return
(
ind
);
}
}
}
}
*
ptimestamp
=
s
->
rx_timestamp
;
s
->
rx_timestamp
+=
nsamps
;
}
}
pktStart
=
p
->
data
;
pktStart
=
p
->
data
;
for
(
uint16_t
b
=
0
;
b
<
sizeof
(
p
->
data
);
b
+=
stepSize
)
{
for
(
uint16_t
b
=
0
;
b
<
sizeof
(
p
->
data
);
b
+=
stepSize
)
{
...
@@ -321,13 +344,15 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
...
@@ -321,13 +344,15 @@ static int trx_sodera_read(openair0_device *device, openair0_timestamp *ptimesta
ind
++
;
ind
++
;
}
}
samples_received
+=
spp
;
samples_received
+=
spp
;
// schedule a new transmission for this index
s
->
handles
[
bufindex
]
=
s
->
Port
.
BeginDataReading
(
&
s
->
buffers_rx
[
bufindex
*
BUFFERSIZE
],
BUFFERSIZE
);
s
->
current_handle
=
(
s
->
current_handle
+
1
)
&
(
BUFFERSCOUNT
-
1
);
}
}
//handle the error code
//handle the error code
s
->
rx_count
+=
samples_received
;
s
->
rx_count
+=
samples_received
;
// s->rx_timestamp = s->rx_md.time_spec.to_ticks(s->sample_rate);
// s->rx_timestamp = s->rx_md.time_spec.to_ticks(s->sample_rate);
*
ptimestamp
=
s
->
rx_timestamp
;
return
samples_received
;
return
samples_received
;
}
}
...
@@ -597,6 +622,7 @@ int openair0_dev_init_sodera(openair0_device* device, openair0_config_t *openair
...
@@ -597,6 +622,7 @@ int openair0_dev_init_sodera(openair0_device* device, openair0_config_t *openair
printf
(
"Cannot SetInterfaceFrequency (%f,%d,%d)
\n
"
,
cgen_freq_MHz
,
interpolation
,
decimation
);
printf
(
"Cannot SetInterfaceFrequency (%f,%d,%d)
\n
"
,
cgen_freq_MHz
,
interpolation
,
decimation
);
exit
(
-
1
);
exit
(
-
1
);
}
}
/*
// Run calibration procedure
// Run calibration procedure
float txrx_calibrationBandwidth_MHz = 5;
float txrx_calibrationBandwidth_MHz = 5;
opStatus = s->lmsControl.CalibrateTx(txrx_calibrationBandwidth_MHz);
opStatus = s->lmsControl.CalibrateTx(txrx_calibrationBandwidth_MHz);
...
@@ -609,7 +635,7 @@ int openair0_dev_init_sodera(openair0_device* device, openair0_config_t *openair
...
@@ -609,7 +635,7 @@ int openair0_dev_init_sodera(openair0_device* device, openair0_config_t *openair
printf("RX Calibration failed\n");
printf("RX Calibration failed\n");
exit(-1);
exit(-1);
}
}
*/
s
->
lmsStream
=
new
LMS_StreamBoard
(
&
s
->
Port
);
s
->
lmsStream
=
new
LMS_StreamBoard
(
&
s
->
Port
);
LMS_StreamBoard
::
Status
opStreamStatus
;
LMS_StreamBoard
::
Status
opStreamStatus
;
...
@@ -693,6 +719,5 @@ int openair0_dev_init_sodera(openair0_device* device, openair0_config_t *openair
...
@@ -693,6 +719,5 @@ int openair0_dev_init_sodera(openair0_device* device, openair0_config_t *openair
s
->
channelscount
=
openair0_cfg
[
0
].
rx_num_channels
;
s
->
channelscount
=
openair0_cfg
[
0
].
rx_num_channels
;
// TODO:
// TODO:
exit
(
-
1
);
return
0
;
return
0
;
}
}
targets/ARCH/SODERA/lms7_trx_LTE_mimo_RF.ini
deleted
100644 → 0
View file @
ec96a43d
This diff is collapsed.
Click to expand it.
targets/ARCH/SODERA/lms7_trx_LTE_mimo_TSG.ini
deleted
100644 → 0
View file @
ec96a43d
This diff is collapsed.
Click to expand it.
targets/PROJECTS/GENERIC-LTE-EPC/CONF/enb.band7.tm1.50PRB.bladerfx40.conf
View file @
2b5f756d
...
@@ -17,7 +17,7 @@ eNBs =
...
@@ -17,7 +17,7 @@ eNBs =
mobile_country_code
=
"208"
;
mobile_country_code
=
"208"
;
mobile_network_code
=
"9
2
"
;
mobile_network_code
=
"9
3
"
;
//////////
Physical
parameters
:
//////////
Physical
parameters
:
...
@@ -132,7 +132,7 @@ eNBs =
...
@@ -132,7 +132,7 @@ eNBs =
};
};
//////////
MME
parameters
:
//////////
MME
parameters
:
mme_ip_address
= ( {
ipv4
=
"192.168.1
3
.11"
;
mme_ip_address
= ( {
ipv4
=
"192.168.1
2
.11"
;
ipv6
=
"192:168:30::17"
;
ipv6
=
"192:168:30::17"
;
active
=
"yes"
;
active
=
"yes"
;
preference
=
"ipv4"
;
preference
=
"ipv4"
;
...
@@ -142,10 +142,10 @@ eNBs =
...
@@ -142,10 +142,10 @@ eNBs =
NETWORK_INTERFACES
:
NETWORK_INTERFACES
:
{
{
ENB_INTERFACE_NAME_FOR_S1_MME
=
"eth0"
;
ENB_INTERFACE_NAME_FOR_S1_MME
=
"eth0"
;
ENB_IPV4_ADDRESS_FOR_S1_MME
=
"192.168.1
3.10
/24"
;
ENB_IPV4_ADDRESS_FOR_S1_MME
=
"192.168.1
2.215
/24"
;
ENB_INTERFACE_NAME_FOR_S1U
=
"eth0"
;
ENB_INTERFACE_NAME_FOR_S1U
=
"eth0"
;
ENB_IPV4_ADDRESS_FOR_S1U
=
"192.168.1
3.10
/24"
;
ENB_IPV4_ADDRESS_FOR_S1U
=
"192.168.1
2.215
/24"
;
ENB_PORT_FOR_S1U
=
2152
;
# Spec 2152
ENB_PORT_FOR_S1U
=
2152
;
# Spec 2152
};
};
...
...
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