Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Reverse Engineering libbl602_wifi #29

Draft
wants to merge 150 commits into
base: master
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
150 commits
Select commit Hold shift + click to select a range
7486028
ignore build folder
Yangff Jul 21, 2021
39ab9ce
Plan: replace object files in libbl602_wifi one by one
Yangff Jul 21, 2021
d17771e
return field after added
Yangff Jul 21, 2021
80db0ac
add more reg from phy_bl602.o
Yangff Jul 21, 2021
fed3a5a
update mdm.h with regs found in phy_bl602.o
Yangff Jul 21, 2021
8898ba5
add missing bit
Yangff Jul 21, 2021
2a14d5a
add bit
Yangff Jul 21, 2021
b778274
add missing rxndpnstsmax
Yangff Jul 21, 2021
427e66d
generate agc code automatically
Yangff Jul 21, 2021
1eda44a
add used functions in header
Yangff Jul 21, 2021
2e9d772
finish phy_bl602
Yangff Jul 21, 2021
d395b9a
support parse bl svd file and find reg with addr and mask
Yangff Jul 22, 2021
ad428c3
no longer need to print the access code
Yangff Jul 22, 2021
d77652c
add missing bit
Yangff Jul 21, 2021
f910c82
add bit
Yangff Jul 21, 2021
cfbeae3
add missing rxndpnstsmax
Yangff Jul 21, 2021
26793ff
add bz_phyfunc
Yangff Jul 22, 2021
377b3c2
add bz_phy.h
Yangff Jul 22, 2021
3ce657a
add support for 0x
Yangff Jul 22, 2021
55be85b
foreach in scan
Yangff Jul 22, 2021
7261e1c
add support for 0x
Yangff Jul 22, 2021
ec71269
fix bz_phy.c
Yangff Jul 22, 2021
f32ad88
add bz_phy_reset
Yangff Jul 22, 2021
c98ef5a
new header
Yangff Jul 22, 2021
fc7f9f8
support parse bl svd file and find reg with addr and mask
Yangff Jul 22, 2021
58095db
add bz_phyfunc
Yangff Jul 22, 2021
c8111a7
more stable name
Yangff Jul 23, 2021
5a877e6
add extra information from DWARF
Yangff Jul 24, 2021
95cf6ec
add extra names
Yangff Jul 24, 2021
80069a9
import other DWARF info and done
Yangff Jul 24, 2021
16d67b8
padding to 32
Yangff Jul 24, 2021
89d1c9c
done
Yangff Jul 24, 2021
5968b95
put irqmacccatimeouten as field name
Yangff Jul 24, 2021
bdac239
fix agc
Yangff Jul 24, 2021
5ab3eca
fix var names
Yangff Jul 24, 2021
c158eea
fix regs and add phy_adapt
Yangff Jul 25, 2021
e7b27ce
fix error and warn
Yangff Jul 25, 2021
81745e5
add offset fixed svd
Yangff Jul 25, 2021
17a12b1
bug fix for field iterator
Yangff Jul 25, 2021
e3d7c8f
add phy_hal
Yangff Jul 25, 2021
da8f1d5
add phy_helper
Yangff Jul 25, 2021
b346a66
add rf_priv header
Yangff Jul 25, 2021
49a3fd6
fix return true
Yangff Jul 25, 2021
1106214
add tcal
Yangff Jul 25, 2021
9088483
add trpc
Yangff Jul 25, 2021
1ffd6cb
fix redefinition and memset
Yangff Jul 25, 2021
184aa2c
using rv32 and c11
Yangff Jul 25, 2021
f4959fc
add memcpy and min/max
Yangff Jul 25, 2021
f20f255
fix type
Yangff Jul 25, 2021
9079d1e
add phyif_utils
Yangff Jul 25, 2021
0a747be
add rf
Yangff Jul 25, 2021
7144472
typo
Yangff Jul 25, 2021
306eed0
update phy
Yangff Jul 25, 2021
9195c86
Merge branch 'bl602_wifi' into nc_wifi
Yangff Jul 26, 2021
c2828b0
update rf header
Yangff Jul 26, 2021
ddf9615
back to * -510
Yangff Jul 30, 2021
29e8a77
fix ;
Yangff Sep 22, 2021
ceb548b
headers for SOC
Yangff Oct 28, 2021
63427a3
partial link library
Yangff Oct 28, 2021
ad04214
reg scanner
Yangff Oct 28, 2021
9f91b71
preliminary decompiled code
Yangff Oct 28, 2021
50d981a
add clang build option
Yangff Dec 19, 2021
c126e6a
add github action
Yangff Dec 19, 2021
e85555d
update command
Yangff Dec 19, 2021
d140eee
update artifact path
Yangff Dec 19, 2021
babe32b
update path
Yangff Dec 19, 2021
09b7916
add ble
Yangff Dec 19, 2021
b1b6e33
implementation of bl602 wifi phy with reverse eng and existed code
Yangff Dec 19, 2021
28e501e
update readme
Yangff Dec 19, 2021
c5250a0
fix dup symbols
Yangff Dec 21, 2021
d0fa9a1
add rf_dump_status
Yangff Dec 21, 2021
5b994a0
fix volatile attr in the pointer
Yangff Dec 23, 2021
d9ccd5d
modify retry logic
Yangff Dec 23, 2021
65ad969
change volatile order in the type
Yangff Dec 23, 2021
9803c20
add some ignores
Yangff Dec 23, 2021
d65e629
move macro to global
Yangff Dec 23, 2021
05d666f
adding sysctrl and ipc
Yangff Dec 23, 2021
becea0d
update IPC regs
Yangff Dec 23, 2021
1845f40
use new macro
Yangff Dec 23, 2021
6537668
reduce warning
Yangff Dec 23, 2021
db03980
sysctrl_init()
Yangff Dec 23, 2021
0231b45
ipc and related headers
Yangff Dec 23, 2021
c1258fa
bl602_demo_wifi.elf built w/o -Wl,--gc-sections
Yangff Dec 23, 2021
935e56a
use freertos ram by default
Yangff Dec 23, 2021
450227c
add intc and fix bug on agc.h
Yangff Dec 23, 2021
d95a37f
add intc from alios
Yangff Dec 23, 2021
501051b
fix irq_index size
Yangff Dec 23, 2021
748ad2e
add hals on hal folder
Yangff Dec 23, 2021
5757b40
update hal location
Yangff Dec 23, 2021
a384bd2
add intc
Yangff Dec 23, 2021
fe5858e
fix intc
Yangff Dec 23, 2021
43d8932
fix intc
Yangff Dec 23, 2021
0a5f4ad
add hal_dma
Yangff Dec 23, 2021
c95092d
add diag_trigger
Yangff Dec 23, 2021
7e68b0b
update mac core
Yangff Dec 24, 2021
f5aae1f
add coexAutoPTIAdjEnable
Yangff Dec 24, 2021
d48da67
add arch related init code
Yangff Dec 24, 2021
0c3f483
add a useless enum
Yangff Dec 24, 2021
ab03273
use ll.h
Yangff Dec 24, 2021
29dfc41
remove dup ipc_host_disable_irq_e2a(void)
Yangff Dec 24, 2021
60f8152
satisfying bl602 linker script
Yangff Dec 24, 2021
db41e5a
fix txdesc copy
Yangff Dec 24, 2021
56ae7f5
add finished drivers
Yangff Dec 24, 2021
262c848
fix gcc build
Yangff Dec 24, 2021
7b1f08e
add header
Yangff Dec 24, 2021
f104c24
remove duplicated bz_phy_reset
Yangff Dec 24, 2021
3c14da3
add includes
Yangff Dec 24, 2021
26f7119
use stdbool.h for bool
Yangff Dec 24, 2021
9852398
add modules/common
Yangff Dec 24, 2021
181c583
ke_event
Yangff Dec 25, 2021
7cc6378
add some common functions
Yangff Dec 25, 2021
5331917
fix ABS_TIMER array
Yangff Dec 25, 2021
73b6ee3
prevent included twice
Yangff Dec 25, 2021
6f745be
fix ABS_TIMER
Yangff Dec 25, 2021
f1b74df
use ke_event
Yangff Dec 25, 2021
9252f4a
ke_task
Yangff Dec 25, 2021
3774c8d
memory management
Yangff Dec 25, 2021
7ff1855
ke_task
Yangff Dec 25, 2021
081015b
add return value
Yangff Dec 25, 2021
c9842db
other ke impl
Yangff Dec 25, 2021
8bef6a3
use assert in arch
Yangff Dec 25, 2021
8cf8ace
use ke_param2msg and ke_msg2param
Yangff Dec 25, 2021
5b5be2c
Finish ke_task
Yangff Dec 25, 2021
fc3bd59
mac
Yangff Dec 25, 2021
f692811
mac_ie
Yangff Dec 25, 2021
b5ae586
modules/dbg
Yangff Dec 26, 2021
18a9299
lmac/bl
Yangff Dec 26, 2021
3faaafb
add memcmp
Yangff Dec 28, 2021
3b6915c
add ASSERT_WARN
Yangff Dec 28, 2021
85d5ef6
moving config to seperated file
Yangff Dec 28, 2021
76d15fc
use config
Yangff Dec 28, 2021
65bf905
lmac/chan
Yangff Dec 28, 2021
3b1ba35
add CHAN_SWITCH_TO_DUR
Yangff Dec 28, 2021
cd4a68f
enable lmac/chan
Yangff Dec 28, 2021
c19b312
format, using space
Yangff Dec 28, 2021
448cf71
working on lmac/mm
Yangff Dec 30, 2021
de1eef4
update phy_init decl
Yangff Jan 1, 2022
c7761ee
add encr_ram_config
Yangff Jan 1, 2022
a72bb1c
add mm_task and mm_timer
Yangff Jan 1, 2022
9ff4dc2
finish mm_hw_config_handler
Yangff Jan 1, 2022
9086529
add more constants
Yangff Jan 1, 2022
126c182
move ipc_emb_tx_q_has_data to header
Yangff Jan 3, 2022
7b2dc52
update headers
Yangff Jan 3, 2022
cc218f1
add mm_traffic_req_ind
Yangff Jan 3, 2022
e395df6
add BCN_MAX_CSA_CPT
Yangff Jan 3, 2022
bb20810
add mm_bcn
Yangff Jan 3, 2022
4abff2d
adding new codes
Yangff Jan 31, 2023
3c5d1c0
vif done, only txl left
Yangff Feb 1, 2023
1603c92
typo
Yangff Feb 1, 2023
d10e3e2
working on txl
Yangff Feb 6, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 20 additions & 0 deletions .github/workflows/action-libbl602_wifi.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
name: Compile libbl602_wifi
on: [push]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Set up Clang
uses: egor-tensin/setup-clang@v1
with:
version: latest
platform: x64
- name: Build libbl602_wifi
run: mkdir build && cd build && cmake -DUSE_CLANG=ON .. && make -j && cd ..
- name: Archive artifacts
uses: actions/upload-artifact@v2
with:
name: libbl602_wifi
path: build/src/bl602_wifi/libbl602_wifi.a

3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -305,3 +305,6 @@ tags
[._]*.un~

# End of https://www.toptal.com/developers/gitignore/api/emacs,vim,pycharm+all,python
/build*
.vscode/
*.cache
44 changes: 44 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
cmake_minimum_required(VERSION 3.14.0)
set(CMAKE_SYSTEM_NAME Generic)

set(CMAKE_USER_MAKE_RULES_OVERRIDE cmake/c_extension.cmake)
set(CMAKE_C_OUTPUT_EXTENSION_REPLACE 1) # This is critical to producing the correct object files name for bl602 linker script

set(CMAKE_SYSTEM_PROCESSOR riscv)
SET(CMAKE_CROSSCOMPILING 1)
set(CMAKE_TRY_COMPILE_TARGET_TYPE "STATIC_LIBRARY")

option(USE_CLANG "build application with clang" OFF)
if(USE_CLANG)
set(CMAKE_C_COMPILER clang)
set(CMAKE_C_COMPILER_TARGET "riscv32-unknown-elf")
set(CMAKE_CXX_COMPILER clang++)
set(CMAKE_CXX_COMPILER_TARGET "riscv32-unknown-elf")
set(CMAKE_TOOLCHAIN_PREFIX llvm-)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fcommon ") # generate correct section for uninitialized data
else()
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fstrict-volatile-bitfields")
# this makes GCC access peripherals memory with respect to word align
# rather than byte align (e.g. sb/lb)
endif()

set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -march=rv32imfc -mabi=ilp32f -DARCH_RISCV")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c11 -march=rv32imfc -mabi=ilp32f -DARCH_RISCV")

project(bl602_re VERSION 0.1.0)

include_directories(./src/include)
include(cmake/add_module.cmake)

option(FREERTOS_RAM "build with freertos ram" ON)
if (FREERTOS_RAM)
include_directories(./components/bl602/freertos_riscv_ram/config)
include_directories(./components/bl602/freertos_riscv_ram/portable/GCC/RISC-V)
include_directories(./components/bl602/freertos_riscv_ram/portable/GCC/RISC-V/chip_specific_extensions/RV32I_CLINT_no_extensions)
else()
include_directories(./components/bl602/freertos_riscv/config)
include_directories(./components/bl602/freertos_riscv/portable/GCC/RISC-V)
include_directories(./components/bl602/freertos_riscv/portable/GCC/RISC-V/chip_specific_extensions/RV32I_CLINT_no_extensions)
endif()

add_subdirectory(./src/bl602_wifi)
11 changes: 11 additions & 0 deletions README.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,17 @@ Whatever you do, do not insert proprietary `Copyright (C) RivieraWaves` code in
RivieraWaves code is known to be easily available on GitHub with simple searches, but avoid looking at it, unless you wish to forfeit your right to directly contribute code here.
====

== BL602 wifi
I'm working on the reverse engineering of the bl602 wifi.

The source code is located in `src/` instead of `components/**`.

Using `cmake` to build the wifi module and it will automatically add other components
from the original `libbl602_wifi.a` and create a new one.

This should generate a usable `libbl602_wifi.a` to link against other bl602 components.
But, I'm still working on this and it hasn't been tested yet.

== Resources

* https://github.com/pine64/bl602-docs[Pine64 SDK fork's documentation], if you figure something out that's documentation-worthy, please update that documentation.
Expand Down
237 changes: 237 additions & 0 deletions alios/reg_intc.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,237 @@
/**
* @file reg_intc.h
* @brief Definitions of the INTC HW block registers and register access functions.
*
* @defgroup REG_INTC REG_INTC
* @ingroup REG
* @{
*
* @brief Definitions of the INTC HW block registers and register access functions.
*/
#ifndef _REG_INTC_H_
#define _REG_INTC_H_

#include "co_int.h"
#include "_reg_intc.h"
#include "compiler.h"
#include "arch.h"
#include "reg_access.h"

/** @brief Number of registers in the REG_INTC peripheral.
*/
#define REG_INTC_COUNT 17

/** @brief Decoding mask of the REG_INTC peripheral registers from the CPU point of view.
*/
#define REG_INTC_DECODING_MASK 0x0000007F

/**
* @name IRQ_STATUS register definitions
*
* @{
*/

/// Address of the IRQ_STATUS register
#define INTC_IRQ_STATUS_ADDR 0x10910000
/// Offset of the IRQ_STATUS register from the base address
#define INTC_IRQ_STATUS_OFFSET 0x00000000
/// Index of the IRQ_STATUS register
#define INTC_IRQ_STATUS_INDEX 0x00000000
/// Reset value of the IRQ_STATUS register
#define INTC_IRQ_STATUS_RESET 0x00000000
/// Number of elements of the IRQ_STATUS register array
#define INTC_IRQ_STATUS_COUNT 2

/**
* @brief Returns the current value of the IRQ_STATUS register.
* The IRQ_STATUS register will be read and its value returned.
* @param[in] reg_idx Index of the register
* @return The current value of the IRQ_STATUS register.
*/
__INLINE uint32_t intc_irq_status_get(int reg_idx)
{
ASSERT_ERR(reg_idx <= 1);
return REG_PL_RD(INTC_IRQ_STATUS_ADDR + reg_idx * 4);
}

/// @}

/**
* @name IRQ_RAW_STATUS register definitions
*
* @{
*/

/// Address of the IRQ_RAW_STATUS register
#define INTC_IRQ_RAW_STATUS_ADDR 0x10910008
/// Offset of the IRQ_RAW_STATUS register from the base address
#define INTC_IRQ_RAW_STATUS_OFFSET 0x00000008
/// Index of the IRQ_RAW_STATUS register
#define INTC_IRQ_RAW_STATUS_INDEX 0x00000002
/// Reset value of the IRQ_RAW_STATUS register
#define INTC_IRQ_RAW_STATUS_RESET 0x00000000
/// Number of elements of the IRQ_RAW_STATUS register array
#define INTC_IRQ_RAW_STATUS_COUNT 2

/**
* @brief Returns the current value of the IRQ_RAW_STATUS register.
* The IRQ_RAW_STATUS register will be read and its value returned.
* @param[in] reg_idx Index of the register
* @return The current value of the IRQ_RAW_STATUS register.
*/
__INLINE uint32_t intc_irq_raw_status_get(int reg_idx)
{
ASSERT_ERR(reg_idx <= 1);
return REG_PL_RD(INTC_IRQ_RAW_STATUS_ADDR + reg_idx * 4);
}

/// @}

/**
* @name IRQ_UNMASK_SET register definitions
*
* @{
*/

/// Address of the IRQ_UNMASK_SET register
#define INTC_IRQ_UNMASK_SET_ADDR 0x10910010
/// Offset of the IRQ_UNMASK_SET register from the base address
#define INTC_IRQ_UNMASK_SET_OFFSET 0x00000010
/// Index of the IRQ_UNMASK_SET register
#define INTC_IRQ_UNMASK_SET_INDEX 0x00000004
/// Reset value of the IRQ_UNMASK_SET register
#define INTC_IRQ_UNMASK_SET_RESET 0x00000000
/// Number of elements of the IRQ_UNMASK_SET register array
#define INTC_IRQ_UNMASK_SET_COUNT 2

/**
* @brief Returns the current value of the IRQ_UNMASK_SET register.
* The IRQ_UNMASK_SET register will be read and its value returned.
* @param[in] reg_idx Index of the register
* @return The current value of the IRQ_UNMASK_SET register.
*/
__INLINE uint32_t intc_irq_unmask_get(int reg_idx)
{
ASSERT_ERR(reg_idx <= 1);
return REG_PL_RD(INTC_IRQ_UNMASK_SET_ADDR + reg_idx * 4);
}

/**
* @brief Sets the IRQ_UNMASK_SET register to a value.
* The IRQ_UNMASK_SET register will be written.
* @param[in] reg_idx Index of the register
* @param value - The value to write.
*/
__INLINE void intc_irq_unmask_set(int reg_idx, uint32_t value)
{
ASSERT_ERR(reg_idx <= 1);
REG_PL_WR(INTC_IRQ_UNMASK_SET_ADDR + reg_idx * 4, value);
}

/// @}

/**
* @name IRQ_UNMASK_CLEAR register definitions
*
* @{
*/

/// Address of the IRQ_UNMASK_CLEAR register
#define INTC_IRQ_UNMASK_CLEAR_ADDR 0x10910018
/// Offset of the IRQ_UNMASK_CLEAR register from the base address
#define INTC_IRQ_UNMASK_CLEAR_OFFSET 0x00000018
/// Index of the IRQ_UNMASK_CLEAR register
#define INTC_IRQ_UNMASK_CLEAR_INDEX 0x00000006
/// Reset value of the IRQ_UNMASK_CLEAR register
#define INTC_IRQ_UNMASK_CLEAR_RESET 0x00000000
/// Number of elements of the IRQ_UNMASK_CLEAR register array
#define INTC_IRQ_UNMASK_CLEAR_COUNT 2

/**
* @brief Sets the IRQ_UNMASK_CLEAR register to a value.
* The IRQ_UNMASK_CLEAR register will be written.
* @param[in] reg_idx Index of the register
* @param value - The value to write.
*/
__INLINE void intc_irq_unmask_clear(int reg_idx, uint32_t value)
{
ASSERT_ERR(reg_idx <= 1);
REG_PL_WR(INTC_IRQ_UNMASK_CLEAR_ADDR + reg_idx * 4, value);
}

/// @}

/**
* @name IRQ_POLARITY register definitions
*
* @{
*/

/// Address of the IRQ_POLARITY register
#define INTC_IRQ_POLARITY_ADDR 0x10910020
/// Offset of the IRQ_POLARITY register from the base address
#define INTC_IRQ_POLARITY_OFFSET 0x00000020
/// Index of the IRQ_POLARITY register
#define INTC_IRQ_POLARITY_INDEX 0x00000008
/// Reset value of the IRQ_POLARITY register
#define INTC_IRQ_POLARITY_RESET 0x00000000
/// Number of elements of the IRQ_POLARITY register array
#define INTC_IRQ_POLARITY_COUNT 2

/**
* @brief Returns the current value of the IRQ_POLARITY register.
* The IRQ_POLARITY register will be read and its value returned.
* @param[in] reg_idx Index of the register
* @return The current value of the IRQ_POLARITY register.
*/
__INLINE uint32_t intc_irq_polarity_get(int reg_idx)
{
ASSERT_ERR(reg_idx <= 1);
return REG_PL_RD(INTC_IRQ_POLARITY_ADDR + reg_idx * 4);
}

/**
* @brief Sets the IRQ_POLARITY register to a value.
* The IRQ_POLARITY register will be written.
* @param[in] reg_idx Index of the register
* @param value - The value to write.
*/
__INLINE void intc_irq_polarity_set(int reg_idx, uint32_t value)
{
ASSERT_ERR(reg_idx <= 1);
REG_PL_WR(INTC_IRQ_POLARITY_ADDR + reg_idx * 4, value);
}

/// @}

/**
* @name IRQ_INDEX register definitions
*
* @{
*/

/// Address of the IRQ_INDEX register
#define INTC_IRQ_INDEX_ADDR 0x10910040
/// Offset of the IRQ_INDEX register from the base address
#define INTC_IRQ_INDEX_OFFSET 0x00000040
/// Index of the IRQ_INDEX register
#define INTC_IRQ_INDEX_INDEX 0x00000010
/// Reset value of the IRQ_INDEX register
#define INTC_IRQ_INDEX_RESET 0x00000000

/**
* @brief Returns the current value of the IRQ_INDEX register.
* The IRQ_INDEX register will be read and its value returned.
* @return The current value of the IRQ_INDEX register.
*/
__INLINE uint32_t intc_irq_index_get(void)
{
return REG_PL_RD(INTC_IRQ_INDEX_ADDR);
}

/// @}


#endif // _REG_INTC_H_

/// @}
Binary file modified blobs/bl602_demo_wifi.elf
100755 → 100644
Binary file not shown.
2 changes: 0 additions & 2 deletions blobs/bz_phy.c
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,5 @@ void bz_phy_reset(void)
write_volatile_4(0x40002810,uVar1 & 0xfffffffe);
uVar1 = read_volatile_4(0x40002810);
write_volatile_4(0x40002810,uVar1 | 0x2);
uVar1 = read_volatile_4(0x40002cac);
write_volatile_4(0x40002cac,uVar1 & 0xffffffe0 | 0x4);
return;
}
Loading