Xianjun Jiao
db25dabc2b
Optimize the pkt_need_ack flag check and rate_hw_value override
2022-03-29 10:56:47 +02:00
Xianjun Jiao
6e0ffbea06
Add abnormal detection prio >= MAX_NUM_HW_QUEUE in openwifi_tx()
2022-03-29 10:48:12 +02:00
Xianjun Jiao
5e4bffc1ef
Optimize some variable type
2022-03-29 10:47:32 +02:00
Xianjun Jiao
56d25ef86c
We try to handle all tid, so qos_hdr can be optimized
2022-03-29 10:45:49 +02:00
aslaamshaafi
9f3a7b7fcf
Merge branch 'pre-release' of github.com:open-sdr/openwifi into pre-release
2022-03-29 10:21:17 +02:00
aslaamshaafi
616c431c9e
replace len_mpdu+LEN_PHY_CRC with num_dma_symbol in sdr.c because axis interface in tx_intf IP use it as num_dma_symbol.
2022-03-29 10:21:04 +02:00
Xianjun Jiao
4bdc210e86
Open the 4 queue gates all the time during xpu initialization
2022-03-29 10:13:16 +02:00
Xianjun Jiao
b597510ce3
Relax the ACK waiting condition for non block ACK case:
...
If the packet type/sub-type is ACK and the length field is 14, we believe it is ACK. No matter the fcs is valid or not
2022-03-29 10:11:14 +02:00
Xianjun Jiao
066dd1bba2
fine tuning of ack tx wait time for new design
2022-03-29 10:06:27 +02:00
Xianjun Jiao
e3fb22a4b3
gpio gain delay and rssi:
...
Fine tune the rssi calculation sync with gpio gain (add the same gpio gain smoothing like iq_rssi in FPGA)
2022-03-29 10:05:33 +02:00
Xianjun Jiao
b96c234d09
Remove unnecessary ht aggr related flag reset:
...
Don't need to reset _prev variables every time when it is not ht aggr qos data. Reason:
1. In 99.9999% cases, the ht always use qos data and goes to prio/queue_idx 2. By not resetting the variable to -1, we can have continuous aggregation packet operation in FPGA queue 2.
2. In other words, the aggregation operation for queue 2 in FPGA won't be interrupted by other non aggregation packets (control/management/beacon/etc.) that go to queue 0 (or other queues than 2).
3. From wired domain and upper level ( DSCP, AC (0~3), WMM management, 802.11D service classes and user priority (UP) ) to chip/FPGA queue index, thre should be some (complicated) mapping relationship.
4. More decent design is setting these aggregation flags (ht_aggr_start) per queue/prio here in driver. But since now only queue 2 and 0 are used (data goes to queue 2, others go to queue 0) in normal (most) cases, let's not go to the decent (complicated) solution immediately.
2022-03-29 10:04:25 +02:00
thavinga
bc98f5bb6c
Driver changes for FPGA SPI Tx LO control
...
- Manually issue Tx Quadrature calibration if frequency change is more than 100MHz
- Disable FPGA SPI module before calibration
- Add xpu reg 13 to disable control manually
2022-03-29 09:56:20 +02:00
Xianjun Jiao
f6ba34deac
Add/adjust missing register modification in tx_intf
2022-03-28 20:49:37 +02:00
Xianjun Jiao
585a56016e
openofdm_rx initialization with the help of macro definition in hw_def.h:
...
Now changing the macro in hw_def.h will change the related initialization part in all related drivers (rx_intf/xpu/openofdm_rx)
2022-03-28 20:48:36 +02:00
Xianjun Jiao
12b235cd18
Remove the unnecessary variable and code from openofdm_rx interface
2022-03-28 20:44:42 +02:00
Xianjun Jiao
54c67c7a2f
No need to consider 4 last pkt from 4 queue in master branch:
...
Always assume Linux schedule 4 priority queue to 4 FPGA queue via 1 on 1 mapping
2022-03-28 20:41:00 +02:00
Xianjun Jiao
0cbb687387
Change the default bb_gain from 290 to 250 in tx_intf:
...
- 2022-03-04 detailed test result:
- - bb_gain 290 work for 11a/g all mcs
- - bb_gain 290 work for 11n mcs 1~7 (aggr and non aggr)
- - bb_gain 290 destroy 11n mcs 0 long (MTU 1500) tx pkt due to high PAPR (Peak to Average Power Ratio)
- - bb_gain 250 work for 11n mcs 0
So, a conservative bb_gain 250 should be used
2022-03-28 20:38:25 +02:00
Xianjun Jiao
469b96d342
Remove/modify the tx_intf register API according to the new FPGA:
...
1. mixer/duc is not needed because we will not use offset tuning after the ad9361 tx lo control via FPGA is supported.
2. source selection register is not needed as well.
3. arbitrary IQ register is added.
2022-03-28 20:35:17 +02:00
Xianjun Jiao
4d39160b06
Add the missing TX_INTF_BW_20MHZ_AT_0MHZ_ANT_BOTH into tx_intf_mode
2022-03-28 20:29:26 +02:00
Xianjun Jiao
a7396dd938
Some minor unused comments
2022-03-28 20:27:36 +02:00
Xianjun Jiao
a7d34401ff
Update ad9361_rf_set_channel() for easier rssi_half_db rssi_dbm rssi_correction stuffs:
...
by using the helper functions: rssi_correction_lookup_table(), rssi_dbm_to_rssi_half_db(), rssi_half_db_to_rssi_dbm()
2022-03-28 16:44:52 +02:00
Xianjun Jiao
dbf0324b60
Restructure a bit ad9361_rf_set_channel() for actual lo tuning and priv lo variable update
2022-03-28 16:39:32 +02:00
Xianjun Jiao
534627041e
Remove unused code in ad9361_rf_set_channel()
2022-03-28 16:35:25 +02:00
Xianjun Jiao
d2bd08e02e
Add useful function definition at the beginning of sdr.c
2022-03-28 16:14:33 +02:00
Xianjun Jiao
df53600a86
Remove the unused code
2022-03-28 16:13:42 +02:00
Xianjun Jiao
747a245fd7
Add a printing via comment in openwifi_beacon_work() in case debug
2022-03-28 16:08:23 +02:00
Xianjun Jiao
dc35c00409
Add MAC addr setting support into driver via openwifi_add_interface()
2022-03-28 16:07:37 +02:00
Xianjun Jiao
dbf47e17aa
Add more print into openwifi_bss_info_changed() when vif_priv->enable_beacon
2022-03-28 16:06:24 +02:00
Xianjun Jiao
16494306ff
Add more info printing into openwifi_ampdu_action
2022-03-28 16:00:01 +02:00
Xianjun Jiao
20936d67e1
Remove unused variable from openwifi_dev_probe()
2022-03-28 15:27:50 +02:00
Xianjun Jiao
f73b4f429f
Tell mac80211 we need extra_tx_headroom = LEN_MPDU_DELIM
2022-03-28 15:27:07 +02:00
Xianjun Jiao
72d992a6ec
More correct hw flag set via ieee80211_hw_set to prevent:
...
Some client, like iPhone, always has frequent PS (Power Saving) state change like this:
sdr0: STA e2:72:49:82:a6:a0 aid 1 enters power save mode
sdr0: STA e2:72:49:82:a6:a0 aid 1 exits power save mode
sdr0: STA e2:72:49:82:a6:a0 aid 1 sending 0 filtered/0 PS frames since STA woke up
Now with these correct hw flag setting, the link is more stable
2022-03-28 15:26:35 +02:00
Xianjun Jiao
921f612e86
Only support 40MHz sps and non offset tuning now
2022-03-28 15:25:20 +02:00
Xianjun Jiao
9f07176e80
Remove the unused code in openwifi_dev_probe()
2022-03-28 15:24:49 +02:00
Xianjun Jiao
cb81054882
Add helper functions for rssi_half_db rssi_dbm conversion and rssi_correction lookup table:
...
and use them for priv->rssi_correction/priv->last_auto_fpga_lbt_th initialization in openwifi_dev_probe()
2022-03-28 15:23:53 +02:00
Xianjun Jiao
7b2f8bdfff
Align the inital actual_tx_lo/actual_rx_lo to rf_init_11n.sh:
...
Make it far from our usual 2.4/5GHz to force ad9361 to calibration while up in 2.4/5GHz due to large tuning offset from the original frequency (1GHz)
2022-03-28 15:20:03 +02:00
Xianjun Jiao
ffd377ca42
Adjust the err code and print in openwifi_dev_probe()
2022-03-28 15:17:12 +02:00
Xianjun Jiao
7b3805608b
Remove the short GI capability report from driver for:
...
stability with minor throughput loss
2022-03-28 15:14:55 +02:00
Xianjun Jiao
8e13e72bca
Add set_antenna and get_antenna implementations to ieee80211_ops
2022-03-28 15:12:50 +02:00
Xianjun Jiao
76b1a6a12c
Adjust the driver arguments while loading/insert:
...
1. test_mode 0 -- normal, no aggregation (AMPDU); test_mode 1 -- experimental, has AMPDU support
2. init_tx_att -- initial tx attenuation in dB*1000 format. example: put 20000 for 20dB
2022-03-28 15:08:01 +02:00
Xianjun Jiao
91a6d83146
Improve the openwifi_is_radio_enabled() according to the new design
2022-03-28 14:58:46 +02:00
Xianjun Jiao
68314a4614
Add the missing rf_reg_val in priv
2022-03-28 14:57:49 +02:00
Xianjun Jiao
e21492d767
Driver register initialization optimization:
...
keep software registers persistent between NIC down and up for multiple times
2022-03-28 14:55:57 +02:00
Xianjun Jiao
56203843f5
Add runtime tx/rx antenna switch support to driver
2022-03-28 14:49:15 +02:00
Xianjun Jiao
11d048d944
Re-structure/define drv reg idx. Add (drv) RF reg
2022-03-28 14:18:35 +02:00
Xianjun Jiao
d3ce582a3d
Add the missing sdrctl reg category
2022-03-28 14:16:57 +02:00
Xianjun Jiao
b196f496df
Add priv->actual_tx_lo preparing for further tx/rx related setting
2022-03-28 14:14:49 +02:00
Xianjun Jiao
2ae501ca2e
Disable TID in sdr.c:
...
By default the TID is disabled in FPGA, because we currently try to TX and RX traffic for all TIDs. So, the TID related operations in sdr.c are removed.
2022-03-28 14:02:23 +02:00
Xianjun Jiao
0b4b8cc75d
Add all Europe 5GHz channel support into driver
2022-03-28 13:58:05 +02:00
Xianjun Jiao
6a9949ee81
Replace some constants of number of NIC by MAX_NUM_VIF
2022-03-28 13:56:19 +02:00
Xianjun Jiao
61a639784b
Add sysfs file based driver/FPGA access interface
2022-03-28 12:46:49 +02:00
Xianjun Jiao
7d0af6df9e
Move sdrctl testmode cmd out to sdrctl_intf.c
2022-03-28 12:46:18 +02:00
Xianjun Jiao
8dc97f7f08
Avoid the git_rev.h issue:
...
When user download the repo instead of clone it.
2022-03-26 20:47:02 +01:00
Xianjun Jiao
ce40e055d2
Add modified ad9361_conv.c of our own:
...
Sometimes the unstable hardware can not pass the 61.44Msps self-test/calibration. Override it to 40Msps
2022-03-26 20:34:55 +01:00
mmehari
9cd584f8de
Missing aggregation rules
2022-01-06 15:12:03 +01:00
mmehari
385339ab4b
tx_interrupt if/else optimization
2022-01-06 15:11:05 +01:00
mmehari
0c0d5d827e
use FPGA fifo count registers instead of software queue_cnt
2022-01-06 15:07:50 +01:00
mmehari
c098112487
bug fixes:
...
1) update start_idx and blk_ack_ssn variables,
2) revert printing switch
3) update use_short_gi type (bool -> u8),
4) advance skb->tail by num_byte_pad for non aggregation flow
2022-01-06 14:53:39 +01:00
mmehari
2d12c07d4d
tx_intf update: PKT_INFO*_[read/write] handlers and openwifi_fpga_type
2022-01-06 14:43:32 +01:00
mmehari
f738aefa50
A-MPDU tx aggregation support
2022-01-06 14:42:01 +01:00
mmehari
261bb9eef7
A-MPDU rx aggregation support
2022-01-06 14:13:24 +01:00
Jiao Xianjun
abdb610f56
Scripts are adapted for SW HW decouple
...
To avoid openwifi-hw github submodule in openwifi. More flexible now.
2021-10-20 22:50:30 +02:00
Jiao Xianjun
72c90e5e32
Merge pull request #104 from open-sdr/fix_large_ping_delay_igent
...
Fix the issue of iGent env related big ping delay:
2021-10-13 09:32:21 +02:00
Xianjun Jiao
b60e485eb5
Fix the possible wrong last_auto_fpga_lbt_th saving:
...
1. Remove the last_auto_fpga_lbt_th saving from sdrctl set reg command. Otherwise, repeated sdrctl set reg will save wrong value into last_auto_fpga_lbt_th
2. The last_auto_fpga_lbt_th is only set in ad9361_rf_set_channel, which is called at least once by Linux after NIC is up
2021-10-04 09:59:43 +02:00
Xianjun Jiao
109b1cfd3a
Fix the issue of iGent env related big ping delay:
...
1. The issue only happens at zcu102 side, when it is tested as AP together with zedboard
2. The issue does not happen when zcu102 is client and zedboard is AP
3. The issue (most likely) does not happen in places other than iGent (like Pablo home)
4. Sometimes it does happen at my home when I test zcu102 as AP together with COTS WiFi
5. Indeed seems like the environment related. Guess some quick small packets in the environment quickly flush/round-up/mess-up the rx dma cyclic buffer, and the rx interrupt internal static variable target_buf_idx_old loses track of the background automatic rx dma cyclic buffer
6. The fix is for all board types (zcu102, zedboard, 7035, etc)
7. The driver compiling make_all.sh script generates USE_NEW_RX_INTERRUPT macro to pre_def.h to enable the new code (while keeping the old code). You can use the script as before.
8. The logic of the fix is that exhaustive search all the rx dma cyclic buffer in rx interrupt to get packet to Linux in the first place.
2021-09-29 16:52:45 +02:00
Xianjun Jiao
8598d2949d
Use drv_xpu register 0 for LBT threshold setting. 0 will enable FPGA threshold auto setting by ad9361_rf_set_channel() in sdr.c. Other value will set static threshold (that value) to FPGA
2021-09-28 21:52:31 +02:00
Xianjun Jiao
d14d06e508
CSI fuzzer feature -- document to be finished
2021-05-13 17:45:39 +02:00
Xianjun Jiao
7cf9ba6e31
Add dmesg printing option for broadcasting packet
2021-05-10 14:04:34 +02:00
Xianjun Jiao
c24e0a046d
sdr.c: change the legacy tx_itrpt1 to tx_itrpt
2021-05-05 16:53:15 +02:00
Xianjun Jiao
c687b19dde
minor update on xilinx dma driver related stuffs
2021-05-05 16:46:28 +02:00
Xianjun Jiao
56fcab2044
udpate ad9361 driver related stuffs:
...
we do not maintain our own (modified) ad9361 driver anymore! The original ad9361 driver in the Linux kernel tree can be used with some extra EXPORT_SYMBOL.
2021-05-05 16:44:39 +02:00
Xianjun Jiao
fc47ee1d62
fix the bug when retry_limit_raw==0 in sdr.c (0 is the abnormal number encountered in the monitor mode. normally it should >= 1). the bug causes 15 times transmissions for a packet if no ack is received
2021-04-05 21:53:29 +02:00
Xianjun Jiao
913a9e947c
add ack disable register in xpu in case ack needs to be disabled in monitor mode
2021-04-05 21:51:47 +02:00
Xianjun Jiao
aed16d0502
add missing soft decoding api in hw_def.h
2021-04-05 21:50:40 +02:00
Xianjun Jiao
bb0a2c5897
in xpu.v slv_reg19 and slv_reg8 are not twistted anymore. slv_reg6 is added to assist the register map in xpu more clear. separate registers for different purpose. separate registers for dynamic and static configurations in driver (sdr.c).
2021-04-05 21:49:59 +02:00
Xianjun Jiao
1196ed1fef
remove our customized xilinx_dma.c. the original xilinx_dma.c in kernel can be used now
2021-04-05 21:45:27 +02:00
Xianjun Jiao
95d3c7c5f3
remove all the compiling warnings when build 32bit driver
2021-04-05 21:42:46 +02:00
Xianjun Jiao
e1c2ba0915
turn on soft decoding by default in openofdm_rx.c driver
2021-04-05 21:41:31 +02:00
Xianjun Jiao
027d42ec5b
Fix the state unsync issue between rx interrupt and mac80211. When the issue happens, only a new packet incoming could trigger an old rx packet going to mac80211 rx. And this new fix also could work with the original xilinx dma driver. Our slightly modified xilinx dma driver is not needed anymore.
2021-03-22 23:59:41 +01:00
luz paz
46c420ae77
Follow-up typo
2021-02-04 20:42:04 +01:00
luz paz
b1dd94e387
Fix various typos
...
Found via codespell v2.1.dev0
`codespell -q 3 -L ans,filp,fils,hsi`
2021-02-04 20:41:51 +01:00
Jiao Xianjun
55c2866f7c
Merge pull request #54 from lnceballosz/master
...
NGI0 - Updating licensing aspects according REUSE
2021-02-03 16:14:49 +01:00
Jiao Xianjun
9e7be83fb0
Update xpu.c
2021-02-03 15:45:09 +01:00
Jiao Xianjun
20f54826cd
Update xilinx_dma.c
2021-02-03 15:44:30 +01:00
Jiao Xianjun
1ed5453a9a
Update make_xilinx_dma.sh
2021-02-03 15:43:59 +01:00
Jiao Xianjun
ad98df511b
Update README.md
2021-02-03 15:43:34 +01:00
Jiao Xianjun
c4306a8baf
Update tx_intf.c
2021-02-03 15:42:49 +01:00
Jiao Xianjun
541ccd3ce3
Update side_ch.h
2021-02-03 15:42:17 +01:00
Jiao Xianjun
ebf4978ece
Update side_ch.c
2021-02-03 15:41:35 +01:00
Jiao Xianjun
a415fa7ffb
Update make_driver.sh
2021-02-03 15:41:02 +01:00
Jiao Xianjun
d8d76f8862
Update sdr.h
2021-02-03 15:40:16 +01:00
Jiao Xianjun
32bfd1abde
Update sdr.c
2021-02-03 15:39:58 +01:00
Jiao Xianjun
8598124eec
Update rx_intf.c
2021-02-03 15:39:36 +01:00
Jiao Xianjun
5355b2b8ea
Update openofdm_tx.c
2021-02-03 15:38:47 +01:00
Jiao Xianjun
a3cbb385b8
Update openofdm_rx.c
2021-02-03 15:38:20 +01:00
Jiao Xianjun
9e46321135
Update make_all.sh
2021-02-03 15:37:12 +01:00
Jiao Xianjun
d5f8d0d664
Update hw_def.h
2021-02-03 15:36:30 +01:00
Jiao Xianjun
f0cca53ce0
Update ad9361_private.h
2021-02-03 15:35:25 +01:00
Jiao Xianjun
eede959f93
Update ad9361.h
2021-02-03 15:34:39 +01:00
Jiao Xianjun
56c954897d
Update ad9361.c
2021-02-03 15:34:08 +01:00