Hi Marcus/Ron:

I built gcc 10.1 from source with the following compiler options in the .cmake 
file:
set(CMAKE_CXX_FLAGS "-march=armv8-a -mtune=cortex-a72" CACHE STRING "" FORCE)
(Ref "New Major Release of GCC" 
https://www.raspberrypi.org/forums/viewtopic.php?t=273441)
The other options "-mfpu=neon-fp-armv8 -mfloat-abi=hard" are not taken.
Benchmark_rate now runs at 30 MSPS for 900 sec (output as follows):

[INFO] [UHD] linux; GNU C++ version 10.1.0; Boost_107100; 
UHD_4.0.0.HEAD-0-g90ce6062
[00:00:00.022222] Creating the usrp device with: ...
[INFO] [B200] Detected Device: B205mini
[INFO] [B200] Operating over USB 3.
[INFO] [B200] Initialize CODEC control...
[INFO] [B200] Initialize Radio control...
[INFO] [B200] Performing register loopback test...
[INFO] [B200] Register loopback test passed
[INFO] [B200] Setting master clock rate selection to 'automatic'.
[INFO] [B200] Asking for clock rate 16.000000 MHz...
[INFO] [B200] Actually got clock rate 16.000000 MHz.
Using Device: Single USRP:
  Device: B-Series Device
  Mboard 0: B205mini
  RX Channel: 0
    RX DSP: 0
    RX Dboard: A
    RX Subdev: FE-RX1
  TX Channel: 0
    TX DSP: 0
    TX Dboard: A
    TX Subdev: FE-TX1

[00:00:01.927367201] Setting device timestamp to 0...
[INFO] [B200] Asking for clock rate 30.000000 MHz...
[INFO] [B200] Actually got clock rate 30.000000 MHz.
[00:00:02.244691822] Testing receive rate 30.000000 Msps on 1 channels
[00:15:02.295329970] Benchmark complete.


Benchmark rate summary:
  Num received samples:     27001584054
  Num dropped samples:      0
  Num overruns detected:    0
  Num transmitted samples:  0
  Num sequence errors (Tx): 0
  Num sequence errors (Rx): 0
  Num underruns detected:   0
  Num late commands:        0
  Num timeouts (Tx):        0
  Num timeouts (Rx):        0


Done!


real 15m2.837s
user 3m35.016s
sys 10m32.291s


Benchmark_rate at 40 MSPS still causes ERROR_CODE_TIMEOUT messages after ~1 min 
15 sec.

With Device Arguments set to "recv_frame_size=16360,num_recv_frames=128" and
Realtime Scheduling turned on in the Options Block, the GRC block approach with
Qt GUI Frequency Sink runs upto 40 MSPS with a 1024-point FFT spectrum display 
refresh rate of ~1 per sec with wireless X forwarding.
Connecting a monitor instead of X forwarding allows upto 35 MSPS (complex 
int16) with combined Qt GUI Frequency Sink and waterfall
and an update rate of ~3 per sec.

uhd_fft freezes at 8 MSPS.

Thanks.

Arthur

________________________________
From: USRP-users <usrp-users-boun...@lists.ettus.com> on behalf of Ron Economos 
via USRP-users <usrp-users@lists.ettus.com>
Sent: Wednesday, September 30, 2020 5:23 AM
To: usrp-users@lists.ettus.com <usrp-users@lists.ettus.com>
Subject: Re: [USRP-users] Raspberry Pi 4B and B205mini


Just for comparison, I can easily do 10 Msps with a Beagleboard X-15 and B210. 
Also, benchmark_rate works fine at 20 Msps. This is without Thread Priority 
Scheduling.


I'm also using X forwarding (with a wired 1 Gbps Ethernet connection). The GUI 
Frequency Sink is sending 120 Mbps over the network.


Some items I'm using.


1) "recv_frame_size=16360, num_recv_frames=128" in the UHD USRP Source block

Device Address.


2) I'm building UHD with specific NEON flags. The Beagleboard X-15 has a 2-core 
32-bit armv7 processor at 1.5 GHz.


cmake -DCMAKE_CXX_FLAGS:STRING="-march=armv7ve -mfloat-abi=hard 
-mfpu=neon-vfpv4 -mtune=cortex-a15 -Wno-psabi" 
-DCMAKE_C_FLAGS:STRING="-march=armv7ve -mfloat-abi=hard -mfpu=neon-vfpv4 
-mtune=cortex-a15 -Wno-psabi" -DCMAKE_ASM_FLAGS:STRING="-march=armv7ve 
-mfloat-abi=hard -mfpu=neon-vfpv4 -mtune=cortex-a15 -g" ../


You could try some other options for the Pi4, especially if you're using a 
64-bit OS.


-march=armv8-a or -march=native

-mtune=cortex-a72

-mfpu=neon-fp-armv8


Unfortunately, I don't have a Pi4 test these options with.


Ron


On 9/29/20 17:00, Arthur Lobo via USRP-users wrote:
Hi All:

I installed UHD 4.0 and GRC 3.9 on a Raspberry Pi 4B following the procedure at:
https://wiki.gnuradio.org/index.php/InstallingGRFromSource_on_Raspberry_Pi
However I did not specify DNEON_SIMD_ENABLE=OFF in the command cmake 
-DNEON_SIMD_ENABLE=OFF -DCMAKE_INSTALL_PREFIX=/usr/local ../
while building UHD.
I also set the CPU Governor and Thread Priority Scheduling according to:
https://kb.ettus.com/USRP_Host_Performance_Tuning_Tips_and_Tricks

Testing USRP Source->Frequency Sink in GRC at 4 MSPS with a B205mini on a 
headless RPI (X forwarding to
a NUC7i7BNH PC) over USB3 shows an update rate (spectrum refresh rate on the 
display) of once per second and at 10 MSPS freezes.

Running benchmark_rate at 20 MSPS will cause ERROR_CODE_TIMEOUT messages.

I also overclocked the RPi4B to 2.2 GHz with the same result.

Any suggestions to get higher sampling rates with the RPi4B-B205mini setup?

Thanks.

Arthur



_______________________________________________
USRP-users mailing list
USRP-users@lists.ettus.com<mailto:USRP-users@lists.ettus.com>
http://lists.ettus.com/mailman/listinfo/usrp-users_lists.ettus.com

_______________________________________________
USRP-users mailing list
USRP-users@lists.ettus.com
http://lists.ettus.com/mailman/listinfo/usrp-users_lists.ettus.com

Reply via email to